Releases: processing/p5.js
v2.2.0
2.2: WebGPU and bugfixes
The 2.2 minor release contains work on WebGPU rendering that has been going on over the past year! WebGPU mode is included in a core add-on now. This release also contains a number of improvements in documentation and p5.strands bugfixes.
To load both p5.js and WebGPU mode, add these two script tags to your sketch:
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.webgpu.js"></script>Then load WebGPU mode in createCanvas:
async function setup() {
await createCanvas(400, 400, WEBGPU);
}Read more about how it works and where we plan on taking it here!
You're also welcome to come by the Discord #webgpu channel 🌱
What's Changed 🎊
- Ported the stroke shader to WebGPU renderer by @lukeplowden in #7915
- Framebuffer support on WebGPU renderer by @davepagurek in #8008
- webgpu ci test by @tychedelia in #8023
- Add WIP WebGPU mode by @davepagurek in #8179
- Update release action to omit WebGPU tests, add TS tests by @davepagurek in #8337
- FES parameter validation decoration use
.apply()for faster function invocation by @limzykenneth in #8332 - Add WebGPU built files to npm releases by @davepagurek in #8338
- Make sure bytes are aligned in p5.Geometry by @davepagurek in #8340
- Fix WebGPU buffer memory leaks by @davepagurek in #8342
- Fix JSDoc return type for p5.Vector.cross (2.0) by @Geethegreat in #8346
- Add support for instanceID() in WebGPU mode by @davepagurek in #8348
- Fix WebGPU filters in CDN builds using duck typing for nodes (closes … by @Piyushrathoree in #8349
- Fix Camera.slerp for ortho by cloning projMatrix into uPMatrix when active by @nakednous in #8351
- fixed the issue with alpha blending - fixing blur remaining by @Piyushrathoree in #8354
- Support background(image) in WEBGL Renderer3D by @reshma045 in #8352
- Fix LogicalExpression (&&, ||) handling in p5.strands by @Aayushdev18 in #8359
- Fix p5.strands filters not working on minified code by @davepagurek in #8367
- More fixes for minified filters by @davepagurek in #8372
- Fix transforms in clip() by using shape system for primitives using manual method by @VANSH3104 in #8236
- Make sure text binds an index buffer by @davepagurek in #8393
- Fix font measurement with font families containing special characters by @davepagurek in #8391
- Fix for strands branching by @davepagurek in #8394
- Fix assignments to properties of
inputsin branches in p5.strands by @davepagurek in #8397 - Fix set() to support p5.Graphics objects by @VANSH3104 in #8326
- Fix type for shuffle() and add type test. by @nbogie in #8410
- Fix p5.strands parsing of named function callbacks by @davepagurek in #8414
New Contributors
- @tychedelia made their first contribution in #8023
- @Piyushrathoree made their first contribution in #8349
- @Aayushdev18 made their first contribution in #8359
Full Changelog: v2.1.2...v2.2.0
v2.2.0-rc.6
Help test the release candidate
The 2.2 proposed minor release contains the ongoing work on WebGPU rendering! This is a release candidate (RC), which means it is not yet live on the p5.js Editor. Please help us to improve the stability of the newest version of p5.js by trying out this release candidate, and reporting bugs. You can also share your thoughts or get involved on Discord in the #webpgu channel! This RC also contains bugfixes in p5.js, including in p5.strands.
Testing WebGPU mode
WebGPU mode is included in a core add-on now. To load both p5.js and WebGPU mode, add these two script tags to your sketch:
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.webgpu.js"></script>Then load WebGPU mode in createCanvas:
async function setup() {
await createCanvas(400, 400, WEBGPU);
}Or, feel free to duplicate this project on the p5.js web editor: https://editor.p5js.org/ksen0/sketches/Ger2euN_J
Read more about how it works and where we plan on taking it here: https://github.com/processing/p5.js/blob/dev-2.0/contributor_docs/webgpu.md
What's Changed
- Ported the stroke shader to WebGPU renderer by @lukeplowden in #7915
- Framebuffer support on WebGPU renderer by @davepagurek in #8008
- webgpu ci test by @tychedelia in #8023
- Add WIP WebGPU mode by @davepagurek in #8179
- Update release action to omit WebGPU tests, add TS tests by @davepagurek in #8337
- FES parameter validation decoration use
.apply()for faster function invocation by @limzykenneth in #8332 - Add WebGPU built files to npm releases by @davepagurek in #8338
- Make sure bytes are aligned in p5.Geometry by @davepagurek in #8340
- Fix WebGPU buffer memory leaks by @davepagurek in #8342
- Fix JSDoc return type for p5.Vector.cross (2.0) by @Geethegreat in #8346
- Add support for instanceID() in WebGPU mode by @davepagurek in #8348
- Fix WebGPU filters in CDN builds using duck typing for nodes (closes … by @Piyushrathoree in #8349
- Fix Camera.slerp for ortho by cloning projMatrix into uPMatrix when active by @nakednous in #8351
- fixed the issue with alpha blending - fixing blur remaining by @Piyushrathoree in #8354
- Support background(image) in WEBGL Renderer3D by @reshma045 in #8352
- Fix LogicalExpression (&&, ||) handling in p5.strands by @Aayushdev18 in #8359
- Fix p5.strands filters not working on minified code by @davepagurek in #8367
- More fixes for minified filters by @davepagurek in #8372
- Fix transforms in clip() by using shape system for primitives using manual method by @VANSH3104 in #8236
- Make sure text binds an index buffer by @davepagurek in #8393
- Fix font measurement with font families containing special characters by @davepagurek in #8391
- Fix for strands branching by @davepagurek in #8394
- Fix assignments to properties of
inputsin branches in p5.strands by @davepagurek in #8397 - Fix set() to support p5.Graphics objects by @VANSH3104 in #8326
- Fix type for shuffle() and add type test. by @nbogie in #8410
- Fix p5.strands parsing of named function callbacks by @davepagurek in #8414
New Contributors
- @tychedelia made their first contribution in #8023
- @Piyushrathoree made their first contribution in #8349
- @Aayushdev18 made their first contribution in #8359
Full Changelog: v2.1.2...v2.2.0-rc.6
What's Changed
What's Changed 🎊
- Fix assignments to properties of
inputsin branches in p5.strands by @davepagurek in #8397 - Fix set() to support p5.Graphics objects by @VANSH3104 in #8326
- Fix type for shuffle() and add type test. by @nbogie in #8410
- Fix p5.strands parsing of named function callbacks by @davepagurek in #8414
Full Changelog: v2.2.0-rc.5...v2.2.0-rc.6
v1.11.12-rc.0
How to test
Please report any issues you find with this release candidate before it goes live as the next version of 1.x! To help test, you can use the downloads below. In the p5.js Editor, you can upload p5.min.js and use it in the index.html page.
What's Changed
Since 1.11.11, the updates have been documentation and bugfixes.
What's Changed 🎊
- Update CONTRIBUTING.md links and add Discord invitation by @RishiAhuja in #8190
- Docs: fix typos and anchors by @nivanovvv in #8216
- docs: add nivanovvv as a contributor for doc by @allcontributors[bot] in #8217
- Add
AGENTS.mdby @SableRaf in #8194 - Add title to CONTRIBUTORS.md by @davepagurek in #8233
- docs: add nbogie as a contributor for bug, and code by @allcontributors[bot] in #8234
- docs: add SoundOfScooting as a contributor for code, and doc by @allcontributors[bot] in #8242
- Improve Accessibility Guidance for
describe()Usage (#8101) by @ksen0 in #8247 - docs: add VANSH3104 as a contributor for code by @allcontributors[bot] in #8258
- docs: add menacingly-coded as a contributor for doc by @allcontributors[bot] in #8292
- docs: add Homaid as a contributor for doc by @allcontributors[bot] in #8298
- Fix zh-Hans reference link by @nivanovvv in #8275
- docs: add Itsrajsk as a contributor for code by @allcontributors[bot] in #8306
- Updated point() examples for visible points in main branch. by @menacingly-coded in #8305
- fix: background(image) support in WEBGL by @reshma045 in #8333
- Fix JSDoc return type for p5.Vector.cross by @Geethegreat in #8336
- docs: add Geethegreat as a contributor for code by @allcontributors[bot] in #8347
- docs: add Piyushrathoree as a contributor for code by @allcontributors[bot] in #8350
- docs: add Aayushdev18 as a contributor for code by @allcontributors[bot] in #8362
- WebGL: Apply per‑vertex stroke color to POINTS by @yugalkaushik in #8380
- Docs/fix broken links by @skyash-dev in #8399
- docs: add rakesh2OO5 as a contributor for code by @allcontributors[bot] in #8403
New Contributors
- @RishiAhuja made their first contribution in #8190
- @nivanovvv made their first contribution in #8216
- @yugalkaushik made their first contribution in #8380
- @skyash-dev made their first contribution in #8399
Full Changelog: v1.11.11...v1.11.12-rc.0
v2.2.0-rc.5
Help test the release candidate
The 2.2 proposed minor release contains the ongoing work on WebGPU rendering! This is a release candidate (RC), which means it is not yet live on the p5.js Editor. Please help us to improve the stability of the newest version of p5.js by trying out this release candidate, and reporting bugs. You can also share your thoughts or get involved on Discord in the #webpgu channel! This RC also contains bugfixes in p5.js, including in p5.strands.
Testing WebGPU mode
WebGPU mode is included in a core add-on now. To load both p5.js and WebGPU mode, add these two script tags to your sketch:
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.webgpu.js"></script>Then load WebGPU mode in createCanvas:
async function setup() {
await createCanvas(400, 400, WEBGPU);
}Or, feel free to duplicate this project on the p5.js web editor: https://editor.p5js.org/ksen0/sketches/Ger2euN_J
Read more about how it works and where we plan on taking it here: https://github.com/processing/p5.js/blob/dev-2.0/contributor_docs/webgpu.md
What's Changed 🎊
- Ported the stroke shader to WebGPU renderer by @lukeplowden in #7915
- Framebuffer support on WebGPU renderer by @davepagurek in #8008
- webgpu ci test by @tychedelia in #8023
- Add WIP WebGPU mode by @davepagurek in #8179
- Update release action to omit WebGPU tests, add TS tests by @davepagurek in #8337
- FES parameter validation decoration use
.apply()for faster function invocation by @limzykenneth in #8332 - Add WebGPU built files to npm releases by @davepagurek in #8338
- Make sure bytes are aligned in p5.Geometry by @davepagurek in #8340
- Fix WebGPU buffer memory leaks by @davepagurek in #8342
- Fix JSDoc return type for p5.Vector.cross (2.0) by @Geethegreat in #8346
- Add support for instanceID() in WebGPU mode by @davepagurek in #8348
- Fix WebGPU filters in CDN builds using duck typing for nodes (closes … by @Piyushrathoree in #8349
- Fix Camera.slerp for ortho by cloning projMatrix into uPMatrix when active by @nakednous in #8351
- fixed the issue with alpha blending - fixing blur remaining by @Piyushrathoree in #8354
- Support background(image) in WEBGL Renderer3D by @reshma045 in #8352
- Fix LogicalExpression (&&, ||) handling in p5.strands by @Aayushdev18 in #8359
- Fix p5.strands filters not working on minified code by @davepagurek in #8367
- More fixes for minified filters by @davepagurek in #8372
- Fix transforms in clip() by using shape system for primitives using manual method by @VANSH3104 in #8236
- Make sure text binds an index buffer by @davepagurek in #8393
- Fix font measurement with font families containing special characters by @davepagurek in #8391
- Fix for strands branching by @davepagurek in #8394
New Contributors
- @tychedelia made their first contribution in #8023
- @Piyushrathoree made their first contribution in #8349
- @Aayushdev18 made their first contribution in #8359
Full Changelog: v2.1.2...v2.2.0-rc.5
v2.2.0-rc.4
Help test the release candidate
The 2.2 proposed minor release contains the ongoing work on WebGPU rendering! This is a release candidate (RC), which means it is not yet live on the p5.js Editor. Please help us to improve the stability of the newest version of p5.js by trying out this release candidate, and reporting bugs. You can also share your thoughts or get involved on Discord in the #webpgu channel!
Testing WebGPU mode
WebGPU mode is included in a core add-on now. To load both p5.js and WebGPU mode, add these two script tags to your sketch:
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.webgpu.js"></script>Then load WebGPU mode in createCanvas:
async function setup() {
await createCanvas(400, 400, WEBGPU);
}Or, feel free to duplicate this project on the p5.js web editor: https://editor.p5js.org/ksen0/sketches/Ger2euN_J
Read more about how it works and where we plan on taking it here: https://github.com/processing/p5.js/blob/dev-2.0/contributor_docs/webgpu.md
What's Changed 🎊
- Ported the stroke shader to WebGPU renderer by @lukeplowden in #7915
- Framebuffer support on WebGPU renderer by @davepagurek in #8008
- webgpu ci test by @tychedelia in #8023
- Add WIP WebGPU mode by @davepagurek in #8179
- Update release action to omit WebGPU tests, add TS tests by @davepagurek in #8337
- FES parameter validation decoration use
.apply()for faster function invocation by @limzykenneth in #8332 - Add WebGPU built files to npm releases by @davepagurek in #8338
- Make sure bytes are aligned in p5.Geometry by @davepagurek in #8340
- Fix WebGPU buffer memory leaks by @davepagurek in #8342
- Fix JSDoc return type for p5.Vector.cross (2.0) by @Geethegreat in #8346
- Add support for instanceID() in WebGPU mode by @davepagurek in #8348
- Fix WebGPU filters in CDN builds using duck typing for nodes (closes … by @Piyushrathoree in #8349
- Fix Camera.slerp for ortho by cloning projMatrix into uPMatrix when active by @nakednous in #8351
- fixed the issue with alpha blending - fixing blur remaining by @Piyushrathoree in #8354
- Support background(image) in WEBGL Renderer3D by @reshma045 in #8352
- Fix LogicalExpression (&&, ||) handling in p5.strands by @Aayushdev18 in #8359
- Fix p5.strands filters not working on minified code by @davepagurek in #8367
- More fixes for minified filters by @davepagurek in #8372
New Contributors
- @tychedelia made their first contribution in #8023
- @Piyushrathoree made their first contribution in #8349
- @Aayushdev18 made their first contribution in #8359
Full Changelog: v2.1.2...v2.2.0-rc.4
v2.2.0-rc.3
Help test the release candidate
The 2.2 proposed minor release contains the ongoing work on WebGPU rendering! This is a release candidate (RC), which means it is not yet live on the p5.js Editor. Please help us to improve the stability of the newest version of p5.js by trying out this release candidate, and reporting bugs. You can also share your thoughts or get involved on Discord in the #webpgu channel!
Testing WebGPU mode
WebGPU mode is included in a core add-on now. To load both p5.js and WebGPU mode, add these two script tags to your sketch:
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.webgpu.js"></script>Then load WebGPU mode in createCanvas:
async function setup() {
await createCanvas(400, 400, WEBGPU);
}Or, feel free to duplicate this project on the p5.js web editor: https://editor.p5js.org/ksen0/sketches/Ger2euN_J
Read more about how it works and where we plan on taking it here: https://github.com/processing/p5.js/blob/dev-2.0/contributor_docs/webgpu.md
What's Changed 🎊
- Ported the stroke shader to WebGPU renderer by @lukeplowden in #7915
- Framebuffer support on WebGPU renderer by @davepagurek in #8008
- webgpu ci test by @tychedelia in #8023
- Add WIP WebGPU mode by @davepagurek in #8179
- Update release action to omit WebGPU tests, add TS tests by @davepagurek in #8337
- FES parameter validation decoration use
.apply()for faster function invocation by @limzykenneth in #8332 - Add WebGPU built files to npm releases by @davepagurek in #8338
- Make sure bytes are aligned in p5.Geometry by @davepagurek in #8340
- Fix WebGPU buffer memory leaks by @davepagurek in #8342
- Fix JSDoc return type for p5.Vector.cross (2.0) by @Geethegreat in #8346
- Add support for instanceID() in WebGPU mode by @davepagurek in #8348
- Fix WebGPU filters in CDN builds using duck typing for nodes (closes … by @Piyushrathoree in #8349
- Fix Camera.slerp for ortho by cloning projMatrix into uPMatrix when active by @nakednous in #8351
- fixed the issue with alpha blending - fixing blur remaining by @Piyushrathoree in #8354
New Contributors
- @tychedelia made their first contribution in #8023
- @Piyushrathoree made their first contribution in #8349
Full Changelog: v2.1.2...v2.2.0-rc.3
v2.2.0-rc.2
Help test the release candidate
The 2.2 proposed minor release contains the ongoing work on WebGPU rendering! This is a release candidate (RC), which means it is not yet live on the p5.js Editor. Please help us to improve the stability of the newest version of p5.js by trying out this release candidate, and reporting bugs. You can also share your thoughts or get involved on Discord in the #webpgu channel!
Testing WebGPU mode
WebGPU mode is included in a core add-on now. To load both p5.js and WebGPU mode, add these two script tags to your sketch:
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.webgpu.js"></script>Then load WebGPU mode in createCanvas:
async function setup() {
await createCanvas(400, 400, WEBGPU);
}Or, feel free to duplicate this project on the p5.js web editor: https://editor.p5js.org/davepagurek/sketches/bmEYKK2aw
Read more about how it works and where we plan on taking it here: https://github.com/processing/p5.js/blob/dev-2.0/contributor_docs/webgpu.md
What's Changed
What's Changed 🎊
- Ported the stroke shader to WebGPU renderer by @lukeplowden in #7915
- Framebuffer support on WebGPU renderer by @davepagurek in #8008
- webgpu ci test by @tychedelia in #8023
- Add WIP WebGPU mode by @davepagurek in #8179
- Update release action to omit WebGPU tests, add TS tests by @davepagurek in #8337
- FES parameter validation decoration use
.apply()for faster function invocation by @limzykenneth in #8332 - Add WebGPU built files to npm releases by @davepagurek in #8338
New Contributors
- @tychedelia made their first contribution in #8023
Full Changelog: v2.1.2...v2.2.0-rc.2
v2.2.0-rc.1
Help test the release candidate
- Use this link to load the library: https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.js
The 2.2 proposed minor release contains the ongoing work on WebGPU rendering! This is a release candidate (RC), which means it is not yet live on the p5.js Editor. Please help us to improve the stability of the newest version of p5.js by trying out this release candidate, and reporting bugs. You can also share your thoughts or get involved on Discord in the #webpgu channel!
What's Changed 🎊
- Ported the stroke shader to WebGPU renderer by @lukeplowden in #7915
- Framebuffer support on WebGPU renderer by @davepagurek in #8008
- webgpu ci test by @tychedelia in #8023
- Add WIP WebGPU mode by @davepagurek in #8179
- Update release action to omit WebGPU tests, add TS tests by @davepagurek in #8337
- FES parameter validation decoration use
.apply()for faster function invocation by @limzykenneth in #8332
New Contributors
- @tychedelia made their first contribution in #8023
Full Changelog: v2.1.2...v2.2.0-rc.1
v2.1.2
What's Changed
Use this link to load the library: https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.js
This patch includes documentation updates, bugfixes, and improvements on the experimental p5.strands feature.
What's Changed 🎊
- Add fallback for property tags that don't fully parse by @davepagurek in #8257
- Fix textToModel face normals for extruded text by @VANSH3104 in #8091
- Fix string quotes in font loading example by @dhowe in #8279
- Updated point() examples for visible points. by @menacingly-coded in #8291
- Add fallback for HTTP HEAD requests by @davepagurek in #8270
- Improve splineProperties() documentation by @Homaid in #8265
- Fix to#7984 by @dhowe in #8014
- Makes sure p5.strands cleans up after an error by @davepagurek in #8301
- Fix usage of int() typecast in p5.strands by @davepagurek in #8254
- Text alignment fixes by @davepagurek in #8317
- Update Spanish steward guidelines for p5.js 2.x by @marioguzzzman in #8310
- Update Spanish steward guidelines for p5.js 2.0 (remove Grunt referen… by @marioguzzzman in #8308
- Better visual centering of text by @davepagurek in #8320
- Make sure camera methods on framebuffers work with push/pop by @davepagurek in #8322
- Fixes 8323 by @dhowe in #8324
- Add noiseDetail() support for p5.strands by @hxrshxz in #8163
New Contributors
- @Homaid made their first contribution in #8265
- @marioguzzzman made their first contribution in #8310
Full Changelog: v2.1.1...v2.1.2
v2.1.1
Use this link to load the library: https://cdn.jsdelivr.net/npm/[email protected]/lib/p5.js
What's new in p5.js 2.1 🌱
- ...TypeScript integration
- ...p5.strands branching
if/elseand loopingfor - ...Addon Events API
- ...Color contrast checker, which you can use like this:
let bgColor, fg1Color, fg2Color, msg1, msg2;
function setup() {
createCanvas(100, 100);
bgColor = color(0);
fg1Color = color(100);
fg2Color = color(220);
if(bgColor.contrast(fg1Color)){
msg1 = 'good';
}else{
msg1 = 'bad';
}
if(bgColor.contrast(fg2Color)){
msg2 = 'good';
}else{
msg2 = 'bad';
}
describe('A black canvas with a faint grey word saying "bad" at the top left and a brighter light grey word saying "good" in the middle of the canvas.');
}
function draw(){
background(bgColor);
textSize(18);
fill(fg1Color);
text(msg1, 10, 30);
fill(fg2Color);
text(msg2, 10, 60);
}oneColor.contrast(anotherColor) checks the contrast between two colors. This method returns a boolean value to indicate if the two color has enough contrast. true means that the colors has enough contrast to be used as background color and body text color. false means there is not enough contrast.
A second argument can be passed to the method, options , which defines the algorithm to be used. The algorithms currently supported are WCAG 2.1 ('WCAG21') or APCA ('APCA'). The default is WCAG 2.1. If a value of 'all' is passed to the options argument, an object containing more details is returned. The details object will include the calculated contrast value of the colors and different passing criteria.
let bgColor, fgColor, contrast;
function setup() {
createCanvas(100, 100);
bgColor = color(0);
fgColor = color(200);
contrast = bgColor.contrast(fgColor, 'all');
describe('A black canvas with four short lines of grey text that respectively says: "WCAG 2.1", "12.55", "APCA", and "-73.30".');
}
function draw(){
background(bgColor);
textSize(14);
fill(fgColor);
text('WCAG 2.1', 10, 25);
text(nf(contrast.WCAG21.value, 0, 2), 10, 40);
text('APCA', 10, 70);
text(nf(contrast.APCA.value, 0, 2), 10, 85);
}For more details about color contrast, you can check out this page from color.js, and the WebAIM color contrast checker.
Changes since 2.0 🎊
- fix: add splineVertex to p5.Graphics prototype and fix unit test error by @VANSH3104 in #7757
- [2.x] Fix ESM export functionality by @limzykenneth in #7764
- Fixed Error in FES prevents message from being shown, Prevented 'window' properties from being overwritten by @HughJacks in #7765
- Fix WebGL alpha blending by @davepagurek in #7769
- [2.0] Fix touch event not updating mouse coordinates by @limzykenneth in #7772
- Updating foundation-section for async/await by @perminder-17 in #7721
- fixing keyReleased() function. by @perminder-17 in #7758
- Fix corrupted textures when rendering too many WebGL characters by @davepagurek in #7792
- Improve antialiased framebuffer performance by @davepagurek in #7794
- Fix FES check for image() not accepting some valid types by @limzykenneth in #7801
- Publish types on NPM with next release by @limzykenneth in #7802
- Fix typo in directionalLight reference (dev-2.0 branch) #7743 by @LalitNarayanYadav in #7778
- Remove dayjs dependency and update date formatting in banner by @error-four-o-four in #7804
- Rest types by @davepagurek in #7803
- Updating all the broken refrence examples. by @perminder-17 in #7739
- Fixing keyTyped() for dev-2.0 branch by @perminder-17 in #7809
- P2HDR docs by @perminder-17 in #7728
- Update creating addon libraries contributor docs by @limzykenneth in #7800
- docs(keyboard): clarify keyIsDown() documentation for key codes and browser compatibility by @dpanshug in #7812
- Prevent FES from checking nested properties by @IIITM-Jay in #7824
- update the model params to be correct for 2.0 in docs and FES by @lukeplowden in #7832
- Model params updated for YUIDocs by @lukeplowden in #7835
- add instance of video in callback (2.0) by @ksen0 in #7877
- Add font readiness wait to create() function in p5.Font.js by @sophyphile in #7882
- Fix typo in createFileInput example by @ksen0 in #7884
- Create Graphics fixing in dev-2.0 branch. by @perminder-17 in #7829
- Alias GLSL's mix function as lerp in p5.strands (#7875) by @LalitNarayanYadav in #7887
- added documentation to _getBrightness() and _getGreen() function by @FerrinThreatt in #7908
- Chore/upgrade eslint by @error-four-o-four in #7853
- Revamped config.yml(branch: dev-2.0) by @shivasankaran18 in #7776
- Update zod 3 to zod 4 support in p5.js dev-2.0 by @madhav2348 in #7872
- Updating visual tests docs for 2.x versions by @perminder-17 in #7827
- Skip adding degenerate faces in textToModel by @davepagurek in #7951
- Add GLSL-based noise(vec2) function to p5.strands (#7897) by @LalitNarayanYadav in #7921
- Fix inline anonymous functions causing a parsing error in p5.strands callbacks by @nking07049925 in #7956
- Fix p5.strands uniform calls, add instance mode construct by @davepagurek in #7961
- Enhance p5.strands noise() to support noise(x, y) and 4-octave fractal noise by @LalitNarayanYadav in #7964
- Adding docs for
codein the refrence. by @perminder-17 in #7902 - Individual flags to disable part of FES by the user by @limzykenneth in #7967
- Add minified ESM build output by @nickswalker in #7973
- Replace fn with direct downloadFile import to fix issue where fn was not found by @acgillette in #7971
- Documentation fix for swapped parameters in splinePoint and bezierPoint by @shawdm in #7997
- Update dev-2.0 docs with recently-added contributors and stewards by @ksen0 in #8000
- Remove incorrect mouseX/mouseY docs regarding WEBGL mode in dev-2.0 branch. by @perminder-17 in #8006
- Fix MediaElement.copy by @pearmini in #7980
- Reset millis() after setup by @davepagurek in #8005
- Fix: Corrected code block in textureMode() in dev2.0 by @harishbit in #8015
- Merge branch 'loopOptimization' of https://github.com/awood0727/p5.js… by @awood0727 in #8024
- Update README.md by @perminder-17 in #8029
- Fixed syntax error at disableFriendleErrors by @Iron-56 in #8038
- Fix noise() getting overridden; add tests by @davepagurek in #8036
- A few documentation issues to fix by @perminder-17 in #8031
- Auto-link / Close Issues for 2.0 PRs (p5.js & p5.js-website) by @NalinDalal in #8025
- minor-fixing in shape docs by @perminder-17 in #8066
- Update auto-close-issues.yml by @ksen0 in #8069
- textWidth ignores leading and trailing spaces by @Nitin2332 in #8067
- [WIP] Docs: Add initial draft of Strands documentation (feedback wanted) by @Abhayaj247 in #7940
- Fix most of the eslint warnings currently generated by @limzykenneth in #8063
- Addon Events API and User Defined Functions access by @limzykenneth in #7947
- Adding some examples for shapes. by @perminder-17 in #8070
- textToContours is broken under textAlign(CENTER,CENTER) and use linebreak by @perminder-17 in #8083
- reference-fix-2.0 b...