mirror of https://github.com/mode777/rayjs.git
Descriptions for math functions, extend readme
This commit is contained in:
parent
18b6c7c5f9
commit
eb3ffd8e35
File diff suppressed because one or more lines are too long
|
@ -4,13 +4,10 @@ import { ApiDescription, ApiFunction } from "./api";
|
||||||
import { RayLibHeader } from "./raylib-header";
|
import { RayLibHeader } from "./raylib-header";
|
||||||
|
|
||||||
function parseMathHeader(): RayLibFunction[] {
|
function parseMathHeader(): RayLibFunction[] {
|
||||||
return readFileSync("thirdparty/raylib/src/raymath.h", 'utf8')
|
const i = readFileSync("thirdparty/raylib/src/raymath.h", 'utf8')
|
||||||
.split("\n")
|
const m = [...i.matchAll(/((?:\/\/ .+\n)*)RMAPI\s+([\w<>]+)\s+([\w<>]+)\((.*)\)/gm)]
|
||||||
.filter(x => x.startsWith("RMAPI"))
|
const res = m.map(groups => {
|
||||||
.map(inputString => {
|
const args = groups[4].split(',').filter(x => x !== 'void').map(arg => {
|
||||||
const matches = inputString.match(/^RMAPI\s+([\w<>]+)\s+([\w<>]+)\((.*)\)$/);
|
|
||||||
if(!matches) throw new Error("Unable to match " + inputString)
|
|
||||||
const args = matches[3].split(',').filter(x => x !== 'void').map(arg => {
|
|
||||||
arg = arg.trim().replace(" *", "* ")
|
arg = arg.trim().replace(" *", "* ")
|
||||||
const frags = arg.split(' ')
|
const frags = arg.split(' ')
|
||||||
const name = frags.pop()
|
const name = frags.pop()
|
||||||
|
@ -18,27 +15,30 @@ function parseMathHeader(): RayLibFunction[] {
|
||||||
|
|
||||||
return { name: name || "", type: type }
|
return { name: name || "", type: type }
|
||||||
})
|
})
|
||||||
|
const comments = groups[1].split('\n').map(x => x.replace("// ","")).join('\n').trim()
|
||||||
return {
|
return {
|
||||||
name: matches[2],
|
name: groups[3],
|
||||||
returnType: matches[1],
|
returnType: groups[2],
|
||||||
params: args,
|
params: args,
|
||||||
description: ""
|
description: comments
|
||||||
}
|
}
|
||||||
});
|
})
|
||||||
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
function main(){
|
function main(){
|
||||||
|
|
||||||
const mathApi = parseMathHeader();
|
// Load the pre-generated raylib api
|
||||||
writeFileSync("bindings/raylib_math_api.json", JSON.stringify(mathApi))
|
|
||||||
|
|
||||||
const api = <RayLibApi>JSON.parse(readFileSync("thirdparty/raylib/parser/output/raylib_api.json", 'utf8'))
|
const api = <RayLibApi>JSON.parse(readFileSync("thirdparty/raylib/parser/output/raylib_api.json", 'utf8'))
|
||||||
|
|
||||||
api.functions.push({
|
api.functions.push({
|
||||||
name: "SetModelMaterial",
|
name: "SetModelMaterial",
|
||||||
description: "Replace material in slot materialIndex",
|
description: "Replace material in slot materialIndex",
|
||||||
returnType: "void",
|
returnType: "void",
|
||||||
params: [{type: "Model *",name:"model"},{type:"int",name:"materialIndex"},{type:"Material",name:"material"}]
|
params: [{type: "Model *",name:"model"},{type:"int",name:"materialIndex"},{type:"Material",name:"material"}]
|
||||||
})
|
})
|
||||||
|
const mathApi = parseMathHeader();
|
||||||
|
writeFileSync("bindings/raylib_math_api.json", JSON.stringify(mathApi))
|
||||||
mathApi.forEach(x => api.functions.push(x))
|
mathApi.forEach(x => api.functions.push(x))
|
||||||
|
|
||||||
const apiDesc = new ApiDescription(api)
|
const apiDesc = new ApiDescription(api)
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 87 KiB |
|
@ -42,15 +42,19 @@ while (!windowShouldClose()) // Detect window close button or ESC key
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update bunnies
|
// Update bunnies
|
||||||
|
const width = getScreenWidth()
|
||||||
|
const height = getScreenHeight()
|
||||||
for (let i = 0; i < bunniesCount; i++)
|
for (let i = 0; i < bunniesCount; i++)
|
||||||
{
|
{
|
||||||
bunnies[i].position.x += bunnies[i].speed.x;
|
const bunny = bunnies[i]
|
||||||
bunnies[i].position.y += bunnies[i].speed.y;
|
|
||||||
|
|
||||||
if (((bunnies[i].position.x + texBunny.width/2) > getScreenWidth()) ||
|
bunny.position.x += bunny.speed.x;
|
||||||
((bunnies[i].position.x + texBunny.width/2) < 0)) bunnies[i].speed.x *= -1;
|
bunny.position.y += bunny.speed.y;
|
||||||
if (((bunnies[i].position.y + texBunny.height/2) > getScreenHeight()) ||
|
|
||||||
((bunnies[i].position.y + texBunny.height/2 - 40) < 0)) bunnies[i].speed.y *= -1;
|
if (((bunny.position.x + texBunny.width/2) > width) ||
|
||||||
|
((bunny.position.x + texBunny.width/2) < 0)) bunny.speed.x *= -1;
|
||||||
|
if (((bunny.position.y + texBunny.height/2) > height) ||
|
||||||
|
((bunny.position.y + texBunny.height/2 - 40) < 0)) bunny.speed.y *= -1;
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -62,13 +66,14 @@ while (!windowShouldClose()) // Detect window close button or ESC key
|
||||||
|
|
||||||
for (let i = 0; i < bunniesCount; i++)
|
for (let i = 0; i < bunniesCount; i++)
|
||||||
{
|
{
|
||||||
|
const bunny = bunnies[i]
|
||||||
// NOTE: When internal batch buffer limit is reached (MAX_BATCH_ELEMENTS),
|
// NOTE: When internal batch buffer limit is reached (MAX_BATCH_ELEMENTS),
|
||||||
// a draw call is launched and buffer starts being filled again;
|
// a draw call is launched and buffer starts being filled again;
|
||||||
// before issuing a draw call, updated vertex data from internal CPU buffer is send to GPU...
|
// before issuing a draw call, updated vertex data from internal CPU buffer is send to GPU...
|
||||||
// Process of sending data is costly and it could happen that GPU data has not been completely
|
// Process of sending data is costly and it could happen that GPU data has not been completely
|
||||||
// processed for drawing while new data is tried to be sent (updating current in-use buffers)
|
// processed for drawing while new data is tried to be sent (updating current in-use buffers)
|
||||||
// it could generates a stall and consequently a frame drop, limiting the number of drawn bunnies
|
// it could generates a stall and consequently a frame drop, limiting the number of drawn bunnies
|
||||||
drawTexture(texBunny, bunnies[i].position.x, bunnies[i].position.y, bunnies[i].color);
|
drawTexture(texBunny, bunny.position.x, bunny.position.y, bunny.color);
|
||||||
}
|
}
|
||||||
|
|
||||||
drawRectangle(0, 0, screenWidth, 40, BLACK);
|
drawRectangle(0, 0, screenWidth, 40, BLACK);
|
||||||
|
|
|
@ -1121,221 +1121,244 @@ declare function setMusicPan(music: Music, pan: number): void;
|
||||||
declare function getMusicTimeLength(music: Music): number;
|
declare function getMusicTimeLength(music: Music): number;
|
||||||
/** Get current music time played (in seconds) */
|
/** Get current music time played (in seconds) */
|
||||||
declare function getMusicTimePlayed(music: Music): number;
|
declare function getMusicTimePlayed(music: Music): number;
|
||||||
/** */
|
/** Clamp float value */
|
||||||
declare function clamp(value: number, min: number, max: number): number;
|
declare function clamp(value: number, min: number, max: number): number;
|
||||||
/** */
|
/** Calculate linear interpolation between two floats */
|
||||||
declare function lerp(start: number, end: number, amount: number): number;
|
declare function lerp(start: number, end: number, amount: number): number;
|
||||||
/** */
|
/** Normalize input value within input range */
|
||||||
declare function normalize(value: number, start: number, end: number): number;
|
declare function normalize(value: number, start: number, end: number): number;
|
||||||
/** */
|
/** Remap input value within input range to output range */
|
||||||
declare function remap(value: number, inputStart: number, inputEnd: number, outputStart: number, outputEnd: number): number;
|
declare function remap(value: number, inputStart: number, inputEnd: number, outputStart: number, outputEnd: number): number;
|
||||||
/** */
|
/** Wrap input value from min to max */
|
||||||
declare function wrap(value: number, min: number, max: number): number;
|
declare function wrap(value: number, min: number, max: number): number;
|
||||||
/** */
|
/** Check whether two given floats are almost equal */
|
||||||
declare function floatEquals(x: number, y: number): number;
|
declare function floatEquals(x: number, y: number): number;
|
||||||
/** */
|
/** Vector with components value 0.0f */
|
||||||
declare function vector2Zero(): Vector2;
|
declare function vector2Zero(): Vector2;
|
||||||
/** */
|
/** Vector with components value 1.0f */
|
||||||
declare function vector2One(): Vector2;
|
declare function vector2One(): Vector2;
|
||||||
/** */
|
/** Add two vectors (v1 + v2) */
|
||||||
declare function vector2Add(v1: Vector2, v2: Vector2): Vector2;
|
declare function vector2Add(v1: Vector2, v2: Vector2): Vector2;
|
||||||
/** */
|
/** Add vector and float value */
|
||||||
declare function vector2AddValue(v: Vector2, add: number): Vector2;
|
declare function vector2AddValue(v: Vector2, add: number): Vector2;
|
||||||
/** */
|
/** Subtract two vectors (v1 - v2) */
|
||||||
declare function vector2Subtract(v1: Vector2, v2: Vector2): Vector2;
|
declare function vector2Subtract(v1: Vector2, v2: Vector2): Vector2;
|
||||||
/** */
|
/** Subtract vector by float value */
|
||||||
declare function vector2SubtractValue(v: Vector2, sub: number): Vector2;
|
declare function vector2SubtractValue(v: Vector2, sub: number): Vector2;
|
||||||
/** */
|
/** Calculate vector length */
|
||||||
declare function vector2Length(v: Vector2): number;
|
declare function vector2Length(v: Vector2): number;
|
||||||
/** */
|
/** Calculate vector square length */
|
||||||
declare function vector2LengthSqr(v: Vector2): number;
|
declare function vector2LengthSqr(v: Vector2): number;
|
||||||
/** */
|
/** Calculate two vectors dot product */
|
||||||
declare function vector2DotProduct(v1: Vector2, v2: Vector2): number;
|
declare function vector2DotProduct(v1: Vector2, v2: Vector2): number;
|
||||||
/** */
|
/** Calculate distance between two vectors */
|
||||||
declare function vector2Distance(v1: Vector2, v2: Vector2): number;
|
declare function vector2Distance(v1: Vector2, v2: Vector2): number;
|
||||||
/** */
|
/** Calculate square distance between two vectors */
|
||||||
declare function vector2DistanceSqr(v1: Vector2, v2: Vector2): number;
|
declare function vector2DistanceSqr(v1: Vector2, v2: Vector2): number;
|
||||||
/** */
|
/** Calculate angle between two vectors
|
||||||
|
NOTE: Angle is calculated from origin point (0, 0) */
|
||||||
declare function vector2Angle(v1: Vector2, v2: Vector2): number;
|
declare function vector2Angle(v1: Vector2, v2: Vector2): number;
|
||||||
/** */
|
/** Calculate angle defined by a two vectors line
|
||||||
|
NOTE: Parameters need to be normalized
|
||||||
|
Current implementation should be aligned with glm::angle */
|
||||||
declare function vector2LineAngle(start: Vector2, end: Vector2): number;
|
declare function vector2LineAngle(start: Vector2, end: Vector2): number;
|
||||||
/** */
|
/** Scale vector (multiply by value) */
|
||||||
declare function vector2Scale(v: Vector2, scale: number): Vector2;
|
declare function vector2Scale(v: Vector2, scale: number): Vector2;
|
||||||
/** */
|
/** Multiply vector by vector */
|
||||||
declare function vector2Multiply(v1: Vector2, v2: Vector2): Vector2;
|
declare function vector2Multiply(v1: Vector2, v2: Vector2): Vector2;
|
||||||
/** */
|
/** Negate vector */
|
||||||
declare function vector2Negate(v: Vector2): Vector2;
|
declare function vector2Negate(v: Vector2): Vector2;
|
||||||
/** */
|
/** Divide vector by vector */
|
||||||
declare function vector2Divide(v1: Vector2, v2: Vector2): Vector2;
|
declare function vector2Divide(v1: Vector2, v2: Vector2): Vector2;
|
||||||
/** */
|
/** Normalize provided vector */
|
||||||
declare function vector2Normalize(v: Vector2): Vector2;
|
declare function vector2Normalize(v: Vector2): Vector2;
|
||||||
/** */
|
/** Transforms a Vector2 by a given Matrix */
|
||||||
declare function vector2Transform(v: Vector2, mat: Matrix): Vector2;
|
declare function vector2Transform(v: Vector2, mat: Matrix): Vector2;
|
||||||
/** */
|
/** Calculate linear interpolation between two vectors */
|
||||||
declare function vector2Lerp(v1: Vector2, v2: Vector2, amount: number): Vector2;
|
declare function vector2Lerp(v1: Vector2, v2: Vector2, amount: number): Vector2;
|
||||||
/** */
|
/** Calculate reflected vector to normal */
|
||||||
declare function vector2Reflect(v: Vector2, normal: Vector2): Vector2;
|
declare function vector2Reflect(v: Vector2, normal: Vector2): Vector2;
|
||||||
/** */
|
/** Rotate vector by angle */
|
||||||
declare function vector2Rotate(v: Vector2, angle: number): Vector2;
|
declare function vector2Rotate(v: Vector2, angle: number): Vector2;
|
||||||
/** */
|
/** Move Vector towards target */
|
||||||
declare function vector2MoveTowards(v: Vector2, target: Vector2, maxDistance: number): Vector2;
|
declare function vector2MoveTowards(v: Vector2, target: Vector2, maxDistance: number): Vector2;
|
||||||
/** */
|
/** Invert the given vector */
|
||||||
declare function vector2Invert(v: Vector2): Vector2;
|
declare function vector2Invert(v: Vector2): Vector2;
|
||||||
/** */
|
/** Clamp the components of the vector between
|
||||||
|
min and max values specified by the given vectors */
|
||||||
declare function vector2Clamp(v: Vector2, min: Vector2, max: Vector2): Vector2;
|
declare function vector2Clamp(v: Vector2, min: Vector2, max: Vector2): Vector2;
|
||||||
/** */
|
/** Clamp the magnitude of the vector between two min and max values */
|
||||||
declare function vector2ClampValue(v: Vector2, min: number, max: number): Vector2;
|
declare function vector2ClampValue(v: Vector2, min: number, max: number): Vector2;
|
||||||
/** */
|
/** Check whether two given vectors are almost equal */
|
||||||
declare function vector2Equals(p: Vector2, q: Vector2): number;
|
declare function vector2Equals(p: Vector2, q: Vector2): number;
|
||||||
/** */
|
/** Vector with components value 0.0f */
|
||||||
declare function vector3Zero(): Vector3;
|
declare function vector3Zero(): Vector3;
|
||||||
/** */
|
/** Vector with components value 1.0f */
|
||||||
declare function vector3One(): Vector3;
|
declare function vector3One(): Vector3;
|
||||||
/** */
|
/** Add two vectors */
|
||||||
declare function vector3Add(v1: Vector3, v2: Vector3): Vector3;
|
declare function vector3Add(v1: Vector3, v2: Vector3): Vector3;
|
||||||
/** */
|
/** Add vector and float value */
|
||||||
declare function vector3AddValue(v: Vector3, add: number): Vector3;
|
declare function vector3AddValue(v: Vector3, add: number): Vector3;
|
||||||
/** */
|
/** Subtract two vectors */
|
||||||
declare function vector3Subtract(v1: Vector3, v2: Vector3): Vector3;
|
declare function vector3Subtract(v1: Vector3, v2: Vector3): Vector3;
|
||||||
/** */
|
/** Subtract vector by float value */
|
||||||
declare function vector3SubtractValue(v: Vector3, sub: number): Vector3;
|
declare function vector3SubtractValue(v: Vector3, sub: number): Vector3;
|
||||||
/** */
|
/** Multiply vector by scalar */
|
||||||
declare function vector3Scale(v: Vector3, scalar: number): Vector3;
|
declare function vector3Scale(v: Vector3, scalar: number): Vector3;
|
||||||
/** */
|
/** Multiply vector by vector */
|
||||||
declare function vector3Multiply(v1: Vector3, v2: Vector3): Vector3;
|
declare function vector3Multiply(v1: Vector3, v2: Vector3): Vector3;
|
||||||
/** */
|
/** Calculate two vectors cross product */
|
||||||
declare function vector3CrossProduct(v1: Vector3, v2: Vector3): Vector3;
|
declare function vector3CrossProduct(v1: Vector3, v2: Vector3): Vector3;
|
||||||
/** */
|
/** Calculate one vector perpendicular vector */
|
||||||
declare function vector3Perpendicular(v: Vector3): Vector3;
|
declare function vector3Perpendicular(v: Vector3): Vector3;
|
||||||
/** */
|
/** Calculate vector length */
|
||||||
declare function vector3Length(v: Vector3): number;
|
declare function vector3Length(v: Vector3): number;
|
||||||
/** */
|
/** Calculate vector square length */
|
||||||
declare function vector3LengthSqr(v: Vector3): number;
|
declare function vector3LengthSqr(v: Vector3): number;
|
||||||
/** */
|
/** Calculate two vectors dot product */
|
||||||
declare function vector3DotProduct(v1: Vector3, v2: Vector3): number;
|
declare function vector3DotProduct(v1: Vector3, v2: Vector3): number;
|
||||||
/** */
|
/** Calculate distance between two vectors */
|
||||||
declare function vector3Distance(v1: Vector3, v2: Vector3): number;
|
declare function vector3Distance(v1: Vector3, v2: Vector3): number;
|
||||||
/** */
|
/** Calculate square distance between two vectors */
|
||||||
declare function vector3DistanceSqr(v1: Vector3, v2: Vector3): number;
|
declare function vector3DistanceSqr(v1: Vector3, v2: Vector3): number;
|
||||||
/** */
|
/** Calculate angle between two vectors */
|
||||||
declare function vector3Angle(v1: Vector3, v2: Vector3): number;
|
declare function vector3Angle(v1: Vector3, v2: Vector3): number;
|
||||||
/** */
|
/** Negate provided vector (invert direction) */
|
||||||
declare function vector3Negate(v: Vector3): Vector3;
|
declare function vector3Negate(v: Vector3): Vector3;
|
||||||
/** */
|
/** Divide vector by vector */
|
||||||
declare function vector3Divide(v1: Vector3, v2: Vector3): Vector3;
|
declare function vector3Divide(v1: Vector3, v2: Vector3): Vector3;
|
||||||
/** */
|
/** Normalize provided vector */
|
||||||
declare function vector3Normalize(v: Vector3): Vector3;
|
declare function vector3Normalize(v: Vector3): Vector3;
|
||||||
/** */
|
/** Transforms a Vector3 by a given Matrix */
|
||||||
declare function vector3Transform(v: Vector3, mat: Matrix): Vector3;
|
declare function vector3Transform(v: Vector3, mat: Matrix): Vector3;
|
||||||
/** */
|
/** Transform a vector by quaternion rotation */
|
||||||
declare function vector3RotateByQuaternion(v: Vector3, q: Vector4): Vector3;
|
declare function vector3RotateByQuaternion(v: Vector3, q: Vector4): Vector3;
|
||||||
/** */
|
/** Rotates a vector around an axis */
|
||||||
declare function vector3RotateByAxisAngle(v: Vector3, axis: Vector3, angle: number): Vector3;
|
declare function vector3RotateByAxisAngle(v: Vector3, axis: Vector3, angle: number): Vector3;
|
||||||
/** */
|
/** Calculate linear interpolation between two vectors */
|
||||||
declare function vector3Lerp(v1: Vector3, v2: Vector3, amount: number): Vector3;
|
declare function vector3Lerp(v1: Vector3, v2: Vector3, amount: number): Vector3;
|
||||||
/** */
|
/** Calculate reflected vector to normal */
|
||||||
declare function vector3Reflect(v: Vector3, normal: Vector3): Vector3;
|
declare function vector3Reflect(v: Vector3, normal: Vector3): Vector3;
|
||||||
/** */
|
/** Get min value for each pair of components */
|
||||||
declare function vector3Min(v1: Vector3, v2: Vector3): Vector3;
|
declare function vector3Min(v1: Vector3, v2: Vector3): Vector3;
|
||||||
/** */
|
/** Get max value for each pair of components */
|
||||||
declare function vector3Max(v1: Vector3, v2: Vector3): Vector3;
|
declare function vector3Max(v1: Vector3, v2: Vector3): Vector3;
|
||||||
/** */
|
/** Compute barycenter coordinates (u, v, w) for point p with respect to triangle (a, b, c)
|
||||||
|
NOTE: Assumes P is on the plane of the triangle */
|
||||||
declare function vector3Barycenter(p: Vector3, a: Vector3, b: Vector3, c: Vector3): Vector3;
|
declare function vector3Barycenter(p: Vector3, a: Vector3, b: Vector3, c: Vector3): Vector3;
|
||||||
/** */
|
/** Projects a Vector3 from screen space into object space
|
||||||
|
NOTE: We are avoiding calling other raymath functions despite available */
|
||||||
declare function vector3Unproject(source: Vector3, projection: Matrix, view: Matrix): Vector3;
|
declare function vector3Unproject(source: Vector3, projection: Matrix, view: Matrix): Vector3;
|
||||||
/** */
|
/** Invert the given vector */
|
||||||
declare function vector3Invert(v: Vector3): Vector3;
|
declare function vector3Invert(v: Vector3): Vector3;
|
||||||
/** */
|
/** Clamp the components of the vector between
|
||||||
|
min and max values specified by the given vectors */
|
||||||
declare function vector3Clamp(v: Vector3, min: Vector3, max: Vector3): Vector3;
|
declare function vector3Clamp(v: Vector3, min: Vector3, max: Vector3): Vector3;
|
||||||
/** */
|
/** Clamp the magnitude of the vector between two values */
|
||||||
declare function vector3ClampValue(v: Vector3, min: number, max: number): Vector3;
|
declare function vector3ClampValue(v: Vector3, min: number, max: number): Vector3;
|
||||||
/** */
|
/** Check whether two given vectors are almost equal */
|
||||||
declare function vector3Equals(p: Vector3, q: Vector3): number;
|
declare function vector3Equals(p: Vector3, q: Vector3): number;
|
||||||
/** */
|
/** Compute the direction of a refracted ray where v specifies the
|
||||||
|
normalized direction of the incoming ray, n specifies the
|
||||||
|
normalized normal vector of the interface of two optical media,
|
||||||
|
and r specifies the ratio of the refractive index of the medium
|
||||||
|
from where the ray comes to the refractive index of the medium
|
||||||
|
on the other side of the surface */
|
||||||
declare function vector3Refract(v: Vector3, n: Vector3, r: number): Vector3;
|
declare function vector3Refract(v: Vector3, n: Vector3, r: number): Vector3;
|
||||||
/** */
|
/** Compute matrix determinant */
|
||||||
declare function matrixDeterminant(mat: Matrix): number;
|
declare function matrixDeterminant(mat: Matrix): number;
|
||||||
/** */
|
/** Get the trace of the matrix (sum of the values along the diagonal) */
|
||||||
declare function matrixTrace(mat: Matrix): number;
|
declare function matrixTrace(mat: Matrix): number;
|
||||||
/** */
|
/** Transposes provided matrix */
|
||||||
declare function matrixTranspose(mat: Matrix): Matrix;
|
declare function matrixTranspose(mat: Matrix): Matrix;
|
||||||
/** */
|
/** Invert provided matrix */
|
||||||
declare function matrixInvert(mat: Matrix): Matrix;
|
declare function matrixInvert(mat: Matrix): Matrix;
|
||||||
/** */
|
/** Get identity matrix */
|
||||||
declare function matrixIdentity(): Matrix;
|
declare function matrixIdentity(): Matrix;
|
||||||
/** */
|
/** Add two matrices */
|
||||||
declare function matrixAdd(left: Matrix, right: Matrix): Matrix;
|
declare function matrixAdd(left: Matrix, right: Matrix): Matrix;
|
||||||
/** */
|
/** Subtract two matrices (left - right) */
|
||||||
declare function matrixSubtract(left: Matrix, right: Matrix): Matrix;
|
declare function matrixSubtract(left: Matrix, right: Matrix): Matrix;
|
||||||
/** */
|
/** Get two matrix multiplication
|
||||||
|
NOTE: When multiplying matrices... the order matters! */
|
||||||
declare function matrixMultiply(left: Matrix, right: Matrix): Matrix;
|
declare function matrixMultiply(left: Matrix, right: Matrix): Matrix;
|
||||||
/** */
|
/** Get translation matrix */
|
||||||
declare function matrixTranslate(x: number, y: number, z: number): Matrix;
|
declare function matrixTranslate(x: number, y: number, z: number): Matrix;
|
||||||
/** */
|
/** Create rotation matrix from axis and angle
|
||||||
|
NOTE: Angle should be provided in radians */
|
||||||
declare function matrixRotate(axis: Vector3, angle: number): Matrix;
|
declare function matrixRotate(axis: Vector3, angle: number): Matrix;
|
||||||
/** */
|
/** Get x-rotation matrix
|
||||||
|
NOTE: Angle must be provided in radians */
|
||||||
declare function matrixRotateX(angle: number): Matrix;
|
declare function matrixRotateX(angle: number): Matrix;
|
||||||
/** */
|
/** Get y-rotation matrix
|
||||||
|
NOTE: Angle must be provided in radians */
|
||||||
declare function matrixRotateY(angle: number): Matrix;
|
declare function matrixRotateY(angle: number): Matrix;
|
||||||
/** */
|
/** Get z-rotation matrix
|
||||||
|
NOTE: Angle must be provided in radians */
|
||||||
declare function matrixRotateZ(angle: number): Matrix;
|
declare function matrixRotateZ(angle: number): Matrix;
|
||||||
/** */
|
/** Get xyz-rotation matrix
|
||||||
|
NOTE: Angle must be provided in radians */
|
||||||
declare function matrixRotateXYZ(angle: Vector3): Matrix;
|
declare function matrixRotateXYZ(angle: Vector3): Matrix;
|
||||||
/** */
|
/** Get zyx-rotation matrix
|
||||||
|
NOTE: Angle must be provided in radians */
|
||||||
declare function matrixRotateZYX(angle: Vector3): Matrix;
|
declare function matrixRotateZYX(angle: Vector3): Matrix;
|
||||||
/** */
|
/** Get scaling matrix */
|
||||||
declare function matrixScale(x: number, y: number, z: number): Matrix;
|
declare function matrixScale(x: number, y: number, z: number): Matrix;
|
||||||
/** */
|
/** Get perspective projection matrix */
|
||||||
declare function matrixFrustum(left: number, right: number, bottom: number, top: number, near: number, far: number): Matrix;
|
declare function matrixFrustum(left: number, right: number, bottom: number, top: number, near: number, far: number): Matrix;
|
||||||
/** */
|
/** Get perspective projection matrix
|
||||||
|
NOTE: Fovy angle must be provided in radians */
|
||||||
declare function matrixPerspective(fovy: number, aspect: number, near: number, far: number): Matrix;
|
declare function matrixPerspective(fovy: number, aspect: number, near: number, far: number): Matrix;
|
||||||
/** */
|
/** Get orthographic projection matrix */
|
||||||
declare function matrixOrtho(left: number, right: number, bottom: number, top: number, near: number, far: number): Matrix;
|
declare function matrixOrtho(left: number, right: number, bottom: number, top: number, near: number, far: number): Matrix;
|
||||||
/** */
|
/** Get camera look-at matrix (view matrix) */
|
||||||
declare function matrixLookAt(eye: Vector3, target: Vector3, up: Vector3): Matrix;
|
declare function matrixLookAt(eye: Vector3, target: Vector3, up: Vector3): Matrix;
|
||||||
/** */
|
/** Add two quaternions */
|
||||||
declare function quaternionAdd(q1: Vector4, q2: Vector4): Vector4;
|
declare function quaternionAdd(q1: Vector4, q2: Vector4): Vector4;
|
||||||
/** */
|
/** Add quaternion and float value */
|
||||||
declare function quaternionAddValue(q: Vector4, add: number): Vector4;
|
declare function quaternionAddValue(q: Vector4, add: number): Vector4;
|
||||||
/** */
|
/** Subtract two quaternions */
|
||||||
declare function quaternionSubtract(q1: Vector4, q2: Vector4): Vector4;
|
declare function quaternionSubtract(q1: Vector4, q2: Vector4): Vector4;
|
||||||
/** */
|
/** Subtract quaternion and float value */
|
||||||
declare function quaternionSubtractValue(q: Vector4, sub: number): Vector4;
|
declare function quaternionSubtractValue(q: Vector4, sub: number): Vector4;
|
||||||
/** */
|
/** Get identity quaternion */
|
||||||
declare function quaternionIdentity(): Vector4;
|
declare function quaternionIdentity(): Vector4;
|
||||||
/** */
|
/** Computes the length of a quaternion */
|
||||||
declare function quaternionLength(q: Vector4): number;
|
declare function quaternionLength(q: Vector4): number;
|
||||||
/** */
|
/** Normalize provided quaternion */
|
||||||
declare function quaternionNormalize(q: Vector4): Vector4;
|
declare function quaternionNormalize(q: Vector4): Vector4;
|
||||||
/** */
|
/** Invert provided quaternion */
|
||||||
declare function quaternionInvert(q: Vector4): Vector4;
|
declare function quaternionInvert(q: Vector4): Vector4;
|
||||||
/** */
|
/** Calculate two quaternion multiplication */
|
||||||
declare function quaternionMultiply(q1: Vector4, q2: Vector4): Vector4;
|
declare function quaternionMultiply(q1: Vector4, q2: Vector4): Vector4;
|
||||||
/** */
|
/** Scale quaternion by float value */
|
||||||
declare function quaternionScale(q: Vector4, mul: number): Vector4;
|
declare function quaternionScale(q: Vector4, mul: number): Vector4;
|
||||||
/** */
|
/** Divide two quaternions */
|
||||||
declare function quaternionDivide(q1: Vector4, q2: Vector4): Vector4;
|
declare function quaternionDivide(q1: Vector4, q2: Vector4): Vector4;
|
||||||
/** */
|
/** Calculate linear interpolation between two quaternions */
|
||||||
declare function quaternionLerp(q1: Vector4, q2: Vector4, amount: number): Vector4;
|
declare function quaternionLerp(q1: Vector4, q2: Vector4, amount: number): Vector4;
|
||||||
/** */
|
/** Calculate slerp-optimized interpolation between two quaternions */
|
||||||
declare function quaternionNlerp(q1: Vector4, q2: Vector4, amount: number): Vector4;
|
declare function quaternionNlerp(q1: Vector4, q2: Vector4, amount: number): Vector4;
|
||||||
/** */
|
/** Calculates spherical linear interpolation between two quaternions */
|
||||||
declare function quaternionSlerp(q1: Vector4, q2: Vector4, amount: number): Vector4;
|
declare function quaternionSlerp(q1: Vector4, q2: Vector4, amount: number): Vector4;
|
||||||
/** */
|
/** Calculate quaternion based on the rotation from one vector to another */
|
||||||
declare function quaternionFromVector3ToVector3(from: Vector3, to: Vector3): Vector4;
|
declare function quaternionFromVector3ToVector3(from: Vector3, to: Vector3): Vector4;
|
||||||
/** */
|
/** Get a quaternion for a given rotation matrix */
|
||||||
declare function quaternionFromMatrix(mat: Matrix): Vector4;
|
declare function quaternionFromMatrix(mat: Matrix): Vector4;
|
||||||
/** */
|
/** Get a matrix for a given quaternion */
|
||||||
declare function quaternionToMatrix(q: Vector4): Matrix;
|
declare function quaternionToMatrix(q: Vector4): Matrix;
|
||||||
/** */
|
/** Get rotation quaternion for an angle and axis
|
||||||
|
NOTE: Angle must be provided in radians */
|
||||||
declare function quaternionFromAxisAngle(axis: Vector3, angle: number): Vector4;
|
declare function quaternionFromAxisAngle(axis: Vector3, angle: number): Vector4;
|
||||||
/** */
|
/** Get the quaternion equivalent to Euler angles
|
||||||
|
NOTE: Rotation order is ZYX */
|
||||||
declare function quaternionFromEuler(pitch: number, yaw: number, roll: number): Vector4;
|
declare function quaternionFromEuler(pitch: number, yaw: number, roll: number): Vector4;
|
||||||
/** */
|
/** Get the Euler angles equivalent to quaternion (roll, pitch, yaw)
|
||||||
|
NOTE: Angles are returned in a Vector3 struct in radians */
|
||||||
declare function quaternionToEuler(q: Vector4): Vector3;
|
declare function quaternionToEuler(q: Vector4): Vector3;
|
||||||
/** */
|
/** Transform a quaternion given a transformation matrix */
|
||||||
declare function quaternionTransform(q: Vector4, mat: Matrix): Vector4;
|
declare function quaternionTransform(q: Vector4, mat: Matrix): Vector4;
|
||||||
/** */
|
/** Check whether two given quaternions are almost equal */
|
||||||
declare function quaternionEquals(p: Vector4, q: Vector4): number;
|
declare function quaternionEquals(p: Vector4, q: Vector4): number;
|
||||||
/** Light Gray */
|
/** Light Gray */
|
||||||
declare var LIGHTGRAY: Color;
|
declare var LIGHTGRAY: Color;
|
||||||
|
|
|
@ -897,31 +897,28 @@ const fs_1 = __webpack_require__(/*! fs */ "fs");
|
||||||
const api_1 = __webpack_require__(/*! ./api */ "./src/api.ts");
|
const api_1 = __webpack_require__(/*! ./api */ "./src/api.ts");
|
||||||
const raylib_header_1 = __webpack_require__(/*! ./raylib-header */ "./src/raylib-header.ts");
|
const raylib_header_1 = __webpack_require__(/*! ./raylib-header */ "./src/raylib-header.ts");
|
||||||
function parseMathHeader() {
|
function parseMathHeader() {
|
||||||
return (0, fs_1.readFileSync)("thirdparty/raylib/src/raymath.h", 'utf8')
|
const i = (0, fs_1.readFileSync)("thirdparty/raylib/src/raymath.h", 'utf8');
|
||||||
.split("\n")
|
const m = [...i.matchAll(/((?:\/\/ .+\n)*)RMAPI\s+([\w<>]+)\s+([\w<>]+)\((.*)\)/gm)];
|
||||||
.filter(x => x.startsWith("RMAPI"))
|
const res = m.map(groups => {
|
||||||
.map(inputString => {
|
const args = groups[4].split(',').filter(x => x !== 'void').map(arg => {
|
||||||
const matches = inputString.match(/^RMAPI\s+([\w<>]+)\s+([\w<>]+)\((.*)\)$/);
|
|
||||||
if (!matches)
|
|
||||||
throw new Error("Unable to match " + inputString);
|
|
||||||
const args = matches[3].split(',').filter(x => x !== 'void').map(arg => {
|
|
||||||
arg = arg.trim().replace(" *", "* ");
|
arg = arg.trim().replace(" *", "* ");
|
||||||
const frags = arg.split(' ');
|
const frags = arg.split(' ');
|
||||||
const name = frags.pop();
|
const name = frags.pop();
|
||||||
const type = frags.join(' ').replace("*", " *");
|
const type = frags.join(' ').replace("*", " *");
|
||||||
return { name: name || "", type: type };
|
return { name: name || "", type: type };
|
||||||
});
|
});
|
||||||
|
const comments = groups[1].split('\n').map(x => x.replace("// ", "")).join('\n').trim();
|
||||||
return {
|
return {
|
||||||
name: matches[2],
|
name: groups[3],
|
||||||
returnType: matches[1],
|
returnType: groups[2],
|
||||||
params: args,
|
params: args,
|
||||||
description: ""
|
description: comments
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
return res;
|
||||||
}
|
}
|
||||||
function main() {
|
function main() {
|
||||||
const mathApi = parseMathHeader();
|
// Load the pre-generated raylib api
|
||||||
(0, fs_1.writeFileSync)("bindings/raylib_math_api.json", JSON.stringify(mathApi));
|
|
||||||
const api = JSON.parse((0, fs_1.readFileSync)("thirdparty/raylib/parser/output/raylib_api.json", 'utf8'));
|
const api = JSON.parse((0, fs_1.readFileSync)("thirdparty/raylib/parser/output/raylib_api.json", 'utf8'));
|
||||||
api.functions.push({
|
api.functions.push({
|
||||||
name: "SetModelMaterial",
|
name: "SetModelMaterial",
|
||||||
|
@ -929,6 +926,8 @@ function main() {
|
||||||
returnType: "void",
|
returnType: "void",
|
||||||
params: [{ type: "Model *", name: "model" }, { type: "int", name: "materialIndex" }, { type: "Material", name: "material" }]
|
params: [{ type: "Model *", name: "model" }, { type: "int", name: "materialIndex" }, { type: "Material", name: "material" }]
|
||||||
});
|
});
|
||||||
|
const mathApi = parseMathHeader();
|
||||||
|
(0, fs_1.writeFileSync)("bindings/raylib_math_api.json", JSON.stringify(mathApi));
|
||||||
mathApi.forEach(x => api.functions.push(x));
|
mathApi.forEach(x => api.functions.push(x));
|
||||||
const apiDesc = new api_1.ApiDescription(api);
|
const apiDesc = new api_1.ApiDescription(api);
|
||||||
const core = new raylib_header_1.RayLibHeader("raylib_core", apiDesc);
|
const core = new raylib_header_1.RayLibHeader("raylib_core", apiDesc);
|
||||||
|
|
27
readme.md
27
readme.md
|
@ -5,6 +5,9 @@ Javascript bindings for raylib in a single ~3mb executable
|
||||||
## What is this?
|
## What is this?
|
||||||
rayjs is small ES2020 compliant Javascript interpreter based on [QuickJS](https://bellard.org/quickjs/) with bindings for [Raylib](https://www.raylib.com/). You can use it to develop desktop games with Javascript.
|
rayjs is small ES2020 compliant Javascript interpreter based on [QuickJS](https://bellard.org/quickjs/) with bindings for [Raylib](https://www.raylib.com/). You can use it to develop desktop games with Javascript.
|
||||||
|
|
||||||
|
## What this is not
|
||||||
|
rayjs is not a binding for NodeJS nor is it running in the browser (yet). It's comes with its own Javascript engine (QuickJS) similar to how NodeJS comes with the V8 engine. That makes it much easier to run and distribute rayjs programs as all you need to run a program / game is the small rayjs executable. No installation, no dlls or additional files are needed.
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
* Compiles into a single, small executable without any dependencies for easy distribution
|
* Compiles into a single, small executable without any dependencies for easy distribution
|
||||||
* Use modern Javascript features like classes or async/await
|
* Use modern Javascript features like classes or async/await
|
||||||
|
@ -43,6 +46,26 @@ rayjs will run code in three different modes
|
||||||
|
|
||||||
The directory of the main Javascript module will also be the working directory of the app. Modules and resources will be loaded relative to it.
|
The directory of the main Javascript module will also be the working directory of the app. Modules and resources will be loaded relative to it.
|
||||||
|
|
||||||
|
## API support
|
||||||
|
|
||||||
|
The following raylib APIs are supported so far (with a few exceptions):
|
||||||
|
|
||||||
|
- core (no VR support yet)
|
||||||
|
- shapes
|
||||||
|
- textures
|
||||||
|
- text (no support for GlyphInfo yet)
|
||||||
|
- models
|
||||||
|
- shaders
|
||||||
|
- audio
|
||||||
|
- raymath
|
||||||
|
|
||||||
|
Similar to including a header in C and for your convenience, all types/functions are provided globally. They are additionally available in a module called 'raylib'
|
||||||
|
|
||||||
|
## Auto-Complete / Intellisense
|
||||||
|
|
||||||
|
rayjs comes with full auto-complete support in the form of the definitions file `lib.raylib.d.ts`. These will work with Typescript and Javascript. For most editors (e.g. Visual Studio Code) it should be enough to put them in the project folder.
|
||||||
|
![](doc/auto-complete.png)
|
||||||
|
|
||||||
## Building
|
## Building
|
||||||
Here are some basic steps if you want to compile rayjs yourself.
|
Here are some basic steps if you want to compile rayjs yourself.
|
||||||
You should use CMake for building. **Please note that QuickJS needs Mingw in order to compile correctly on Windows**
|
You should use CMake for building. **Please note that QuickJS needs Mingw in order to compile correctly on Windows**
|
||||||
|
@ -53,6 +76,8 @@ git clone https://github.com/mode777/rayjs.git
|
||||||
git submodule update --init --recursive
|
git submodule update --init --recursive
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### Build with cmake
|
### Build with cmake
|
||||||
Make sure you have cmake installed and in your path.
|
Make sure you have cmake installed and in your path.
|
||||||
```bash
|
```bash
|
||||||
|
@ -64,5 +89,5 @@ make
|
||||||
```
|
```
|
||||||
|
|
||||||
## Performance
|
## Performance
|
||||||
QuickJS is one of the [faster JS interpreters](https://bellard.org/quickjs/bench.html). I'm getting about 13000 bunnys in bunnmark before dropping any frames on my 2020 Macbook Air M1 which seems pretty good.
|
QuickJS is one of the [faster JS interpreters](https://bellard.org/quickjs/bench.html). I'm getting about 13000 bunnys in the unmodified bunnmark before dropping any frames on my 2020 Macbook Air M1 which seems pretty good.
|
||||||
![Bunnymark](doc/bunny.png)
|
![Bunnymark](doc/bunny.png)
|
||||||
|
|
Loading…
Reference in New Issue