#N canvas 350 148 784 564 10; #X text 452 8 GEM object; #X obj 9 263 cnv 15 430 170 empty empty empty 20 12 0 14 -233017 -66577 0; #X text 40 265 Inlets:; #X obj 9 227 cnv 15 430 30 empty empty empty 20 12 0 14 -195568 -66577 0; #X text 18 226 Arguments:; #X obj 8 56 cnv 15 430 165 empty empty empty 20 12 0 14 -233017 -66577 0; #X obj 452 75 cnv 15 200 170 empty empty empty 20 12 0 14 -228992 -66577 0; #X text 461 54 Example:; #X obj 457 120 cnv 15 190 150 empty empty empty 20 12 0 14 -24198 -66577 0; #X text 71 31 Class: pix object; #X text 29 57 Description: a storage place for a number of images; #X text 11 79 [pix_buffer] is a named storage place for images. It is quite similar to Pd's [table] object (but you cannot open it and have a look at it's contents).; #X text 50 11 Synopsis: [pix_buffer]; #X text 23 281 Inlet 1: bang: get the size of the buffer in frames ; #X text 12 123 The images stored in the [pix_buffer] can have different dimensions and colourspaces. Memory is reserved on demand \, but you can preallocate memory with the [allocate( message.; #X text 23 481 Outlet 1: int: size of the buffer; #X msg 464 128 bang; #X floatatom 464 253 5 0 0 0 - - -; #X msg 505 154 allocate 256 256 4; #X text 462 296 see also:; #X obj 475 348 pix_buffer_read; #X obj 474 323 pix_buffer_write; #X text 64 237 list: <buffer_name> <size>; #X obj 464 230 pix_buffer depot 10; #X text 10 170 To write data to the [pix_buffer] or get images from it \, you can use separate objects [pix_buffer_write] and [pix_buffer_read] or the [open( message.; #X obj 505 80 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 -1; #N canvas 0 22 450 300 openpanel 0; #X obj 114 62 inlet; #X obj 121 254 outlet; #X obj 114 125 openpanel; #X obj 114 199 t b a; #X msg 114 162 set open \$1 0; #X connect 0 0 2 0; #X connect 2 0 4 0; #X connect 3 0 1 0; #X connect 3 1 1 0; #X connect 4 0 3 0; #X restore 505 97 pd openpanel; #X text 23 300 Inlet 1: message: open <filename> <index>: put an image into the pix_buffer at the given index; #X msg 505 132 open somefile.jpg 0; #X msg 506 174 resize 15; #X text 23 384 Inlet 1: message: resize <size>: re-allocate slots in the buffer (slots will survive this); #X text 23 333 Inlet 1: message: allocate <xsize> <ysize> <bytes_per_pixel>: assume that all images in the pix_buffer will have the given dimension and preallocate memory for them (pixes will be set to black); #X msg 506 193 copy 0 2; #X msg 506 212 save /tmp/out.jpg 2; #X text 23 414 Inlet 1: message: copy <src> <target>: copy a pix from slot <src> to slot <target>; #X text 23 444 Inlet 1: message: save <filename> <index>: save image in given slot to harddisk.; #X connect 16 0 23 0; #X connect 18 0 23 0; #X connect 23 0 17 0; #X connect 25 0 26 0; #X connect 26 0 28 0; #X connect 28 0 23 0; #X connect 29 0 23 0; #X connect 32 0 23 0; #X connect 33 0 23 0;