G.js - Create Geometry Dash levels (with a SPWN-like syntax) in JavaScript
The project now supports these platforms:
- Windows
- MacOS
- Linux
- Android
For support on how to use G.js, join the Discord server: https://discord.gg/GwVd7K2cQY
Use G.js in your project by running this in your project (with Node.js installed):
npm install @g-js-api/g.js
Here is a functional example of G.js:
require('@g-js-api/g.js');
$.exportConfig({
type: 'savefile', // type can be 'savefile' to export to savefile, 'levelstring' to return levelstring or 'live_editor' to export to WSLiveEditor (must have Geode installed)
options: { info: true } // you can use { level_name: "my level" } if you must specify a level to save to if using savefile export config
}).then(x => {
// Creating counters
let my_counter = counter();
my_counter.display(15, 15);
// Events
on(
touch(),
trigger_function(() => {
my_counter.add(1);
})
);
// Waiting
wait(1);
my_counter.add(15);
// While loops
let g = unknown_g();
$.add({
OBJ_ID: 1,
X: 15,
Y: 15,
GROUPS: g
})
let i = counter();
i.display(45, 45);
while_loop(less_than(i, 10), () => {
i.add(1);
g.move(15, 0, 0.5);
});
});
- Inherits speed and ecosystem from JS (JS might sometimes be considered slower than others, but it is much faster than SPWN + ecosystem is much bigger than SPWN)
- Has early 2.2 features (9999 group limit, item triggers, ID remapping, 2.2 obj props, gradient trigger, level options, keyframes, random + adv random, sequence trigger, song trigger, particle system, etc.)
This is not finished yet - do not expect it to work exactly as SPWN yet! Docs can be found at https://g-js-api.github.io/G.js, but they are incomplete. Usage section below might help explaining more of the complex or unclear features.
G.js has mostly the same usage as SPWN, with exceptions:
- File must start with
$.exportConfig(...)
for exporting to a level (check example above or docs) - Since JS cannot do something like
!{}
for trigger functions, usetrigger_function(() => { /* ... */ })
for trigger functions - GD objects are just done with normal JS objects, obj props are mostly the same
- Use while loops with the
less_than(a, b)
,equal_to(a, b)
orgreater_than(a, b)
functions followed by a normal function, not trigger function - For comparing a counter with a plain number, use
counter.if_is(SMALLER_THAN | EQUAL_TO | LARGER_THAN, trigger_function)
- Counter operations are
counter.add(num | counter)
,counter.subtract(num | counter)
,counter.multiply(num | counter)
andcounter.divide(num | counter)
extract x
statements in SPWN areextract(x)
in G.jsgamescene
library from SPWN can be used in G.js by doinggamescene()
instead ofimport gamescene
- Ranges in G.js are done with
range(a, b)
- Getting unknown IDs for groups/blocks/colors can be done using
unknown_g()/unknown_b()/unknown_c()
- Group, block, and color IDs are represented using
group(id)
,block(id)
andcolor(id)
- Instead of calling groups by using
1g!
in SPWN, you can dogroup(1).call()
counter.to_const(a..b)
in SPWN is done inside of G.js by usingcounter.to_const(range(a, b), (number) => { /* ... */ })
- Counter comparison can be done using
compare(counter_1, EQUAL_TO/GREATER/GREATER_OR_EQ/GREATER_OR_EQ/LESS_OR_EQ/NOT_EQ, counter_2, true_id, false_id)
- ID remapping can be done through
my_trig_func.remap([group(3), group(2)], [group(7), group(4)]);
- Item edit trigger:
$.add(item_edit(item_1, item_2, target_item, type_1 (NONE/ITEM/TIMER/POINTS/TIME/ATTEMPT), type_2 (NONE/ITEM/TIMER/POINTS/TIME/ATTEMPT), target_type (NONE/ITEM/TIMER/POINTS/TIME/ATTEMPT), assign_op (EQ/ADD/SUB/MUL/DIV), op1 (EQ/ADD/SUB/MUL/DIV), op2 (EQ/ADD/SUB/MUL/DIV), mod, absn1 (ABS/NEG), absn2 (NONE/ABS/NEG), rfc1 (NONE/RND/FLR/CEI))
- Remappables are a sort of trigger function that can take in IDs as inputs through ID remapping:
let bl = group(10);
let fn = remappable(my_gr => {
group(my_gr).move(10, 0);
});
wait(0.5)
fn(bl);
- Particle systems have its own property system, check particles.js for info. Example:
$.add(particle_system({
MAX_PARTICLES: 30,
DURATION: -1,
LIFETIME: 1,
LIFETIME_VAR: 0.3,
EMISSION: -1,
ANGLE: 90,
ANGLE_VAR: 90,
SPEED: 29,
POSVAR_X: 11,
START_SIZE: 2,
START_SIZE_VAR: 1,
END_SIZE: 1,
END_SIZE_VAR: 1,
START_R: 1,
START_G: 1,
START_B: 1,
START_A: 1,
END_R: 1,
END_G: 1,
END_B: 1,
END_A: 1,
ADDITIVE: true
}).with(X, 200).with(Y, 100));
- item comp
- item edit
- item pers
- camera static
- camera offset
- teleport
- timer
- song
- gradient trigger
- keyframe system
- reverse trigger
- level options
- gravity
- sequence
- all camera triggers
- particle systems
- sfx trigger
- shader triggers