This page contains a list of all command argument types. 1 Java Edition 1.1 brigadier:bool 1.2 brigadier:double 1.3 brigadier:float 1.4 brigadier:integer 1.5 brigadier:long 1.6 brigadier:string 1.7 minecraft:angle 1.8 minecraft:blockpos 1.9 minecraft:blockpredicate 1.10 minecraft:blockstate 1.11 minecraft:color 1.12 minecraft:columnpos 1.13 minecraft:component 1.14 minecraft:dimension 1.15. Original Kick Of Singomakers EDM One Shots Mega Pack / SEOM Legacy One Shots / SEOM Kicks In Keys / SEE Big Hard Kick 20 F.wav SERGIUS 2 years ago Kick Clubby Of Vengeance Essential Club Sounds Vol. 2 / VEC2 Bassdrum Clubby 047.
- Drumloop 3/4 breakbeats 1 - 4 bar - 135 BPM - mp3 version Drumloop 3/4 breakbeats 1 - 4 bar - 135 BPM - ogg version Drumloop 3/4 breakbeats 1 - 4 bar - 135 BPM - waveform Drumloop 3/4 breakbeats 1 - 4 bar - 135 BPM - spectrogram 5333.33. Play / pause loop.
- Equal(vec2) or equal(x, y) or equal(array) returns true if the incoming coordinates are the same as this vector's. Returns: boolean. Abs(returnNew) Return a Vec2 that contains the absolute value of each of this vector's parts. If returnNew is truthy, create a new Vec2 and return it. Otherwise apply the absolute values to to this.
- Shader
- Variable types
- Layout qualifiers
- Interface blocks
- Shader stages:
A number of OpenGL Shading Language variables and definitions can have layout qualifiers associated with them. Layout qualifiers affect where the storage for a variable comes from, as well as other user-facing properties of a particular definition.
All layout qualifiers are defined with a common syntax:
The texture2D function returns a texel, i.e. The (color) value of the texture for the given coordinates. The function has one input parameter of the type sampler2D and one input parameter of the type vec2: sampler, the uniform the texture is bound to, and coord, the 2-dimensional coordinates of the texel to look up.
The qualifier values are specific to a particular use of layouts. The qualifiers are order-independent, unless otherwise noted. Some qualifiers can have values assigned to them, as with qualifier2 in the above example.
In the above, value must be an integer literal, unless you are using OpenGL 4.4 or ARB_enhanced_layouts, in which case it may be an Integral Constant Expression (aka: a compile-time constant).
Layout qualifiers are sometimes used to define various options for different shader stages. These shader stage options apply to the input of the shader stage or the output. In these definitions, variable definition will just be in or out.
In OpenGL 4.2 or ARB_shading_language_420pack, a definition can have multiple layout() segments to qualify the definition, and the same qualifier can appear multiple times for the same definition. When this happens, the last defined value for mutually-exclusive qualifiers or for numeric qualifiers prevails.
Interface layouts
Shader stage input and output variables define a shader stage's interface. Depending on the available feature set, these variables can have layout qualifiers that define what resources they use.
Vertex shader attribute index
Vertex shader inputs can specify the attribute index that the particular input uses. This is done with this syntax:
With this syntax, you can forgo the use of glBindAttribLocation entirely. If you try to combine the two and they conflict, the layout qualifier always wins.
Attributes that take up multiple attribute slots will be given a sequential block of that number of attributes in order starting with the given attribute. For example:
This will allocate the attribute indices 2, 3, 4, and 5.
Fragment shader buffer output
Fragment shader outputs can specify the buffer index that a particular output writes to. This uses the same syntax as vertex shader attributes:
As with vertex shader inputs, this allows the user to forgo the use of glBindFragDataLocation. Similarly, the values in the shader override the values provided by this function.
For dual source blending, the syntax includes a second qualifier:
Again, this allows one to forgo the use of glBindFragDataLocationIndexed.
Program separation linkage
Core in version | 4.6 | |
---|---|---|
Core since version | 4.1 | |
Core ARB extension | ARB_separate_shader_objects |
When dynamically using separate programs, the correspondence between the outputs of one program and the inputs of the next is important. This correspondence typically happens the same way as when doing dynamic linkage: inputs and outputs must match by name, type, and qualifiers exactly (with a few exceptions).
However, it is possible to tag variables with an index, such that they correspond by the index instead of by name. This changes the interface matching process a bit, allowing outputs that aren't consumed by the next stage and so forth.
This index is provided by location qualifier. This applies to loose input/output variables. Input and output#Interface block variables need additional functionality to use these.
For example, given a vertex shader that provides these outputs:
This allows the consuming shader to use different names and even types:
This still results in an interface match.
Location sizes: Interfaces between programs can be of various types, even user-defined structs and arrays. Some such types consume multiple locations. When a type that consumes multiple locations is used, they will consume locations sequentially. It is a compile/link-time error to have ranges of variables overlap their locations (unless they have different components specifiers and doesn't overlap their component usage).
Scalars and vector types that are not doubles all take up one location. The double and dvec2 types also take one location, while dvec3 and dvec4 take up 2 locations. Structs take up locations based on their member types, in-order. Arrays also take up locations based on their array sizes.
Here are some examples:
The number of available locations is implementation-defined, and it cannot be queried. However, it will be at least one-fourth of GL_MAX_VARYING_COMPONENTS.
Block member locations
Core in version | 4.6 | |
---|---|---|
Core since version | 4.4 | |
Core ARB extension | ARB_enhanced_layouts |
With this feature, The location qualifier can be used on input/output interface block definitions and members.
The block as a whole can have a location qualifier. This will allocate a sequential sets of locations, giving the first member the given location and incrementing from there. The size of the individual members is computed the same way as above.
A particular member of a block can have a location qualifier. However, this only works if the block itself is qualified or if all members of the block have a qualifier.
If the block has a qualifier, then a member's qualifier overrides the block computed qualifier. It also resets the block's computed qualifier, so that subsequent unqualified members will be computed relative to the most recent explicit qualifier. Here is an example:
Interface components
Core in version | 4.6 | |
---|---|---|
Core since version | 4.4 | |
Core ARB extension | ARB_enhanced_layouts |
There are limits on the locations of input and output variables (of all kinds). These limits are based on an implicit assumption in the API that the resources being passed around are done so as groups of 4-element vectors of data. This is why a mat2 takes up 2 locations, while a vec4 only takes up 1, even though they both are 4 floats in size. The mat2 is considered to be passed as two vec4s; the last two components of each vector simply go unused.
It is possible to reclaim some of this unused space. To do this, you declare two (or more) variables that use the same location, but use different components within that location.
This is done using the component layout qualifier. You must use a location qualifier when using component, even if the variable would have an implicitly assigned location from an interface block declaration. If a variable does not have an explicit component qualifier, it is as through it were set to 0.
The component qualifier specifies the starting component that the variable will use. It is illegal to set the component on a variable whose type would cause it to exceed the boundaries of a 4-element vector. So if you have a vec3, the component can only be 0 or 1.
If you set two interface variables to the same location, the variables must use components such that the used space in that location does not overlap. So you can't pack a vec3 in the same location with a vec2, but you can pack two floats with a vec2.
Arrays (and arrays of arrays) can also have components assigned. This will assign the component to each location that the array covers. So it is possible to do the following:
Two (or more) variables that share the same location must satisfy the following conditions:
- Share the same base data type. So you can have alias locations for floating-point types, or integer types (signed and unsigned does not matter for this), but you cannot have a float sit alongside an integer.
- Use the same interpolation qualifiers.
The component qualifier can be used for any shader stage input/output declaration. This includes interfaces between shaders, fragment shader outputs, tessellation patch variables, and so forth. However, it may not be used on:
- Variables of matrix types
- Variables of structs types
- Interface blocks (this qualifier can be on members of a block, but not on the block itself)
- Arrays of types on this list (arrays of non-matrix basic types are fine).
For Vertex Attributes and Fragment Shader Outputs, OpenGL still treats each location as though it were a single variable. So glVertexAttribPointer feeds data to all of the input variables for that location. Any components used by the shader that are not provided by the array are filled in as normal (with zeros, except for the last which gets a 1). And glDrawBuffers pulls data from all of the output variables for that location.
Binding points
Core in version | 4.6 | |
---|---|---|
Core since version | 4.2 | |
Core ARB extension | ARB_shading_language_420pack |
Buffer backed interface blocks and all opaque types have a setting which represents an index in the GL context where a buffer or texture object is bound so that it can be accessed through that interface. These binding points, like input attribute indices and output data locations, can be set from within the shader. This is done by using the 'binding' layout qualifier:
The first line is the equivalent of getting the uniform location for 'mainTexture' and setting its uniform value to '3'. Similarly, the second line is the equivalent of getting the 'MainBlock' block location and setting its block index to '1'.
This capacity only sets the initial binding index. OpenGL code can later modify it if it wishes.
Image formats
Core in version | 4.6 | |
---|---|---|
Core since version | 4.2 | |
Core ARB extension | ARB_shader_image_load_store |
Image uniform variables have qualifiers that define the format that all reading operations will convert the data into and all writing operations will convert the data from. They are grouped into 3 categories: floating-point, signed-integer, and unsigned-integer formats. These are the possible values:
- Floating-point layout image formats:
- rgba32f
- rgba16f
- rg32f
- rg16f
- r11f_g11f_b10f
- r32f
- r16f
- rgba16
- rgb10_a2
- rgba8
- rg16
- rg8
- r16
- r8
- rgba16_snorm
- rgba8_snorm
- rg16_snorm
- rg8_snorm
- r16_snorm
- r8_snorm
- Signed integer layout image formats:
- rgba32i
- rgba16i
- rgba8i
- rg32i
- rg16i
- rg8i
- r32i
- r16i
- r8i
- Unsigned integer layout image formats:
- rgba32ui
- rgba16ui
- rgb10_a2ui
- rgba8ui
- rg32ui
- rg16ui
- rg8ui
- r32ui
- r16ui
- r8ui
Atomic counter storage
Core in version | 4.6 | |
---|---|---|
Core since version | 4.2 | |
Core ARB extension | ARB_shader_atomic_counters |
Atomic Counter variables have special layout settings that define where within a buffer object a particular variable comes from. These are required; there are no alternate methods to set these fields.
Atomic counters use two layout qualifier parameters. The binding defines which Buffer Object bound to the given index in the indexed target GL_ATOMIC_COUNTER_BUFFER will provide the storage for this atomic counter. The binding parameter is not optional.
Atomic counters also have an optional offset parameter. The offset is the byte offset from the beginning of the range bound to the target to the location where this variable gets its 32-bits of storage.
The offset parameter is not required. If it is not specified, then the offset will be 4 bytes larger than the offset previously used for that binding, starting at 0 if none were previously specified. For example:
The offsets for these are as follows:
- one: 12
- two: 16 (12 + 4)
- three: 4 (specified)
- four: 0 (unused bindings offsets always start with a default of 0).
- five: 4
- six: 20
- seven: 8 (the last value used for binding 0 was 4, so this one gets 8).
Interface block memory layout
Variables declared in interface blocks that get their storage from buffers (uniform blocks or shader storage blocks) have a number of layout qualifiers to define the packing and ordering of the variables defined in the block.
Explicit uniform location
Core in version | 4.6 | |
---|---|---|
Core since version | 4.3 | |
Core ARB extension | ARB_explicit_uniform_location |
Uniforms defined outside of Interface Blocks have a location. This location can be directly assigned in the shader, using this syntax:
Calling glGetUniformLocation(prog, 'modelToWorldMatrix') is guaranteed to return 2. It is illegal to assign the same uniform location to two uniforms in the same shader or the same program. Even if those two uniforms have the same name and type, and are defined in different shader stages, it is not legal to explicitly assign them the same uniform location; a linker error will occur.
All non-array/struct types will be assigned a single location. Arrays and structs will be assigned sequentially increasing locations, starting with the given location. Given this:
some_mats will be assigned all of the uniform locations on the half-open range [2, 12). This will apply for nested types. Consider the following:
Each Thingy takes up 4 uniform locations; the first three going to an_array and the fourth going to foo. Thus, some_thingies takes up 24 uniform locations.
Uploading arrays of uniforms with one of the glUniform*v functions will work. For example, uniform location 2 represents the array `some_thingies[0].an_array`. As such, you can upload an array of vec4s to this array with glUniform4fv(2, 3, ...);.
If two uniforms in a program are given the same explicit location, then they refer to the same uniform. This means they must also match in variable name, type, array-index, qualifiers, etc. The following would be illegal:
some_mats takes up 10 uniform locations, from [2, 12). But since some_vecs starts at uniform location 6, it would have the same location as some_mats[4]. But it wouldn't have the same name, or same type, or other characteristics. Even if some_vecs was a mat4, it would not be the same, since they don't have the same name or same array index.
The maximum number of available locations within a single program is GL_MAX_UNIFORM_LOCATIONS, which will be at least 1024 locations. You may not use a uniform location outside of the range [0, GL_MAX_UNIFORM_LOCATIONS), nor may the sequential assignment of uniform locations due to array/struct aggregation go outside of this range.
Subroutine qualifiers
Core in version | 4.6 | |
---|---|---|
Core since version | 4.3 | |
Core ARB extension | ARB_explicit_uniform_location |
Shader Subroutines use a number of resources that can be automatically assigned to each shader stage at link time. However, the user can explicitly define them within the shader text as well, to avoid having to query them.
Subroutine functions each have a specific index that identifies that particular subroutine among all subroutines in a shader stage. This subroutine can be set from within a shader using the index layout qualifier:
This sets the particular subroutine function definition to index 2. No two subroutine functions may have the same index. Also, this index is subject to the limitations on the number of subroutines in a shader stage.
Each subroutine uniform variable within a shader stage has a particular position in that stage's list of subroutine uniforms. This location in the array can be set using the location layout qualifer:
This means that array index 1 in the call to glUniformSubroutines refers to the variable subroutineVariableName.
The number of active subroutine uniforms for this shader stage will be the largest location + 1. This means that some 'active' uniform locations may be unused. If the above example were the only subroutine uniform, then the number of active subroutine uniforms will be considered to be 2, with location 0 going unusued.
Arrays of subroutine uniforms are always assigned consecutive uniform locations.
If some uniforms are user-assigned and some are linker-assigned, the linker will fill in the unused indices first, before increasing the number of active uniforms. So the number of active subroutine uniforms can be larger than this. The linker will never assign a subroutine uniform to a user-assigned subroutine uniform, even if the user-assigned one is not active.
The linking can fail if user-defined subroutine uniform assignments do not leave enough room for linker-assigned ones. Linker-assigned subroutine uniform locations for arrays must also be consecutively assigned, so if there is insufficient space to assign that many uniform locations, the linking will fail.
Transform feedback qualifiers
Core in version | 4.6 | |
---|---|---|
Core since version | 4.4 | |
Core ARB extension | ARB_enhanced_layouts |
Layout qualifiers can be used to define which output variables are captured in Transform Feedback operations. When these qualifiers are set in a shader, they completely override any attempt to set the transform feedback outputs from OpenGL via glTransformFeedbackVaryings.
Any output variable or output interface block declared with the xfb_offset layout qualifier will be part of the transform feedback output. This qualifier must be specified with an integer byte offset. The offset is the number of bytes from the beginning of a vertex to be written to the current buffer to this particular output variable.
The offsets of contained values (whether in arrays, structs, or members of an interface block if the whole block has an offset) are computed, based on the sizes of prior components to pack them in the order specified. Any explicitly provided offsets are not allowed to violate alignment restrictions. So if a definition contains a double (either directly or indirectly), the offset must be 8-byte aligned.
Members of interface blocks can have their offsets specified directly on them, which overrides any computed offsets. Also, all members of an interface block are not required to be written to outputs (though that will happens if you set the xfb_offset on the block itself). Stream assignments for a geometry shader are required to be the same for all members of a block, but offsets are not.
Different variables being captured are assigned to buffer binding indices. Offset assignments are separate for the separate buffers. It is a linker error for two variables captured by the same buffer to have overlapping byte offsets, whether automatically computed or explicitly assigned.
An explicit buffer assignment is made by using the xfb_buffer qualifier on the same declaration as the offset qualifier. This takes an integer which defines the buffer binding index that the captured output(s) is/are associated with. The integer must be less than GL_MAX_TRANSFORM_FEEDBACK_BUFFERS.
Any offsets for global variables or interface blocks that do not specify a buffer explicitly will use the current buffer. The current buffer is set as follows:
All following offsets for globals that do not explicitly specify a buffer will use 1 as their buffer. The initial current buffer for a shader is 0.
Variables can have xfb_buffer assigned to them without xfb_offset. This does nothing and will be ignored.
Interface blocks have a special association with buffers. Each interface block is associated with a buffer, regardless of whether any of its members are captured. The buffer is either the current buffer as defined above or a buffer explicitly specified by xfb_buffer.
As previously stated, all members of a block do not have to be captured. However, if any members of a block are captured, they must all be captured to the same buffer. Specifically, the buffer associated with that block. It is an error to use xfb_buffer on a member if the buffer index you provide is different from the index used by the block.
As an example:
Each buffer has the concept of a stride. This represents the byte count from the beginning of one captured vertex to the beginning of the next. It is computed by taking the output with the highest xfb_offset value, adding its size to that offset, and then aligning the computed value to the base alignment of the buffer. The buffer's alignment is 4, unless it captures any double-precision values in which case it is 8. This means you do not need to manually pad structures for alignment, as you did with outside shader setting.
The stride for a buffer can also be explicitly set using the xfb_stride layout qualifier. This allows you to add extra space at the end, perhaps to skip data that will not change. A compilation error will result if the stride you specify is:
- Too small, given the offsets and computed sizes of the captured data for that buffer.
- Not properly aligned. It must be at least 4 byte aligned, and it must be 8 byte aligned if the buffer captures any double-precision values.
The stride for a buffer is set as follows:
Linking errors will result if any captured outputs within a buffer overlap in space or violate padding. For example:
Compiler/linker errors will result if you are using Geometry Shader output streams and two outputs from different streams are routed to the same buffer.
Shader stage options
Many shader stages have options that control some aspect of how they work. These are defined within the shader using layout qualifiers.
Tessellation control output vertex count
Core in version | 4.6 | |
---|---|---|
Core since version | 4.0 | |
Core ARB extension | ARB_tessellation_shader |
Tessellation Control Shaders (TCS) output patches with a particular vertex count. This is defined by a layout qualifier:
The TCS will be invoked once for each vertex output.
Tessellation evaluation options
The Tessellation Evaluation Shader (requires GL 4.0 or ARB_tessellation_shader) has a large number of special layout qualifiers that control its behavior.
Geometry shader primitives
Geometry Shaders take a particular primitive type as input and return a particular primitive type as outputs. Also, geometry shaders have a defined maximum number of vertices that they can output. These specifications cannot be used on a variable definition; it can only be used on the qualifiers in and out as a whole.
For inputs, the primitive type can be any of the following:
- points
- lines
- lines_adjacency
- triangles
- triangles_adjacency
For outputs, the primitive type can be any of the following:
- points
- line_strip
- triangle_strip
The value of max_vertices defines the maximum number of vertices the geometry shader can every output in a single invocation.
Fragment shader coordinate origin
The gl_FragCoordbuilt-in variable represents the location of the fragment in window-space. There are two layout qualifiers that can affect this. These are specified by redeclaring the predefined variable.
The qualifier origin_upper_left specifies that gl_FragCoord will have the origin (0, 0) in the upper-left of the screen. The standard OpenGL convention is to have it in the lower-left. This does not change the Z or W of the gl_FragCoord value.
The qualifier pixel_center_integer specifies that the X and Y of gl_FragCoord will be shifted by a half-pixel, so that the center of each pixel is an integer value. The standard OpenGL convention puts the integer values at the corner of the pixel.
These are used as follows:
Early fragment tests
Core in version | 4.6 | |
---|---|---|
Core since version | 4.2 | |
Core ARB extension | ARB_shader_image_load_store |
By the OpenGL specification, the depth and stencil tests are performed after the fragment shader's execution (implementations can and will do it before the fragment shader, but only if it won't affect the apparent output). However, with a fragment shader's ability to write to arbitrary images and buffers in OpenGL 4.2+, it is useful to be able to enforce early tests. This can be done in GL 4.2 (or with ARB_shader_image_load_store):
Any writes to gl_FragDepth in a shader that defines this will be ignored.
A generic library useful when you need to work with points/vectors in 2d space.
Use
Stuff to Note: most of the Vec2's methods take a returnNew
as the last parameter. If passed a truthy value, a new vector will be returned to you. Otherwise the operation will be applied to this
and this
will be returned.
Also, since Infinity
and NaN
are so insidious, this library will throw as soon as it detects either of these so you can take action to fix your data/algorithm.
Supported operations
change([fn])
Add an observer fn
that will be called whenever this vector changes. Calling this method without a function causes it to notify observers.
fn
signature: function(vec, prev) {}
- where prev
is a clone of the vector before the last operation.
this function returns the passed fn
returns: Vec2
ignore([fn])
Pass a fn
to remove it from the observers list. Calling this function without a fn
will remove all observers.
returns: Vec2
set(x, y [, notify]) or set(vec2 [, notify])
Sets the x
and y
coordinates of this vector. If false
is passed for notify
, none of the observers will be called.
returns: Vec2
zero()
Sets the x
and y
of this vector to 0
returns: Vec2
clone()
Returns a clone of this vector.
Note: this does not clone observers
returns: Vec2
negate([returnNew])
Negate the x
and y
coords of this vector. If returnNew
is truthy, a new vector with the negated coordinates will be returned.
returns: Vec2
add(x, y [, returnNew]) or add(array, [, returnNew]) or add(vec2 [, returnNew])
Add the x
and y
to this vector's coordinates.
If returnNew
is truthy, return a new vector containing the resulting coordinates. Otherwise apply them to this vector and return it.
returns: Vec2
subtract(x, y [, returnNew]) or subtract(array, [, returnNew]) or subtract(vec2 [, returnNew])
returns: Vec2
multiply(scalar [, returnNew]) or multiply(x, y [, returnNew]) or multiply(array, [, returnNew]) or multiply(vec2 [, returnNew])
Multiply this vectors components with the incoming, returning a clone if returnNew
is truthy.
returns: Vec2
divide(scalar [, returnNew]) or divide(x, y [, returnNew]) or divide(array, [, returnNew]) or divide(vec2 [, returnNew])
Divide this vectors components by the incoming, returning a clone if returnNew
is truthy.
note: this method will throw if you attempt to divide by zero or pass values that cause NaNs
returns: Vec2
rotate(radians [, inverse [, returnNew]])
Rotate this vector's cordinates around (0,0)
. If returnNew
is specified, a new Vec2
will be created and populated with the result and returned. Otherwise the result is applied to this vector and this
is returned.
inverse
- inverts the direction of the rotation
returnNew
- causes the result to be applied to a new Vec2
, otherwise the result is applied to this
returns: Vec2
length()
Returns the length of this vector from (0,0)
returns: double
lengthSquared()
Returns the length of this vector prior to the Math.sqrt
call.
This is usefull when you don't need to know the actual distance, but need a normalized value to compare with another Vec2#lengthSquared
or similar.
returns: double
distance(vec2)
returns: the distance between this vector and the incoming
nearest(array)
returns: closest vector in array to this vector.
normalize([returnNew])
Normalizes this vector. If returnNew
is truthy, a new vector populated with the normalized coordinates will be returned.
returns: Vec2
equal(vec2) or equal(x, y) or equal(array)
returns true if the incoming coordinates are the same as this vector's
returns: boolean
Vec Package
abs([returnNew])
Return a Vec2
that contains the absolute value of each of this vector's parts.
If returnNew
is truthy, create a new Vec2
and return it. Otherwise apply the absolute values to to this
.
returns: Vec2
min(vec)
Return a Vec2
consisting of the smallest values from this vector and the incoming
When returnNew is truthy, a new Vec2
will be returned otherwise the minimum values in either this or vec
will be applied to this vector.
returns: Vec2
max(vec)
Return a Vec2
consisting of the largest values from this vector and the incoming
Vec2 Sample Pack
When returnNew is truthy, a new Vec2
will be returned otherwise the maximum values in either this
or vec
will be applied to this vector.
returns: Vec2
clamp(low, high [, returnNew])
Clamp the coordinates of this vector to the high/low of the incoming vec2s. If returnNew
apply the result to the new vector and return. Otherwise apply to this vector.
returns: Vec2
Vec2 Pack Download
lerp(vec, amount [, returnNew])
Perform linear interpolation between this vector and the incoming.
amount
- the percentage along the path to place the vector
returnNew
- if truthy
, apply the result to a new vector and return it, otherwise return this
returns: Vec2
skew([returnNew])
Returns a vector set with the (-y,x)
coordinates of this vector. If returnNew
a new vector is created and the operation is applied to the new vector.
returns: Vec2
dot()
returns: double
perpDot()
returns: double
angleTo(vec)
returns the angle from this vector to the incoming.
returns: double
isPointOnLine(start, end)
where start
and end
are vec2-like (e.g. start.x
and start.y
)
returns: boolean
toArray()
returns: [x, y]
fromArray(array)
Applies the [0]
to this.x
and [1]
to this.y
returns: Vec2
toJSON()
returns: { x: ..., y: ...}
toString()
returns: '(x, y)'
Install
Browser
Node
install with npm
and then require it!
License
MIT (see LICENSE.txt)