PGraphics
processing
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.
PGraphics is available since version 1.0.0.
See also
Signatures
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.