Releases: processing/p5.js
v2.0.0-beta.1
We want your help!
Try testing out the beta and report any bugs you encounter!
-
You can fork this web editor project: https://editor.p5js.org/davepagurek/sketches/wiOiYAp6P
-
You can also add a script tag to this build that @davepagurek is hosting:
<script src="https://davepagurek.com/stuff/p5/p5-2.0-b1.min.js"></script>
What's Changed 🎊
In addition to lots of behind-the-scenes refactoring, here are some new features that we'd love your help testing out!
Async loading (thanks to @limzykenneth)
Rather than having a preload
function, p5 2.0 has async setup
!
1.x | 2.0 |
---|---|
let img;
function preload() {
img = loadImage('cat.jpg');
}
function setup() {
createCanvas(200, 200);
} |
let img;
async function setup() {
createCanvas(200, 200);
img = await loadImage('cat.jpg');
} |
Support for loading fonts via CSS (thanks to @dhowe)
In 2D mode, try loading fonts via a a path to a CSS font file, such as a Google Fonts link!
loadFont("https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,[email protected],200..800&display=swap")
loadFont(`@font-face { font-family: "Bricolage Grotesque", serif; font-optical-sizing: auto; font-weight: <weight> font-style: normal; font-variation-settings: "wdth" 100; }`);
loadFont({
fontFamily: '"Bricolage Grotesque", serif',
fontOpticalSizing: 'auto',
fontWeight: '<weight>',
fontStyle: 'normal',
fontVariationSettings: '"wdth" 100',
});
loadFont("https://fonts.gstatic.com/s/inter/v18/UcCO3FwrK3iLTeHuS_nVMrMxCp50SjIw2boKoduKmMEVuLyfMZhrib2Bg-4.ttf");
loadFont("path/to/localFont.ttf");
loadFont("system-font-name");
Support for variable font weight (thanks to contributions by @dhowe)
In 2D mode, if you've loaded a variable font, try changing its weight!
async function setup() {
createCanvas(100, 100);
const font = await loadFont(
'https://fonts.googleapis.com/css2?family=Sniglet:wght@400;800&display=swap'
);
}
function draw() {
background(255);
textFont(font);
textAlign(LEFT, TOP);
textSize(35);
textWeight(sin(millis() * 0.002) * 200 + 400);
text('p5*js', 0, 10);
}
More ways to draw and manipulate text (thanks to @davepagurek)
Like how textToPoints()
gives you points on text, the new textToContours()
function lets you edit the points on text and then draw them with fills!
createCanvas(100, 100);
const font = await loadFont('myFont.ttf');
background(200);
strokeWeight(2);
textSize(50);
const contours = font.textToContours('p5*js', 0, 50, { sampleFactor: 0.5 });
beginShape();
for (const pts of contours) {
beginContour();
for (const pt of pts) {
vertex(x + 20*sin(y*0.01), y + 20*sin(x*0.01));
}
endContour(CLOSE);
}
endShape();
In WebGL, you can use textToModel
to extrude a 3D model out of your text:
createCanvas(100, 100, WEBGL);
const font = await loadFont('myFont.ttf');
background(200);
textSize(50);
const geom = font.textToModel('p5*js', 0, 50, { sampleFactor: 2, extrude: 20 });
orbitControl();
model(geom);
A new pointer event handling system (thanks to @diyaayay)
Instead of having separate methods for mouse and touch, we now use the browser's pointer API to handle both simultaneously. Try defining mouse functions as usual and accessing the global touches
array to see what pointers are active for multitouch support!
Custom shader attributes (thanks to @lukeplowden)
If you are using a shader and want custom per-vertex properties in addition to uniform
s, which are the same across the whole shape, you can now call vertexProperty(name, value)
before vertices.
const vertSrc = `#version 300 es
precision mediump float;
uniform mat4 uModelViewMatrix;
uniform mat4 uProjectionMatrix;
in vec3 aPosition;
in vec2 aOffset;
void main(){
vec4 positionVec4 = vec4(aPosition.xyz, 1.0);
positionVec4.xy += aOffset;
gl_Position = uProjectionMatrix * uModelViewMatrix * positionVec4;
}
`;
const fragSrc = `#version 300 es
precision mediump float;
out vec4 outColor;
void main(){
outColor = vec4(0.0, 1.0, 1.0, 1.0);
}
`;
function setup(){
createCanvas(100, 100, WEBGL);
// Create and use the custom shader.
const myShader = createShader(vertSrc, fragSrc);
shader(myShader);
describe('A wobbly, cyan circle on a gray background.');
}
function draw(){
// Set the styles
background(125);
noStroke();
// Draw the circle.
beginShape();
for (let i = 0; i < 30; i++){
const x = 40 * cos(i/30 * TWO_PI);
const y = 40 * sin(i/30 * TWO_PI);
// Apply some noise to the coordinates.
const xOff = 10 * noise(x + millis()/1000) - 5;
const yOff = 10 * noise(y + millis()/1000) - 5;
// Apply these noise values to the following vertex.
vertexProperty('aOffset', [xOff, yOff]);
vertex(x, y);
}
endShape(CLOSE);
}
Updated bezier and curve drawing functions (thanks to @GregStanton)
First off: you can combine multiple types of curves in one begin/endShape()
block now!
Long cubic and quadratic bezier vertex calls are now split up into their individual control points. Both cubic and quadratic curves are done with bezierVertex
now, and you can set bezierOrder()
to change from cubic (order 3) to quadratic (order 2). For WebGL mode, this also means you can also specify texture coordinates per control point, or change the fill, stroke, normal, and more between control points.
1.x | 2.0 |
---|---|
beginShape();
vertex(10, 10);
vertex(30, 10);
bezierVertex(35, 10, 40, 15, 40, 20);
vertex(40, 30);
quadraticVertex(40, 40, 30, 40);
vertex(10, 40);
endShape(CLOSE); |
beginShape();
vertex(10, 10);
vertex(30, 10);
// Default cubic
bezierVertex(35, 10);
bezierVertex(40, 15);
bezierVertex(40, 20);
vertex(40, 30);
bezierOrder(2);
bezierVertex(40, 40);
bezierVertex(30, 40);
vertex(10, 40);
endShape(p5.CLOSE); |
We've renamed curveVertex
to splineVertex
and have given it more options. By default, it will now go through every splineVertex
, so you no longer have to double up the first/last point to get it to go through it:
1.x | 2.0 |
---|---|
beginShape();
curveVertex(10, 10);
curveVertex(10, 10);
curveVertex(15, 40);
curveVertex(40, 35);
curveVertex(25, 15);
curveVertex(15, 25);
curveVertex(15, 25);
endShape(); |
beginShape();
splineVertex(10, 10);
splineVertex(15, 40);
splineVertex(40, 35);
splineVertex(25, 15);
splineVertex(15, 25);
endShape(); |
Similarly, endShape(CLOSE)
(or endContour(CLOSE)
if you're in a contour) will cause a spline to smoothly loop back on itself so you no longer need to double up any points:
1.x | 2.0 |
---|---|
beginShape();
curveVertex(15, 25);
curveVertex(10, 10);
curveVertex(15, 40);
curveVertex(40, 35);
curveVertex(25, 15);
curveVertex(15, 25);
curveVertex(10, 10);
curveVertex(15, 40);
endShape(); |
beginShape();
splineVertex(10, 10);
splineVertex(15, 40);
splineVertex(40, 35);
splineVertex(25, 15);
splineVertex(15, 25);
endShape(CLOSE); |
A new simple lines mode for WebGL (thanks to contributions from @perminder-17)
If you are drawing lots of shapes, and don't need stroke caps or joins, you can use a simple lines mode for increased performance in WebGL. You can activate this mode by calling linesMode(SIMPLE)
in your sketch.
Custom shaders for fills, strokes, images (thanks to @Garima3110 and @perminder-17)
You can now create your own shaders for fills, strokes, and images, and have them all applied at once! Use shader()
to set a fill shader, strokeShader()
to set a stroke shader, and imageShader()
to set an image shader. Try using baseMaterialShader().modify(...)
and baseStrokeShader().modify(...)
to create custom shaders.
let myFillShader = baseMaterialShader.modify({
'vec4 getFinalColor': `(vec4 color) {
return vec4(1., 1., 0., 1.);
}`
});
let myStrokeShader = baseStrokeShader.modify({
'vec4 getFinalColor': `(vec4 color) {
return vec4(1., 0., 1., 1.);
}`
});
let myImageShader = baseMaterialShader.modify({
'vec4 getFinalColor': `(vec4 color) {
return vec4(0., 1., 1., 1.);
}`
});
shader(myFillShader);
strokeShader(myStrokeShader);
imageShader(myImageShader);
sphere(); // Draws with the custom stroke and image shaders
image(myImg, 0, 0); // Draws with the custom image shader
A new public p5.Matrix
class (thanks to @holomorfo)
TODO add examples
Support for more color spaces in p5.Color
(thanks to @limzykenneth and @dianamgalindo)
TODO add examples
Support for wide-gamut colors with the display-p3
mode (thanks to @limzykenneth)
TODO add examples
Full List
- modified stroke vertex shader by @JordanSucher in #7064
- Fix #7049: P5.Graphics.remove() doesn't release all related resources by @iambiancafonseca in #7060
- Separate Model and View Matrices. by @deveshidwivedi in #6761
- Switch camera keep transform by @davepagurek in #7067
- Check the element type before calling
createRadio
fromselect()
by @lindapaiste in #6838 - Use requestAni...
v1.11.2
What's Changed
What's Changed 🎊
- Switch all-contributor shield styling to match other shields by @SableRaf in #7347
- Fix a typo (dpeth -> depth) in webgl/p5.Framebuffer.js by @zs-5 in #7348
- Save/restore textureMode with push/pop by @davepagurek in #7358
- fix: Correct typo, improve createRadio() method description, and simplify input tag by @Dhanush111 in #7315
- Update links to point to tutorial page by @muffinista in #7318
- fix add alpha doc by @asukaminato0721 in #7362
- Negative dimensions will mirror rect() again by @martinleopold in #7363
- fixes issue #7366: Adjust Option Orientation in CreateRadio() reference. by @Prajyot05 in #7367
New Contributors
- @zs-5 made their first contribution in #7348
- @Dhanush111 made their first contribution in #7315
- @muffinista made their first contribution in #7318
- @Prajyot05 made their first contribution in #7367
Full Changelog: v1.11.1...v1.11.2
v1.11.1
What's Changed 🎊
Code
- fixed nf to work with negative number by @Akhilbisht798 in #7054
- textureData updated to fix flipping property for webgl by @MuktiMishra in #7305
- Fix ellipseMode(CORNERS) and rectMode(CORNER) by @martinleopold in #7290
- add usage of dist by @asukaminato0721 in #7324
- Uses canvas dimensions instead of arbitrary constants for
noise()
andnoiseDetail()
by @RandomGamingDev in #7330
Documentation
- Change Reference Example by @samarsrivastav in #7280
- Fix example of createModel function. by @shibomb in #7298
- fix missing example tag in documentation for color's toString method by @ashish1729 in #7302
- Fixes language reference and Markdown syntax by @danicruz0415 in #7314
- fix typo by @asukaminato0721 in #7322
- Fix broken links in contributor-doc by @shibomb in #7320
- Fix broken links in website references by @shibomb in #7321
- mouseY reference first example issue fixed by @shourysingh07 in #7311
- Docs: "A maximum of 5 directional lights can be active at once." by @blackboxlogic in #7337
New Contributors 💗
- @samarsrivastav made their first contribution in #7280
- @Akhilbisht798 made their first contribution in #7054
- @MuktiMishra made their first contribution in #7305
- @danicruz0415 made their first contribution in #7314
- @martinleopold made their first contribution in #7290
- @blackboxlogic made their first contribution in #7337
Full Changelog: v1.11.0...v1.11.1
v1.11.0
What's Changed 🎊
Code
- Fix unnecessary console warnings when using smooth() on P2D Graphics objects by @zeesworth in #7159
- added paletteLerp by @RandomGamingDev in #6960
- imageLight - panorama shader bug, added @perminder-17 code snippet by @PimTournaye in #7169
- Tie FES initialization to only run just before p5 init by @limzykenneth in #7173
- Code block updates in
vertex.js
by @DenisovichDev in #7174 - Fix incorrect pixel offset in updatePixels() by @Forchapeatl in #7177
- fix for #7181 by @orrkislev in #7182
- Fix Camera.eyeX comment by @Psychpsyo in #7184
- Solves issue #6891 by @Garima3110 in #7165
- Fix: Added unique group names for radio buttions by @Forchapeatl in #7162
- Caps at the beginning of the curve by @diyaayay in #7201
- Added useLinePerspective to cam copy properties by @TiborUdvari in #7213
- Fix clipping bug with ellipses by @jeanetteandrews in #7249
- Refactor arc and rect to use canvas methods rather than curves by @ksen0 in #7205
- Shader hooks by @davepagurek in #7149
- fix: added
WEBGL
mode for correct blendMode(SUBTRACT) behavior by @Abhinavcode13 in #7229 - Add list support for
lerpColor
like other color functions by @RandomGamingDev in #6954 - Remove 2.0 built file by @davepagurek in #7274
- Added textAscent and textDescent functions on Webgl by @Forchapeatl in #7187
- Line.vert fix for small units by @TiborUdvari in #7206
- fixed textpoint alignment by @mathewpan2 in #6967
- Fixed minor error in documentation for p5.Vector.sub() by @jaredberghold in #7265
- Rename default shader methods to have a base* prefix by @davepagurek in #7288
- Performance improvements for WebGL shape drawing by @davepagurek in #7287
Documentation
- add non-code contributions to contrib guidelines readme by @sarahciston in #6941
- Update README.md to include an updated get started link by @willallstet in #7232
- Fix : broken link in contributor_docs/webgl_mode_architecture.md by @ashwanidey in #7235
- Fix broken links in contributor_docs/steward_guidelines.md by @aleannab in #7240
- Fix broken link in contributing_to_the_p5js_references.md by @aleannab in #7242
- Fix : broken link in contributor_docs/webgl_contribution_guide.md by @ashwanidey in #7239
- Fix Broken README Link by @benpalevsky in #7216
- Fixed the broken link on p5.js website page for "p5.js Web Accessibility" by @shourysingh07 in #7254
- Fixed the broken link on p5.js website page for "Our Focus on Access" by @shourysingh07 in #7255
- Fixed broken links for p5js references by @visheshrwl in #7253
- fix: broken links in lerpColor() by @M0nica in #7241
- Fix broken links in contributor_docs/access.md by @aleannab in #7243
- Fixed the broken link on p5.js website page for "WebGL Contribution Guide". by @shourysingh07 in #7263
- Fixed the broken link on p5.js website page for "How to add Friendly Error Messages" by @shourysingh07 in #7264
New Contributors 💗
Thanks to all the contributors, and big shout out to the first time contributors!
- @zeesworth made their first contribution in #7159
- @PimTournaye made their first contribution in #7169
- @DenisovichDev made their first contribution in #7174
- @Forchapeatl made their first contribution in #7177
- @orrkislev made their first contribution in #7182
- @Psychpsyo made their first contribution in #7184
- @sarahciston made their first contribution in #6941
- @TiborUdvari made their first contribution in #7213
- @willallstet made their first contribution in #7232
- @ashwanidey made their first contribution in #7235
- @aleannab made their first contribution in #7240
- @benpalevsky made their first contribution in #7216
- @jeanetteandrews made their first contribution in #7249
- @shourysingh07 made their first contribution in #7254
- @visheshrwl made their first contribution in #7253
- @M0nica made their first contribution in #7241
- @ksen0 made their first contribution in #7205
- @mathewpan2 made their first contribution in #6967
- @jaredberghold made their first contribution in #7265
Full Changelog: v1.10.0...v1.11.0
v1.10.0
What's Changed 🎊
Code
- Adds geometry to downloadable obj files functionality by @diyaayay in #6812
- Implemented roll function by @rohanjulka19 in #7093
- Added window size check upon p5 instantiation by @Evorage0 in #7134
- Adds
webp
mime type tosaveCanvas
. by @starzonmyarmz in #7140 - modified stroke vertex shader by @JordanSucher in #7064
- Separate Model and View Matrices. by @deveshidwivedi in #6761
- Switch camera keep transform by @davepagurek in #7067
- Check the element type before calling
createRadio
fromselect()
by @lindapaiste in #6838 - Use requestAnimationFrame timestamp for less noise in deltaTime by @davepagurek in #6785
- Update clearDepth() example to restore trails by @davepagurek in #7095
- Changed point class documentation description text by @Chaitanya1672 in #7096
- Skip out of canvas shapes for gridOutput() table by @limzykenneth in #7135
- Fix #7049: P5.Graphics.remove() doesn't release all related resources by @iambiancafonseca in #7060
- fix: framebuffer cameras uses the size from main canvas by @Vishal2002 in #7075
- Fix vector reflect() mutating surface normal arg (#7088) by @nbogie in #7103
- Fix clipped multiline font rendering by @davepagurek in #7109
- fix: Correct default parameters for quad in y-direction by @Abhinavcode13 in #7129
- Fix: corrected variable name to reflect height instead of width by @Abhinavcode13 in #7132
- Fix panorama() by @davepagurek in #7154
Documentation
- Fix code snippet formatting in references by @nickmcintyre in #7089
- Fix more
code
tags in reference by @davepagurek in #7092 - Update: FES Messages in Japanese. by @shibomb in #7074
- Corrects the circle() description by @JulioGitLab in #7110
- Fix broken JsDoc comments by @Orasund in #7114
- Resolves issue #7118 - Update README.md & Changed the path for contributor docs by @ravixalgorithm in #7119
- Fix 'Learn' and 'Get Started' links in README.md by @NicholasGillen in #7126
- fixed: Broken link to dev_notes.md in the documentation by @Shahmaz0 in #7117
- "Fix Broken 'Get Started for Developers' Link in README" by @Souvik-Cyclic in #7151
- Update readme copy by @davepagurek in #6944
New Contributors 💗
- @JordanSucher made their first contribution in #7064
- @iambiancafonseca made their first contribution in #7060
- @Chaitanya1672 made their first contribution in #7096
- @rohanjulka19 made their first contribution in #7093
- @shibomb made their first contribution in #7074
- @Orasund made their first contribution in #7114
- @ravixalgorithm made their first contribution in #7119
- @Abhinavcode13 made their first contribution in #7129
- @NicholasGillen made their first contribution in #7126
- @Evorage0 made their first contribution in #7134
- @starzonmyarmz made their first contribution in #7140
- @Shahmaz0 made their first contribution in #7117
- @Souvik-Cyclic made their first contribution in #7151
Full Changelog: v1.9.4...v1.10.0
v1.9.4
What's Changed 🎊
Code
- Account for pixel density when masking images by @Papershine in #6788
- fix clearStorage function to match expected behaviour by @seralichtenhahn in #7006
- Fix broken test by @davepagurek in #7010
- textWrap() parameter validation uses FES instead of throwing error by @limzykenneth in #7009
- fix The constructor of p5.Table by @asukaminato0721 in #7011
- Fix autoSized for framebuffers by @davepagurek in #7012
- fix: add the missing index of
attributes
by @IronBlood in #7027
Documentation
- Add Japanese Version Contributor Docs by @RuimingShen in #6979
- Add missing backtick by @aGuyWhoMadeGames in #6996
- Fix default z value in p5.Camera::camera() docs by @davepagurek in #7001
- Fix 'p5.Vector.sub()' documentation mistakenly referencing 'add'ing by @bobbykaz in #7024
- Update structure references by @nickmcintyre in #7020
- Update more structure references by @nickmcintyre in #7021
- Fix foundation references by @nickmcintyre in #7022
- Update array references by @nickmcintyre in #7032
- Update conversion references by @nickmcintyre in #7033
- Update storage references by @nickmcintyre in #7034
- Update string references by @nickmcintyre in #7037
- Update IO references by @nickmcintyre in #7038
- Update time & date references by @nickmcintyre in #7039
- Update p5.XML references by @nickmcintyre in #7040
- Update rendering references by @nickmcintyre in #7041
- Fix map example by @PalumboN in #7036
- Update p5.Graphics references by @nickmcintyre in #7042
- Update p5.Geometry references by @nickmcintyre in #7045
- Update documentation_style_guide.md by @lottihill in #7053
- Patch-CORNER-descr-cx by @JulioGitLab in #7062
- Fix p5.Graphics.remove() reference by @nickmcintyre in #7057
- Fix links and typos by @nickmcintyre in #7058
- Update p5.Framebuffer references by @nickmcintyre in #7044
New Contributors 💗
- @RuimingShen made their first contribution in #6979
- @aGuyWhoMadeGames made their first contribution in #6996
- @Papershine made their first contribution in #6788
- @seralichtenhahn made their first contribution in #7006
- @bobbykaz made their first contribution in #7024
- @PalumboN made their first contribution in #7036
- @IronBlood made their first contribution in #7027
- @lottihill made their first contribution in #7053
- @JulioGitLab made their first contribution in #7062
Full Changelog: v1.9.3...v1.9.4
v1.9.3
What's Changed 🎊
Code
- Fix vertices with different texture coordinates in imported models getting collapsed by @davepagurek in #6923
- fixed parameters for normal() method by @kaiserarg in #6984
- Fix for gif not animating when drawing to p5.graphics by @kaiserarg in #6935
- add friendly error to createCapture() by @mdb0 in #6961
- Fix main canvas clipping getting applied to framebuffers by @davepagurek in #6990
Documentation
- Contributors docs cleanup by @limzykenneth in #6906
- Add short descriptions to contributor docs by @davepagurek in #6866
- Update contributor doc descriptions by @davepagurek in #6933
- Add doc on adding FES messages by @davepagurek in #6942
Reference
- Update keyboard event referenes by @nickmcintyre in #6932
- Update touch event references by @nickmcintyre in #6934
- Fix typo in touchStarted() by @nickmcintyre in #6938
- Update mouse event references by @nickmcintyre in #6937
- Update WebGL light references by @nickmcintyre in #6957
- Update WebGL interaction references by @nickmcintyre in #6955
- Update WebGL material references by @nickmcintyre in #6974
- Update p5.Shader references by @nickmcintyre in #6975
- Update p5.Camera references by @nickmcintyre in #6976
- Update 3D model references by @nickmcintyre in #6978
- Update vertex references by @nickmcintyre in #6981
- Update curve references by @nickmcintyre in #6985
- Update constant references by @nickmcintyre in #6986
- Update foundation references by @nickmcintyre in #6988
- Update transformation references by @nickmcintyre in #6991
- Update 3D primitive references by @nickmcintyre in #6980
Translation
- [p5.js - es] Translation of contributor_guidelines.md by @MarianneTeixido in #6895
- [p5.js KO] Create webgl_contribution_guide.md by @ienground in #6859
- [p5.js - zh] Update steward_guidelines.md by @Harrycheng233 in #6879
- [p5.js KO] steward_guidelines.md by @Orwiss in #6874
- Hindi translation of webgl contribution guide by @ranaaditya in #6886
- translation: Add
Steward Guidelines
documentation in Hindi by @EshaanAgg in #6887 - [p5.js KO] Create contributor_guidelines.md by @yunyoungJang in #6855
- hindi translation - contributing to p5.js reference added by @Surbhi-Pittie in #6890
- Fix: [p5.js - zh] Added contributor guidelines part 1 + 2 zh translations by @Tmicrd in #6903
- add: hindi translation of contributor guidelines by @jaiakash in #6892
- [p5.js KO] Update image path in contributing_to_the_p5.js_reference.md by @wooknick in #6916
- [p5.js KO] Update steward_guidelines.md by @Orwiss in #6918
- [p5.js KO]Update contributor_guidelines.md by @yunyoungJang in #6919
- Update contributing_to_the_p5.js_reference.md by @Harrycheng233 in #6948
- Update contributor_guidelines.md by @Harrycheng233 in #6946
- Update steward_guidelines.md by @Harrycheng233 in #6947
- Update webgl_contribution_guide.md by @Harrycheng233 in #6949
- [p5.js KO] Translate access.md by @Orwiss in #6951
- [p5.js HI]
access.md
and line 1 description translation to hindi by @jaiakash in #6950 - Update p5.Vector.js by @asukaminato0721 in #6831
- Update access.md by @Harrycheng233 in #6945
New Contributors 💗
- @MarianneTeixido made their first contribution in #6895
- @ienground made their first contribution in #6859
- @Orwiss made their first contribution in #6874
- @ranaaditya made their first contribution in #6886
- @EshaanAgg made their first contribution in #6887
- @yunyoungJang made their first contribution in #6855
- @Surbhi-Pittie made their first contribution in #6890
- @Tmicrd made their first contribution in #6903
- @jaiakash made their first contribution in #6892
- @kaiserarg made their first contribution in #6984
- @mdb0 made their first contribution in #6961
Full Changelog: v1.9.2...v1.9.3
v1.9.2
What's Changed 🎊
Code
- Fix for fill artifact in WebGL mode when rendering in LINE mode using beginShape by @RandomGamingDev in #6827
- Solves issue #4214 by @Garima3110 in #6734
- Solves issue #6787 by @Garima3110 in #6809
- Fix usage of default fonts by @davepagurek in #6861
- Enhancement limit WebGL textures to gl.MAX_TEXTURE_SIZE by @capGoblin in #6651
- .mtl files support for .obj files to render color in 3D custom geometry by @diyaayay in #6710
Documentation
- Nat Decker and Bobby Joe Smith III updated access.md by @natdecker in #6823
- Update WebGL architecture doc with edits by @davepagurek in #6791
- Convert FES doc updates + fix things that cause issues in mdx files by @davepagurek in #6832
- docs(styleguide): add section on chaining by @meezwhite in #6885
Reference
- Update accessibility references by @nickmcintyre in #6833
- Update environment references by @nickmcintyre in #6834
- Update color references by @nickmcintyre in #6835
- Update p5.Color references by @nickmcintyre in #6837
- Update calculation references by @nickmcintyre in #6842
- Update noise references by @nickmcintyre in #6843
- Update random references by @nickmcintyre in #6844
- Update createVector() reference by @nickmcintyre in #6846
- Update trigonometry references by @nickmcintyre in #6845
- Update p5.Element references by @nickmcintyre in #6849
- Update p5.Vector references by @nickmcintyre in #6848
- Update typography attribute references by @nickmcintyre in #6854
- Update p5.Font references by @nickmcintyre in #6862
- Update image load and display references by @nickmcintyre in #6864
- Update 2D shape references by @nickmcintyre in #6840
- Update shape attribute references by @nickmcintyre in #6841
- Update color references by @nickmcintyre in #6839
- Update pixels references by @nickmcintyre in #6865
- Update DOM references by @nickmcintyre in #6850
- Update image references by @nickmcintyre in #6863
- Update environment.js by @sphantom-code in #6877
- Update p5.Image references by @nickmcintyre in #6867
Translation
- [p5.js - es] Translate contributing_to_the_p5.js_reference by @ninioArtillero in #6871
- [p5.js - zh]Create contributing_to_the_p5.js_reference.md by @asukaminato0721 in #6869
- [p5.js KO] add korean translation of 'contributing_to_the_p5.js_reference.md by @wooknick in #6868
- [p5.js - zh] Create webgl_contribution_guide.md by @Harrycheng233 in #6878
- [p5.js - es] Translation of contributor_guidelines.md by @dianamgalindo in #6876
- [p5.js - zh] Added contributor guidelines part 1 + 2 zh translations by @douMax in #6881
- [p5.js - es] Translate steward_guidelines by @ml008008 in #6873
- [p5.js - es] Translation of steward_guidelines.md by @EmilioOcelotl in #6894
New Contributors 💗
- @natdecker made their first contribution in #6823
- @ninioArtillero made their first contribution in #6871
- @sphantom-code made their first contribution in #6877
- @wooknick made their first contribution in #6868
- @Harrycheng233 made their first contribution in #6878
- @dianamgalindo made their first contribution in #6876
- @douMax made their first contribution in #6881
- @ml008008 made their first contribution in #6873
- @EmilioOcelotl made their first contribution in #6894
Full Changelog: v1.9.1...v1.9.2
v1.9.1
What's Changed 🎊
Code
- lights() and specularMaterial() support on framebuffer block when filter is applied inside the block. by @perminder-17 in #6596
- Stores the width and height values before any adjustments are made, Solves #6581 by @diyaayay in #6588
- Image light performance improvements by implementing Framebuffers instead of Graphics. by @perminder-17 in #6599
- Added additional shader usage documentation related to replacement of default shaders. by @deveshidwivedi in #6601
- Fix filter shaders when rectMode is applied; add tests by @davepagurek in #6603
- Fix bug in orbitControl() where scaling with the mouse wheel worked even outside the canvas. by @inaridarkfox4231 in #6629
- Fix Web Accessibility output not tracking background color changes by @limzykenneth in #6619
- Fix syntax error re:
new p5.Vector.cross
by @lindapaiste in #6640 - Add clearDepth() method for feedback effects by @davepagurek in #6584
- cleanup passing of mat4 arguments by @lindapaiste in #6633
- Fix bug in ortho() where using it without arguements, drawing failed in some cases, resolved. by @diyaayay in #6639
- refined the number of samples used in diffused and specular textures by @sudhanshuv1 in #6613
- Resolves #6612 by @calebfoss in #6649
- Fixed the shader in the
endShape()
example to make the boxes separated from one another by @RandomGamingDev in #6656 - bugfix #6653 vertexNormal() is not defined,replaces with normal by @diyaayay in #6659
- Updated docs for p5.Shader.js by @Garima3110 in #6672
- fixed the doubleClicked() in offline docs by @Artimus100 in #6685
- add missing return type by @asukaminato0721 in #6682
- make parms optional by @asukaminato0721 in #6689
- Remove unused grunt task. by @IgnorantSapient in #6718
- Changed the definition of textBounds() in p5.Font.js by @sudhanshuv1 in #6673
- Changed width and height by @Hemant2A2 in #6658
- Create visual test system by @davepagurek in #6604
- Adding metallic feature in p5.js for both IBL and non-IBL codes. by @perminder-17 in #6618
- Solves issue #4562 by @Garima3110 in #6699
- lerpColor in HSL or HSB mode now can loop the color wheel if needed by @Bumblebee00 in #6708
- Enhanced loadModel() method signature with independent U and V flipping options. by @deveshidwivedi in #6669
- max and min now evaluates correctly by @iamnithishraja in #6730
- Add required parameters in _flipPixels function by @mohitbalwani in #6726
OrbitControl()
Compatibility withimageLight()
by fixing camera. by @perminder-17 in #6735- Fix rotation properties being in degrees irrespective of angleMode by @SlightlyEpic in #6589
- Fixed textfont() to work for multi-word fonts by @ar-rana in #6667
- Addresses #6485 Refactor ellipse drawing logic in p5.Renderer2D.js by @tuminzee in #6499
- Add issue form for p5.js 2.0 RFC proposals and make associated updates by @GregStanton in #6748
- Fix for touchEnded triggers twice among other issues with touchEnded/mouseReleased on mobile by @RandomGamingDev in #6738
- Fix for touchStarted triggers twice among other issues with touchStarted/mousePressed on mobile by @RandomGamingDev in #6740
- Update default values in ortho() docs, use default args in example by @davepagurek in #6758
- Fix filters run on framebuffers with different sizes from the main canvas by @davepagurek in #6783
- Adds Error message for when there are no screenshots by @diyaayay in #6773
- Check for per vertex transparency when blending by @davepagurek in #6541
- Fix mistake in p5.Vector.rotate() documentation by @pie999 in #6814
- Fixed cursor image issue by @haroon10725 in #6810
- Added a Method (
panorama(img)
) which adds a sphereMapped Background. by @perminder-17 in #6808 - Implement mirrored video feature for createCapture (#6441) by @Vishal2002 in #6703
- Default values of arguments && modernize some code by @asukaminato0721 in #6807
Documentation
- Update WebGL contributor docs by @davepagurek in #6625
- Fixed example broken by #6216 and added information for new camera default setting by @inaridarkfox4231 in #6620
- Update contributor_guidelines.md by @skushagra9 in #6636
- Update contributor_guidelines.md by @skushagra9 in #6637
- Fix typos in contributor_docs README.md by @jakebeamish in #6628
- fix documentation typo in src/math/random.js by @clemzio in #6702
- fixed second example in the reference page for
acos()
by @sudhanshuv1 in #6697 - Update contributor_guidelines.md by @RohitPaul0007 in #6687
- Update the broken link in friendly_error_system.md by @PracDuckling in #6692
- fixed spelling in src/accessibility/describe.js by @PoulavBhowmick03 in #6705
- fixed spelling in src/accessibility/describe.js by @AmreshSrivastava in #6714
- Update README.md by @codesmith-emmy in #6753
- fixed the example in the reference page for lightFalloff() by @sudhanshuv1 in #6790
- Update contributor docs by @davepagurek in #6811
New Contributors 💗
- @skushagra9 made their first contribution in #6636
- @jakebeamish made their first contribution in #6628
- @lindapaiste made their first contribution in #6640
- @sudhanshuv1 made their first contribution in #6613
- @Artimus100 made their first contribution in #6685
- @clemzio made their first contribution in #6702
- @RohitPaul0007 made their first contribution in #6687
- @PracDuckling made their first contribution in #6692
- @IgnorantSapient made their first contribution in #6718
- @PoulavBhowmick03 made their first contribution in #6705
- @AmreshSrivastava made their first contribution in #6714
- @Hemant2A2 made their first contribution in #6658
- @Bumblebee00 made their first contribution in #6708
- @iamnithishraja made their first contribution in #6730
- @mohitbalwani made their first contribution in #6726
- @ar-rana made their first contribution in #6667
- @tuminzee made their first contribution in #6499
- @GregStanton made their first contribution in #6748
- @codesmith-emmy made their first contribution in #6753
- @pie999 made their first contribution in #6814
- @haroon10725 made their first contribution in #6810
- @Vishal2002 made their first contribution in #6703
Full Changelog: v1.9.0...v1.9.1
v1.9.1-1 (beta)
What's Changed
What's Changed 🎊
- lights() and specularMaterial() support on framebuffer block when filter is applied inside the block. by @perminder-17 in #6596
- Stores the width and height values before any adjustments are made, Solves #6581 by @diyaayay in #6588
- Image light performance improvements by implementing Framebuffers instead of Graphics. by @perminder-17 in #6599
- Added additional shader usage documentation related to replacement of default shaders. by @deveshidwivedi in #6601
- Fix filter shaders when rectMode is applied; add tests by @davepagurek in #6603
- Update WebGL contributor docs by @davepagurek in #6625
- Fixed example broken by #6216 and added information for new camera default setting by @inaridarkfox4231 in #6620
- Fix bug in orbitControl() where scaling with the mouse wheel worked even outside the canvas. by @inaridarkfox4231 in #6629
- Fix Web Accessibility output not tracking background color changes by @limzykenneth in #6619
- Update contributor_guidelines.md by @skushagra9 in #6636
- Update contributor_guidelines.md by @skushagra9 in #6637
- Fix typos in contributor_docs README.md by @jakebeamish in #6628
- Fix syntax error re:
new p5.Vector.cross
by @lindapaiste in #6640 - Add clearDepth() method for feedback effects by @davepagurek in #6584
- cleanup passing of mat4 arguments by @lindapaiste in #6633
- Fix bug in ortho() where using it without arguements, drawing failed in some cases, resolved. by @diyaayay in #6639
- refined the number of samples used in diffused and specular textures by @sudhanshuv1 in #6613
- Resolves #6612 by @calebfoss in #6649
- Fixed the shader in the
endShape()
example to make the boxes separated from one another by @RandomGamingDev in #6656 - bugfix #6653 vertexNormal() is not defined,replaces with normal by @diyaayay in #6659
- Updated docs for p5.Shader.js by @Garima3110 in #6672
- fixed the doubleClicked() in offline docs by @Artimus100 in #6685
- add missing return type by @asukaminato0721 in #6682
- fix documentation typo in src/math/random.js by @clemzio in #6702
- fixed second example in the reference page for
acos()
by @sudhanshuv1 in #6697 - make parms optional by @asukaminato0721 in #6689
- Update contributor_guidelines.md by @RohitPaul0007 in #6687
- Update the broken link in friendly_error_system.md by @PracDuckling in #6692
- Remove unused grunt task. by @IgnorantSapient in #6718
- fixed spelling in src/accessibility/describe.js by @PoulavBhowmick03 in #6705
- fixed spelling in src/accessibility/describe.js by @AmreshSrivastava in #6714
- Changed the definition of textBounds() in p5.Font.js by @sudhanshuv1 in #6673
- Changed width and height by @Hemant2A2 in #6658
- Create visual test system by @davepagurek in #6604
- Adding metallic feature in p5.js for both IBL and non-IBL codes. by @perminder-17 in #6618
- Solves issue #4562 by @Garima3110 in #6699
- lerpColor in HSL or HSB mode now can loop the color wheel if needed by @Bumblebee00 in #6708
- Enhanced loadModel() method signature with independent U and V flipping options. by @deveshidwivedi in #6669
- max and min now evaluates correctly by @iamnithishraja in #6730
- Add required parameters in _flipPixels function by @mohitbalwani in #6726
OrbitControl()
Compatibility withimageLight()
by fixing camera. by @perminder-17 in #6735
New Contributors
- @skushagra9 made their first contribution in #6636
- @jakebeamish made their first contribution in #6628
- @lindapaiste made their first contribution in #6640
- @sudhanshuv1 made their first contribution in #6613
- @Artimus100 made their first contribution in #6685
- @clemzio made their first contribution in #6702
- @RohitPaul0007 made their first contribution in #6687
- @PracDuckling made their first contribution in #6692
- @IgnorantSapient made their first contribution in #6718
- @PoulavBhowmick03 made their first contribution in #6705
- @AmreshSrivastava made their first contribution in #6714
- @Hemant2A2 made their first contribution in #6658
- @Bumblebee00 made their first contribution in #6708
- @iamnithishraja made their first contribution in #6730
- @mohitbalwani made their first contribution in #6726
Full Changelog: v1.9.0...v1.9.1-1