PGraphics


processing
Since v1.0.0
Available on all platforms
See also

Configuration parameters


Warp 10 includes a large subset of the Processing drawing library. You can create and manipulate images, then push a base64 encoded png onto the stack.

  • Step 1: create a processing graphic object with PGraphics function.
  • Step 2: manipulate this object with Processing functions.
  • Step 3: render the processing graphic with Pencode function.

Documentation of every function has a link to original Processing website. Original website includes more examples for each function.

Processing functions offers a lot of different signatures for colors. The most efficient is to keep the raw ARGB format : 0x102030FF means Red 32, Green 48, Blue 255 with alpha=16/255. Alpha 0xFF means fully opaque.

Up to Warp 10 1.2.18, antialiasing was not available. It is now available, by appending a digit to the imgtype string argument. The maximum anti-aliasing level is determined by the hardware of the machine that is running the software, so 2D4 and 2D8 mode will not work with every computer.

  • "2D" : no antialiasing
  • "2D2" : bilinear smoothing
  • "2D3" : bicubic smoothing
  • "2D4" : 4x antialiasing
  • "2D8" : 8x antialiasing

You can adjust the maximal number of pixel allowed in Warp 10 configuration file.

Signature

Examples

//simple example // @preview image 200 150 '2D3' PGraphics //new image instance, 200x150 pixels 0xffffff6c Pbackground //yellow background 3 PstrokeWeight //stroke width 3pixels 0xff0000ff Pstroke //blue stroke (ARGB color) 0x7fff0000 Pfill //semi transparent red fill 10 30 100 50 Prect //draw a rectangle, left corner 10 30, size 100 50 20 PtextSize //set text size to 20pt 0xffff0000 Pfill //red fill "Hello Warp 10" 10 100 Ptext //text, bottom left at 10 100. Pencode //render the image in a base64 format on the stack
//advanced example : create a random star background with motion blur, with a well known spaceship over it. // @preview image 250 'width' STORE 100 'height' STORE $width $height '2D' PGraphics //create an image instance 0xff000000 Pbackground //ARGB, black background 0xffffffff Pstroke //white outline 0xffffffff Pfill //white fill //draw some random stars in the black deep space 1 40 <% DROP //remove loop index from top of stack RAND $width * //random x RAND $height * //random y RAND 4 * 1 + //random radius from 1 to 5 px DUP //same x and y radius to draw circles Pellipse %> FOR //add a motion blur to the stars //define a one line convolution matrix [ [ 0.05 0.05 0.05 0.05 0.1 0.1 0.1 0.5 ] ] ->MAT 'simpleconvolutionmatrix' STORE //convert to a $width x $heigh list of value Ppixels 'imagepixels' STORE <% //This macro apply the motion blur on a list of pixels //it does not support rgb. 'imagepixels' STORE //take the input on the top of the stack //create an empty list with 8 pixels black [ 0 6 <% DROP 0xff000000 %> FOR ] 'ConvolutedImage' STORE MARK $imagepixels <% //push every pixel value on the stack 0xff & //keep blue component <% COUNTTOMARK 7 > %> <% //as soon as there is the 8 last pixels on the stack 8 DUPN 8 ->LIST ->VEC //take 8 values on the stack to build a vector $simpleconvolutionmatrix SWAP * //vector * matrix VEC-> 0 GET TOLONG //get resulting pixel value 0x00010101 * 0xff000000 + //pixel value with alpha 100% $ConvolutedImage SWAP +! DROP //store it in output image 8 ROLL DROP //remove the deepest one %> IFT %> FOREACH COUNTTOMARK DROPN //remove elts on the stack DROP //remove the mark. $ConvolutedImage //push the result on the stack %> 'MotionBlurMacro' STORE $imagepixels @MotionBlurMacro //one pass //@MotionBlurMacro //second pass will nearly double the operation count 'ConvolutedImage' STORE $ConvolutedImage PupdatePixels //load the pixel list in the PIMAGE "BLUR" 1 Pfilter //apply a blur filter 'spacebackground' STORE //store the instance for later use. $spacebackground //use a b64 encoded image (linux command : base64 -w 0 uss_small2.gif) "" Pdecode 5 20 Pimage //decode the image, paste it with a 5 30 offset Pencode //render the image to have a b64 png on the top of the stack.