ObjFW
Loading...
Searching...
No Matches
OFMatrix4x4 Class Reference

A 4x4 matrix of floats. More...

#include <OFMatrix4x4.h>

Inheritance diagram for OFMatrix4x4:
OFObject <OFCopying> <OFObject>

Instance Methods

(instancetype) - initWithValues:
 Initializes an already allocated 4x4 matrix with the specified values.
 
(void) - multiplyWithMatrix:
 Multiplies the receiver with the specified matrix on the left side and the receiver on the right side.
 
(void) - translateWithVector:
 Translates the matrix with the specified vector.
 
(void) - scaleWithVector:
 Scales the matrix with the specified vector.
 
(OFVector4D- transformedVector:
 Transforms the specified vector according to the matrix.
 
(void) - transformVectors:count:
 Transforms the specified vectors in-place according to the matrix.
 
- Instance Methods inherited from OFObject
(instancetype) - init
 Initializes an already allocated object.
 
(nullable OFMethodSignature *) - methodSignatureForSelector:
 Returns the method signature for the specified selector.
 
(void) - dealloc
 Deallocates the object.
 
(void) - performSelector:afterDelay:
 Performs the specified selector after the specified delay.
 
(void) - performSelector:withObject:afterDelay:
 Performs the specified selector with the specified object after the specified delay.
 
(void) - performSelector:withObject:withObject:afterDelay:
 Performs the specified selector with the specified objects after the specified delay.
 
(void) - performSelector:withObject:withObject:withObject:afterDelay:
 Performs the specified selector with the specified objects after the specified delay.
 
(void) - performSelector:withObject:withObject:withObject:withObject:afterDelay:
 Performs the specified selector with the specified objects after the specified delay.
 
(void) - performSelector:onThread:waitUntilDone:
 Performs the specified selector on the specified thread.
 
(void) - performSelector:onThread:withObject:waitUntilDone:
 Performs the specified selector on the specified thread with the specified object.
 
(void) - performSelector:onThread:withObject:withObject:waitUntilDone:
 Performs the specified selector on the specified thread with the specified objects.
 
(void) - performSelector:onThread:withObject:withObject:withObject:waitUntilDone:
 Performs the specified selector on the specified thread with the specified objects.
 
(void) - performSelector:onThread:withObject:withObject:withObject:withObject:waitUntilDone:
 Performs the specified selector on the specified thread with the specified objects.
 
(void) - performSelectorOnMainThread:waitUntilDone:
 Performs the specified selector on the main thread.
 
(void) - performSelectorOnMainThread:withObject:waitUntilDone:
 Performs the specified selector on the main thread with the specified object.
 
(void) - performSelectorOnMainThread:withObject:withObject:waitUntilDone:
 Performs the specified selector on the main thread with the specified objects.
 
(void) - performSelectorOnMainThread:withObject:withObject:withObject:waitUntilDone:
 Performs the specified selector on the main thread with the specified objects.
 
(void) - performSelectorOnMainThread:withObject:withObject:withObject:withObject:waitUntilDone:
 Performs the specified selector on the main thread with the specified objects.
 
(void) - performSelector:onThread:afterDelay:
 Performs the specified selector on the specified thread after the specified delay.
 
(void) - performSelector:onThread:withObject:afterDelay:
 Performs the specified selector on the specified thread with the specified object after the specified delay.
 
(void) - performSelector:onThread:withObject:withObject:afterDelay:
 Performs the specified selector on the specified thread with the specified objects after the specified delay.
 
(void) - performSelector:onThread:withObject:withObject:withObject:afterDelay:
 Performs the specified selector on the specified thread with the specified objects after the specified delay.
 
(void) - performSelector:onThread:withObject:withObject:withObject:withObject:afterDelay:
 Performs the specified selector on the specified thread with the specified objects after the specified delay.
 
(nullable id) - forwardingTargetForSelector:
 This method is called when resolveClassMethod: or resolveInstanceMethod: returned false. It should return a target to which the message should be forwarded.
 
(void) - doesNotRecognizeSelector:
 Handles messages which are not understood by the receiver.
 
- Instance Methods inherited from <OFObject>
(unsigned long) - hash
 Returns a hash for the object.
 
(unsigned int) - retainCount
 Returns the retain count.
 
(bool) - isProxy
 Returns whether the object is a proxy object.
 
(bool) - isKindOfClass:
 Returns a boolean whether the object is of the specified kind.
 
(bool) - isMemberOfClass:
 Returns a boolean whether the object is a member of the specified class.
 
(bool) - respondsToSelector:
 Returns a boolean whether the object responds to the specified selector.
 
(nullable IMP- methodForSelector:
 Returns the implementation for the specified selector.
 
(nullable id) - performSelector:
 Performs the specified selector.
 
(nullable id) - performSelector:withObject:
 Performs the specified selector with the specified object.
 
(nullable id) - performSelector:withObject:withObject:
 Performs the specified selector with the specified objects.
 
(nullable id) - performSelector:withObject:withObject:withObject:
 Performs the specified selector with the specified objects.
 
(nullable id) - performSelector:withObject:withObject:withObject:withObject:
 Performs the specified selector with the specified objects.
 
(bool) - isEqual:
 Checks two objects for equality.
 
(instancetype) - retain
 Increases the retain count.
 
(void) - release
 Decreases the retain count.
 
(instancetype) - autorelease
 Adds the object to the topmost autorelease pool of the thread's autorelease pool stack.
 
(instancetype) - self
 Returns the receiver.
 
(bool) - allowsWeakReference
 Returns whether the object allows a weak reference.
 
(bool) - retainWeakReference
 Retain a weak reference to this object.
 
- Instance Methods inherited from <OFCopying>
(id) - copy
 Copies the object.
 

Class Methods

(OFMatrix4x4 *) + identityMatrix
 Returns the 4x4 identity matrix.
 
(instancetype) + matrixWithValues:
 Creates a new 4x4 matrix with the specified values.
 
- Class Methods inherited from OFObject
(void) + load
 A method which is called once when the class is loaded into the runtime.
 
(void) + unload
 A method which is called when the class is unloaded from the runtime.
 
(void) + initialize
 A method which is called the moment before the first call to the class is being made.
 
(instancetype) + alloc
 Allocates memory for an instance of the class and sets up the memory pool for the object.
 
(Class) + class
 Returns the class.
 
(OFString *) + className
 Returns the name of the class as a string.
 
(bool) + isSubclassOfClass:
 Returns a boolean whether the class is a subclass of the specified class.
 
(nullable Class) + superclass
 Returns the superclass of the class.
 
(bool) + instancesRespondToSelector:
 Checks whether instances of the class respond to a given selector.
 
(bool) + conformsToProtocol:
 Checks whether the class conforms to a given protocol.
 
(nullable IMP+ instanceMethodForSelector:
 Returns the implementation of the instance method for the specified selector.
 
(nullable OFMethodSignature *) + instanceMethodSignatureForSelector:
 Returns the method signature of the instance method for the specified selector.
 
(OFString *) + description
 Returns a description for the class, which is usually the class name.
 
(nullable IMP+ replaceClassMethod:withMethodFromClass:
 Replaces a class method with a class method from another class.
 
(nullable IMP+ replaceInstanceMethod:withMethodFromClass:
 Replaces an instance method with an instance method from another class.
 
(void) + inheritMethodsFromClass:
 Adds all methods from the specified class to the class that is the receiver.
 
(bool) + resolveClassMethod:
 Try to resolve the specified class method.
 
(bool) + resolveInstanceMethod:
 Try to resolve the specified instance method.
 
(id) + copy
 Returns the class.
 

Properties

float(* values )[4]
 A 2D array of the 4x4 floats of the matrix in row-major format.
 
- Properties inherited from OFObject
OFStringclassName
 The name of the object's class.
 
OFStringdescription
 A description for the object.
 

Detailed Description

A 4x4 matrix of floats.

Method Documentation

◆ initWithValues:

- (instancetype) initWithValues: (const float [ 4][4]) values

Initializes an already allocated 4x4 matrix with the specified values.

Parameters
valuesA 2D array of 4x4 floats in row-major format
Returns
An initialized OFMatrix4x4

◆ matrixWithValues:

+ (instancetype) matrixWithValues: (const float [ 4][4]) values

Creates a new 4x4 matrix with the specified values.

Parameters
valuesA 2D array of 4x4 floats in row-major format
Returns
A new, autoreleased OFMatrix4x4

◆ multiplyWithMatrix:

- (void) multiplyWithMatrix: (OFMatrix4x4 *) matrix

Multiplies the receiver with the specified matrix on the left side and the receiver on the right side.

Parameters
matrixThe matrix to multiply the receiver with

◆ scaleWithVector:

- (void) scaleWithVector: (OFVector3D) vector

Scales the matrix with the specified vector.

Parameters
vectorThe vector to scale the matrix with

◆ transformedVector:

- (OFVector4D) transformedVector: (OFVector4D) vector

Transforms the specified vector according to the matrix.

Parameters
vectorThe vector to transform
Returns
The transformed vector

◆ transformVectors:count:

- (void) transformVectors: (OFVector4D *) vectors
count: (size_t) count 

Transforms the specified vectors in-place according to the matrix.

Warning
Please note that the vectors must be 16 byte aligned! This is required to allow SIMD optimizations. Passing a pointer to vectors that are not 16 byte aligned will crash if SIMD optimizations are enabled.
Parameters
vectorsThe vectors to transform
countThe count of the specified vectors

◆ translateWithVector:

- (void) translateWithVector: (OFVector3D) vector

Translates the matrix with the specified vector.

Parameters
vectorThe vector to translate the matrix with

Property Documentation

◆ values

- (float(*) values
readnonatomicassign

A 2D array of the 4x4 floats of the matrix in row-major format.

These may be modified directly.


The documentation for this class was generated from the following files: