diff options
42 files changed, 1776 insertions, 946 deletions
diff --git a/CHANGES.LOG b/CHANGES.LOG index e369e49..d76102e 100644 --- a/CHANGES.LOG +++ b/CHANGES.LOG @@ -1,3 +1,38 @@ +0.12.17 ( codename No pasa nada ) + added pdp_theorout~ : theora file recorder + fixed pdp_theorin~ : fixed buggy end of file detection + fixed pdp_theorin~ : now, it's able to read files without sound + added pdp_cropper : a video cropper for image compositing + ( see patch cutandpaste.pd ) + added pdp_background : a simple background generator + modified pdp_ocanvas : added an alpha channel for each source + modified pdp_text, pdp_form, pdp_pen : added an alpha channel ( global ) + +0.12.16 ( codename Fadaiat ) + added pdp_theorin~ : threaded theora file reader + ( warning : requires theora, ogg & vorbis static libs ) + + modified pdp_live~ : added an autoplay option ( default = true ) + modified pdp_live~ : made the files seekable + ( added an input for the frame number, works with ffmpeg >= 0.4.9 ) + modified pdp_live~ : better disconnection mechanism + modified pdp_live~ : reworked on a/v synchronisation + + fixed pdp_i/pdp_o : fixed huffman encoding and freezings + fixed pdp_i/pdp_o : fix communication between macs and pcs ( endianness problem ) + + added --with-ffmpeg=PATH and --with-mpeg4ip=PATH configure options + ( --enable-ffmpeg and --enable-mpeg4ip are dead ) + +0.12.15 ( codename Technologia Del Sur ) + added morphology patches : patches/morphology : opening, closing, thinning, thickening, skeletization + added morphology operator : distance transform + ( inspired by Paul Rosin, 91, http://www.cs.cf.ac.uk/User/Paul.Rosin/resources/sdt/ ) + added morphology operators : erosion ( pdp_erode ), dilation ( pdp_dilate ), hit and miss ( pdp_hitandmiss ) + added pdp_binary : transform an image to a binary image ( using yuv settings, a filter for morphology ) + ( for all the theory on morphology, thanx to the excellent site : http://homepages.inf.ed.ac.uk/rbf/HIPR2 ) + added pdp_disintegration : a new effect based on piksels summing and averaging + 0.12.14 ( codename Naveen's Ethiopian Cafe ) added pdp_mp4player~ : a quicktime stream reader ( compiled against meg4ip v1.0, needs some testing ) fixed pdp_mp4live~ : fixed audio encoding @@ -5,6 +40,7 @@ fixed pdp_canvas : fixed a huge memory leak ( reported by Ian Smith Heisters ) added colorgrid : a color picker written by Lluis Gomez i Bigorda ( http://www.artefacte.org/pd ) added help_pdp-tatiana.pd : a more simple to use help patch for effects, contribution from Tatiana de la O. + 0.12.13 ( codename Gollum Club Riereta ) improved decoding in pdp_live~, in particular for audio/video synchronization added a "end of stream" outlet in pdp_live~ ( when reaching the end of a file ) @@ -12,6 +48,7 @@ added pdp_spotlight : a spotlight, for cabaret (for pep') added pdp_cabaret patch : a patch to track someone with a spotlight ( poursuite ) added pdp_ieee1394 : firewire capture object for OSX based on pix_video ( OSX only ) + 0.12.12 added pdp_mp4live~ : mpeg4ip streaming object to stream to a darwin server note : now, building of streaming objects is optional @@ -19,12 +56,14 @@ fixed some crashes when objects like pdp_ctrack, pdp_cmap, pdp_compose were in a sub-patch ( problem reported by Mark Widmer ) added offsets messages in pdp_pen + 0.12.11 added pdp_charcoal to the effect rack : charcoal effect using edge detection, blur, normalization and negate ( it's an abstraction using basic pdp_objects ) fixed compilation problem with latest ffmpeg ( AVFMT_NOHEADER --> AVFMTCTX_NOHEADER ) commented pdp_aa : it introduces useless dependencies ( aalib ) and is not very good added pdp_ocanvas : canvas with some overlay + 0.12.10 fixed crashes and 'resize' bug in pdp_text added pdp_xcanvas : pdp_canvas + pdp_xv in one ( for performances reasons ) @@ -33,74 +72,96 @@ added pdp_fcqt : fast quicktime reader ( same as pdp_fqt but frames are compressed ) added help patches for pdp_yqt, pdp_fqt and pdp_fcqt adaptations for newer autoconfs + 0.12.9 fixed pdp_ripple added pdp_shape : a shape recognition object (based on color, similar to color tracker ) added "fill" in pdp_pen ( on request from ben ) + 0.12.8 added pdp_pen : a free hand drawing object ( on request from patrick/11h11.com ) + 0.12.7 added pdp_canvas : a canvas to display several video sources + 0.12.6 fix conflict between pdp_text and pdp_imgloader ( and the likes using Imlib2 ) fix successive loading of images in pdp_imgloader set help patches for all objects and install them in PD's doc folder ( compliant with 0.37 ) + 0.12.5 pdp_cache : hiding triangular zones from a video stream to let you do some collage ( see collage.pd patch ) pdp_imgloader : added "hide" method for triangles to let you do some collage ( see collage.pd patch ) pdp_transition : added "page" transitions + 0.12.4 added pdp_imgsaver : save an image from the current video stream pdp_transition : added "melt" and "blend" transitions + 0.12.3 added pdp_imgloader : load an image and blend it with a video added pdp_transition : some funky transitions, "circle", "wipe" and "random" added pdp_lumafilt : lumosity filter, useful to isolate some objects added pdp_smuck : same as pdp_transform ( mode 5 ) but setable, ported from veejay + 0.12.2 Fixed problems with Image Magick includes + 0.12.1 Added color components output in pdp_ctrack + 0.12.0 Compatibility with PDP 0.12 + 0.11.3 Nicolas Lhommet added scroll parameter in pdp_text + 0.11.2 added pdp_capture : capture a portion of screen : lets you import browser data, etc .... fixed pdp_compose + 0.11.1 added pdp_juxta : allow juxtaposition of frames + 0.11.0 change some packet allocation policies to comply with PDP 0.11 no new object + 0.10.1 added pdp_noquark object : moving object are clear, the background is noisy added tolerance input in pdp_quark + 0.10.0 added pdp_segsnd~ : produces sound from a segment of the video ( similar to pdp_scanxy~ ) binary compatible with pdp v.0.10 improved installation instructions + 0.9.2 fixed disconnection phase in pdp_live~ + 0.9.1 remove synchronization proposed by martin pi : it lead to some deadlocks sometimes + 0.9.0 fixed audio encoding/decoding in pdp_ffmpeg~/pdp_live~ ( which caused a lot of crashes ) add synchronization in pdp_live~ and other nice features ( thanks to martin pi ) made the audio decoding in pdp_live~ optional add "set cursor" message in pdp_cmap, pdp_ctrack, pdp_compose ( used in conjonction with coordinates output of pdp_xv v0.9 ) + 0.8.4 added pdp_live~ : receive a video feed, at least from a ffmpeg server ( ffserver ) fixed resampling in pdp_ffmpeg~ : resizing to a bigger image used to crash PD ( now, you can't resize to a bigger scale, blame it on libavcodec ) + 0.8.3 pdp_rec became pdp_rec~ : it can record audio now fix crash in pdp_ascii, pdp_nervous, pdp_quark + 0.8.2 added pdp_ffmpeg : stream to a ffmpeg server with possibly several formats ( mpeg, asf, ... ) NOTE : although there is an experimental audio streaming possibility, @@ -108,73 +169,95 @@ added a ratio action in pdp_ascii added a planes number action in pdp_quark and pdp_nervous ( plays on speed of switching ) fixed index bug in pdp_ctrack, pdp_cmap + 0.8.1 fixed colors in pdp_warhol + 0.8.0 added pdp_ascii : rendering of videos in ASCII art using character maps + 0.7.7 added pdp_aa : rendering of videos in ASCII art using aalib + 0.7.6 added pdp_cmap : color mapper ( thanx to liz for the suggestion ) added actions in color tracker ( steady mode, cursor on/off, frame on/off ), generally improved fixed colors in pdp_spiral, pdp_dice + 0.7.5 added pdp_form : addition of geometric forms added pdp_compose : color-based video compositor ( thanx to liz for the suggestion ) added actions in pdp_text ( rotations, font, resize, dither, blend ) fixed colors in pdp_transform, pdp_warp fix install stage + 0.7.4 added pdp_text : text addition on videos ( requires imlib2 ) use the automake/autoconf system optimized streaming again (pdp_i/pdp_o) fixed colors in pdp_puzzle + 0.7.3 fixed streaming objects pdp_i/pdp_o added "smoothing" and "framerate" controls to act on the bandwidth + 0.7.2 added shagadelic, dice and puzzle from effecTV modified objects to use PDP queue + 0.7.1 added cycle and transform : first effetTV objects using PDP queue ( i know i changed my mind ) all other objects must be modified to use PDP queue + 0.7.0 compatibility with PDP 0.7 + 0.6.2 added pdp_ctrack : color tracker : lets you follow an object + 0.6.1 added pdp_i/pdp_o : PDP packets streaming objects using bz2 added pdp_mgrid : motion grid detects movement within a grid + 0.6.0 added pdp_rec : a video recording object fixed a bug in pdp_edge incremented PDP release number : it's now 0.6 set proper credits for each effecTV plugin + 0.5.8 added pdp_spigot : a video signal routing utility + 0.5.7 added nervous and quark objects these will be the last effecTV objects added some effectv have been left aside ( fireTV, ... ) because they are just clones of some other effects or because i simply wasn't interested in porting them + 0.5.6 added radioactiv and warhol objects + 0.5.5 added edge and spiral objects happy new year 2003 + 0.5.4 renamed to PiDiP added rev and mosaic objects + 0.5.3 added parameter "increment" to ripple fix "threshold" in ripple added warp and mosaic object + 0.5.2 remove buggy support of GREY packets + 0.5.1 added aging and ripple effects + 0.5 initial release it is called 0.5 because it should be used with PDP 0.5 @@ -5,33 +5,31 @@ MANDATORY :: ***** PD sources : http://www-crca.ucsd.edu/~msp/software.html ***** PDP and its deps : http://zwizwa.fartit.com/pd/pdp/ ***** imlib2 : http://sourceforge.net/project/showfiles.php?group_id=2 +***** theora : http://www.theora.org/files/ + ----> watchout !! you will need the static libs ( theora.a, ogg.a, vorbis.a ) ***** Image Magick : http://www.imagemagick.org ----> watchout !! configure with --enable-shared OPTIONALLY :: ============= ***** ffmpeg : http://ffmpeg.sourceforge.net/cvs -( --enable-ffmpeg ) ----> watchout, it requires the cvs snapshot ! +( --with-ffmpeg=PATH ) ----> watchout, it requires the cvs snapshot ! + don't forget to activate mp3 and vorbis support in ffmpeg : ./configure --enable-mp3lame --enable-vorbis OR ***** mpeg4ip : http://mpeg4ip.sourceforge.net/ ( download mpeg4ip v1.0 ) -( --enable-mpeg4ip ) +( --with-mpeg4ip=PATH ) -b/ fix PD, PDP and FFMPEG/MPEG4IP paths in configure.ac +b/ ./configure --with-pd=PATH --with-pdp=PATH [--with-ffmpeg=PATH] OR [--with-mpeg4ip=PATH] ( not both ) -c/ autoconf +c/ make clean -d/ ./configure [--enable-ffmpeg] OR [--enable-mpeg4ip] ( not both ) +d/ make -e/ make clean +e/ as root, make install -f/ make - -g/ as root, make install - -h/ modify your pd start-up script : +f/ modify your pd start-up script : pidip is a library, it should be loaded with the "-lib <path>/pidip" command line option @@ -1,14 +1,15 @@ PD_DIR = /usr/local/pd PDP_DIR = /usr/local/pd/pdp -FFMPEG_SOURCE_DIR = /SOURCES/ffmpeg +FFMPEG_SOURCE_DIR = /SOURCES/ffmpeg-cvs-2003-03-04 -PDP_PIDIP_LIBS = -lbz2 -lz -ldl -lmp3lame -logg -lvorbis -lvorbisenc /SOURCES/ffmpeg/libavformat/libavformat.a /SOURCES/ffmpeg/libavcodec/libavcodec.a +PDP_PIDIP_LIBS = -lbz2 -lz -ldl -lmp3lame -logg -lvorbis -lvorbisenc /SOURCES/ffmpeg-cvs-2003-03-04/libavformat/libavformat.a /SOURCES/ffmpeg-cvs-2003-03-04/libavcodec/libavcodec.a IMLIB_CFLAGS = -I/usr/local/include -I/usr/X11R6/include -IMLIB_LIBS = -L/usr/local/lib -lImlib2 -lttf -lm -ldl -lXext -lXext -lX11 -L/usr/X11R6/lib -MAGICK_CFLAGS = -I/usr/X11R6/include -g -O2 -Wall -MAGICK_LIBS = -L/usr/X11R6/lib -lMagick -lMagick -ltiff -lfreetype -ljasper -ljpeg -lpng -lXext -lSM -lICE -lX11 -lbz2 -lxml2 -lz -lpthread -lm -L/usr/local/lib -L/usr/X11R6/lib -L/usr/X11R6/lib -L/usr/local/lib -PDP_PIDIP_INCLUDES = -I/usr/local/pd/src -I. -I/usr/local/pd/pdp/include -I../include -I../charmaps -I/SOURCES/ffmpeg/libavcodec -I/SOURCES/ffmpeg/libavformat -PDP_PIDIP_VERSION = 0.12.14 +IMLIB_LIBS = -L/usr/local/lib -lImlib2 -lfreetype -lz -lm -ldl -lXext -lXext -lX11 -L/usr/X11R6/lib +MAGICK_CFLAGS = -I/usr/X11R6/include -O2 -g -pipe -m32 -march=i386 -mtune=pentium4 -Wall -pthread +MAGICK_LIBS = -L/usr/X11R6/lib -lMagick -lMagick -ltiff -lfreetype -ljpeg -lpng -ldpstk -ldps -lXext -lXt -lSM -lICE -lX11 -lbz2 -lxml2 -lz -lpthread -lm -lpthread -L/usr/lib -L/usr/X11R6/lib -lfreetype -lz -L/usr/lib +THEORA_LIBS = /usr/lib/libtheora.a /usr/lib/libogg.a /usr/lib/libvorbis.a /usr/lib/libvorbisenc.a +PDP_PIDIP_INCLUDES = -I/usr/local/pd/src -I. -I/usr/local/pd/pdp/include -I../include -I../charmaps -I/SOURCES/ffmpeg-cvs-2003-03-04/libavcodec -I/SOURCES/ffmpeg-cvs-2003-03-04/libavformat +PDP_PIDIP_VERSION = 0.12.17 MPEG4IP_CFLAGS = PDP_PIDIP_DISTRO = /mnt/c/ydegoyon.free.fr/pidip-$(PDP_PIDIP_VERSION) @@ -35,7 +36,7 @@ pdp_pidip_all: pidip.pd_linux: pdp_pidip_all rm -f pidip.pd_linux - g++ -export_dynamic -shared -o pidip.pd_linux modules/*.o system/*.o $(PDP_PIDIP_LIBS) $(IMLIB_LIBS) $(MAGICK_LIBS) + g++ -export_dynamic -shared -o pidip.pd_linux modules/*.o system/*.o $(THEORA_LIBS) $(PDP_PIDIP_LIBS) $(IMLIB_LIBS) $(MAGICK_LIBS) strip --strip-unneeded pidip.pd_linux clean: @@ -43,6 +44,7 @@ clean: rm -f pidip.pd_linux install: + if test ! -d /usr/X11R6/lib/X11/fonts/TTF; then mkdir /usr/X11R6/lib/X11/fonts/TTF; fi cp fonts/* /usr/X11R6/lib/X11/fonts/TTF cp -f --remove-destination doc/* $(PD_DIR)/doc/5.reference diff --git a/Makefile.in b/Makefile.in index dfbd4c5..0370aab 100644 --- a/Makefile.in +++ b/Makefile.in @@ -7,6 +7,7 @@ IMLIB_CFLAGS = @IMLIB_CFLAGS@ IMLIB_LIBS = @IMLIB_LIBS@ MAGICK_CFLAGS = @MAGICK_CFLAGS@ MAGICK_LIBS = @MAGICK_LIBS@ +THEORA_LIBS = @THEORA_LIBS@ PDP_PIDIP_INCLUDES = @PDP_PIDIP_INCLUDES@ PDP_PIDIP_VERSION = @PDP_PIDIP_VERSION@ MPEG4IP_CFLAGS = @MPEG4IP_CFLAGS@ @@ -35,7 +36,7 @@ pdp_pidip_all: pidip.pd_linux: pdp_pidip_all rm -f pidip.pd_linux - g++ -export_dynamic -shared -o pidip.pd_linux modules/*.o system/*.o $(PDP_PIDIP_LIBS) $(IMLIB_LIBS) $(MAGICK_LIBS) + g++ -export_dynamic -shared -o pidip.pd_linux modules/*.o system/*.o $(THEORA_LIBS) $(PDP_PIDIP_LIBS) $(IMLIB_LIBS) $(MAGICK_LIBS) strip --strip-unneeded pidip.pd_linux clean: @@ -43,6 +44,7 @@ clean: rm -f pidip.pd_linux install: + if test ! -d /usr/X11R6/lib/X11/fonts/TTF; then mkdir /usr/X11R6/lib/X11/fonts/TTF; fi cp fonts/* /usr/X11R6/lib/X11/fonts/TTF cp -f --remove-destination doc/* $(PD_DIR)/doc/5.reference diff --git a/acinclude.m4 b/acinclude.m4 index bdce5c2..2eaf6f0 100644 --- a/acinclude.m4 +++ b/acinclude.m4 @@ -24,7 +24,7 @@ dnl At present there is no support for additional "MODULES" (see AM_PATH_GTK) dnl (shamelessly stolen from gtk.m4 and then hacked around a fair amount) dnl dnl @author Angus Lees <gusl@cse.unsw.edu.au> -dnl @version $Id: acinclude.m4,v 1.7 2004-05-18 00:59:44 sevyves Exp $ +dnl @version $Id: acinclude.m4,v 1.8 2004-11-14 22:52:19 sevyves Exp $ AC_DEFUN(AC_PATH_GENERIC, [dnl @@ -36,7 +36,7 @@ dnl At present there is no support for additional "MODULES" (see AM_PATH_GTK) dnl (shamelessly stolen from gtk.m4 and then hacked around a fair amount) dnl dnl @author Angus Lees <gusl@cse.unsw.edu.au> -dnl @version $Id: aclocal.m4,v 1.7 2004-05-18 00:59:44 sevyves Exp $ +dnl @version $Id: aclocal.m4,v 1.8 2004-11-14 22:52:19 sevyves Exp $ AC_DEFUN(AC_PATH_GENERIC, [dnl @@ -271,7 +271,7 @@ PACKAGE_VERSION= PACKAGE_STRING= PACKAGE_BUGREPORT= -ac_subst_vars='SHELL PATH_SEPARATOR PACKAGE_NAME PACKAGE_TARNAME PACKAGE_VERSION PACKAGE_STRING PACKAGE_BUGREPORT exec_prefix prefix program_transform_name bindir sbindir libexecdir datadir sysconfdir sharedstatedir localstatedir libdir includedir oldincludedir infodir mandir build_alias host_alias target_alias DEFS ECHO_C ECHO_N ECHO_T LIBS CC CFLAGS LDFLAGS CPPFLAGS ac_ct_CC EXEEXT OBJEXT CPP EGREP INSTALL_PROGRAM INSTALL_SCRIPT INSTALL_DATA SET_MAKE MAINTAINER_MODE_TRUE MAINTAINER_MODE_FALSE MAINT IMLIB2_CONFIG IMLIB_LIBS IMLIB_CFLAGS IMLIB2_CFLAGS IMLIB2_LIBS PDP_PIDIP_VERSION MAGICK_LIBS MAGICK_CFLAGS PD_DIR PDP_DIR FFMPEG_SOURCE_DIR MPEG4IP_SOURCE_DIR MPEG4IP_CFLAGS PDP_STREAMING_OBJECTS PDP_PIDIP_LIBS PDP_PIDIP_INCLUDES LIBOBJS LTLIBOBJS' +ac_subst_vars='SHELL PATH_SEPARATOR PACKAGE_NAME PACKAGE_TARNAME PACKAGE_VERSION PACKAGE_STRING PACKAGE_BUGREPORT exec_prefix prefix program_transform_name bindir sbindir libexecdir datadir sysconfdir sharedstatedir localstatedir libdir includedir oldincludedir infodir mandir build_alias host_alias target_alias DEFS ECHO_C ECHO_N ECHO_T LIBS CC CFLAGS LDFLAGS CPPFLAGS ac_ct_CC EXEEXT OBJEXT CPP EGREP INSTALL_PROGRAM INSTALL_SCRIPT INSTALL_DATA SET_MAKE MAINTAINER_MODE_TRUE MAINTAINER_MODE_FALSE MAINT IMLIB2_CONFIG IMLIB_LIBS IMLIB_CFLAGS IMLIB2_CFLAGS IMLIB2_LIBS PDP_PIDIP_VERSION MAGICK_LIBS MAGICK_CFLAGS THEORA_LIBS PD_DIR PDP_DIR FFMPEG_SOURCE_DIR MPEG4IP_SOURCE_DIR MPEG4IP_CFLAGS PDP_STREAMING_OBJECTS PDP_PIDIP_LIBS PDP_PIDIP_INCLUDES LIBOBJS LTLIBOBJS' ac_subst_files='' # Initialize some variables set by options. @@ -802,14 +802,16 @@ if test -n "$ac_init_help"; then Optional Features: --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) --enable-FEATURE[=ARG] include FEATURE [ARG=yes] - --enable-ffmpeg enable ffmpeg streaming support (no) - --enable-mpeg4ip enable mpeg4ip streaming support (no) --enable-maintainer-mode enable make rules and dependencies not useful (and sometimes confusing) to the casual installer Optional Packages: --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) + --with-pd=PATH pd source tree + --with-pdp=PATH pdp source tree + --with-ffmpeg=PATH ffmpeg source tree + --with-mpeg4ip=PATH mpeg4ip source tree --with-dmalloc use dmalloc, as in ftp://ftp.letters.com/src/dmalloc/dmalloc.tar.gz --with-imlib2-prefix=PFX Prefix where imlib2 is installed (optional) @@ -1264,27 +1266,96 @@ ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_config_headers="$ac_config_headers include/pidip_config.h" -# Check whether --enable-ffmpeg or --disable-ffmpeg was given. -if test "${enable_ffmpeg+set}" = set; then - enableval="$enable_ffmpeg" -else - enable_ffmpeg=no -fi; -# Check whether --enable-mpeg4ip or --disable-mpeg4ip was given. -if test "${enable_mpeg4ip+set}" = set; then - enableval="$enable_mpeg4ip" - -else - enable_mpeg4ip=no -fi; - -PDP_PIDIP_VERSION="0.12.14" +PDP_PIDIP_VERSION="0.12.17" PD_DIR=/usr/local/pd PDP_DIR=/usr/local/pd/pdp FFMPEG_SOURCE_DIR=/SOURCES/ffmpeg MPEG4IP_SOURCE_DIR=/SOURCES/mpeg4ip PDP_STREAMING_OBJECTS= +enable_ffmpeg=no +enable_mpeg4ip=no + + +# Check whether --with-pdsources or --without-pdsources was given. +if test "${with_pdsources+set}" = set; then + withval="$with_pdsources" + +fi; +if ! test -z "${with_pd}" +then + pd_tree="`cd ${with_pd} 2>/dev/null && pwd`" + if test -z "${pd_tree}" + then + { { echo "$as_me:$LINENO: error: pd sources not found in ${with_pd}" >&5 +echo "$as_me: error: pd sources not found in ${with_pd}" >&2;} + { (exit 1); exit 1; }; } + else + PD_DIR=${pd_tree} + fi +fi + + +# Check whether --with-pdpsources or --without-pdpsources was given. +if test "${with_pdpsources+set}" = set; then + withval="$with_pdpsources" + +fi; +if ! test -z "${with_pdp}" +then + pdp_tree="`cd ${with_pdp} 2>/dev/null && pwd`" + if test -z "${pdp_tree}" + then + { { echo "$as_me:$LINENO: error: pdp sources not found in ${with_pdp}" >&5 +echo "$as_me: error: pdp sources not found in ${with_pdp}" >&2;} + { (exit 1); exit 1; }; } + else + PDP_DIR=${pdp_tree} + fi +fi + + +# Check whether --with-ffmpeg or --without-ffmpeg was given. +if test "${with_ffmpeg+set}" = set; then + withval="$with_ffmpeg" + +fi; +if ! test -z "${with_ffmpeg}" +then + ffmpeg_tree="`cd ${with_ffmpeg} 2>/dev/null && pwd`" + if test -z "${ffmpeg_tree}" + then + { { echo "$as_me:$LINENO: error: ffmpeg sources not found in ${with_ffmpeg}" >&5 +echo "$as_me: error: ffmpeg sources not found in ${with_ffmpeg}" >&2;} + { (exit 1); exit 1; }; } + else + FFMPEG_SOURCE_DIR=${ffmpeg_tree} + enable_ffmpeg=yes + fi +fi + + +# Check whether --with-mpeg4ip or --without-mpeg4ip was given. +if test "${with_mpeg4ip+set}" = set; then + withval="$with_mpeg4ip" + +fi; +if ! test -z "${with_mpeg4ip}" +then + mpeg4ip_tree="`cd ${with_mpeg4ip} 2>/dev/null && pwd`" + if test -z "${mpeg4ip_tree}" + then + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 + { { echo "$as_me:$LINENO: error: mpeg4ip sources not found in ${with_mpeg4ip}" >&5 +echo "$as_me: error: mpeg4ip sources not found in ${with_mpeg4ip}" >&2;} + { (exit 1); exit 1; }; } + else + MPEG4IP_SOURCE_DIR=${mpeg4ip_tree} + enable_mpeg4ip=yes + fi +fi + PDP_PIDIP_LIBS="$PDP_PIDIP_LIBS -lbz2 -lz -ldl -lmp3lame -logg -lvorbis -lvorbisenc" PDP_PIDIP_INCLUDES="-I$PD_DIR/src -I. -I$PDP_DIR/include -I../include -I../charmaps" @@ -4561,6 +4632,84 @@ echo "$as_me: error: streaming requires vorbis encoder library!!" >&2;} fi +echo "$as_me:$LINENO: checking for theora_encode_init in -ltheora" >&5 +echo $ECHO_N "checking for theora_encode_init in -ltheora... $ECHO_C" >&6 +if test "${ac_cv_lib_theora_theora_encode_init+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ltheora -lm $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char theora_encode_init (); +int +main () +{ +theora_encode_init (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" + || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_theora_theora_encode_init=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_theora_theora_encode_init=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_theora_theora_encode_init" >&5 +echo "${ECHO_T}$ac_cv_lib_theora_theora_encode_init" >&6 +if test $ac_cv_lib_theora_theora_encode_init = yes; then + cat >>confdefs.h <<_ACEOF +#define HAVE_LIBTHEORA 1 +_ACEOF + + LIBS="-ltheora $LIBS" + +else + { { echo "$as_me:$LINENO: error: theora library needed! sorry..." >&5 +echo "$as_me: error: theora library needed! sorry..." >&2;} + { (exit 1); exit 1; }; } +fi + + MAGICK_LIBS="-L/usr/X11R6/lib -lMagick `Magick-config --libs` `Magick-config --ldflags`" @@ -4568,13 +4717,49 @@ MAGICK_CFLAGS="-I/usr/X11R6/include `Magick-config --cflags` " +THEORA_LIBS="" +if test -f /usr/lib/libtheora.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libtheora.a" +fi +if test -f /usr/local/lib/libtheora.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libtheora.a" +fi +if test -f /usr/lib/libogg.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libogg.a" +fi +if test -f /usr/local/lib/libogg.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libogg.a" +fi +if test -f /usr/lib/libvorbis.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libvorbis.a" +fi +if test -f /usr/local/lib/libvorbis.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libvorbis.a" +fi +if test -f /usr/lib/libvorbisenc.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libvorbisenc.a" +fi +if test -f /usr/local/lib/libvorbisenc.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libvorbisenc.a" +fi + + + echo -n "looking for pd sources (required) ... " if test -f $PD_DIR/src/m_pd.h then echo "ok." else - echo "pd source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "pd source tree not found... install it and use the --with-pd=<path> configuration option." exit -1 fi @@ -4584,7 +4769,7 @@ then echo "ok." else - echo "pdp source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "pdp source tree not found... install it and use the --with-pdp=<path> configuration option." exit -1 fi @@ -4594,7 +4779,7 @@ then if test -f $FFMPEG_SOURCE_DIR/libavformat/avformat.h then - PDP_STREAMING_OBJECTS="$PDP_STREAMING_OBJECTS pdp_live~.o pdp_ffmpeg~.o" + PDP_STREAMING_OBJECTS="pdp_live~.o pdp_ffmpeg~.o" cat >>confdefs.h <<\_ACEOF #define HAVE_PIDIP_FFMPEG 1 @@ -4604,7 +4789,7 @@ _ACEOF PDP_PIDIP_INCLUDES="$PDP_PIDIP_INCLUDES -I$FFMPEG_SOURCE_DIR/libavcodec -I$FFMPEG_SOURCE_DIR/libavformat" echo "ok." else - echo "ffmpeg source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "ffmpeg source tree not found... install it and use the --with-ffmpeg=<path> configuration option." exit -1 fi fi @@ -4615,7 +4800,7 @@ then if test -f $MPEG4IP_SOURCE_DIR/server/mp4live/mp4live_common.h then - PDP_STREAMING_OBJECTS="$PDP_STREAMING_OBJECTS pdp_mp4config.o pdp_mp4videosource.o pdp_mp4audiosource.o pdp_mp4live~.o pdp_mp4player~.o pdp_mp4audiosync.o pdp_mp4videosync.o pdp_mp4playermedia.o pdp_mp4playersession.o" + PDP_STREAMING_OBJECTS="pdp_mp4config.o pdp_mp4videosource.o pdp_mp4audiosource.o pdp_mp4live~.o pdp_mp4player~.o pdp_mp4audiosync.o pdp_mp4videosync.o pdp_mp4playermedia.o pdp_mp4playersession.o" cat >>confdefs.h <<\_ACEOF #define HAVE_PIDIP_MPEG4IP 1 @@ -4627,7 +4812,7 @@ _ACEOF echo "ok." else - echo "mpeg4ip source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "mpeg4ip source tree not found... install it and use the --with-mpeg4ip=<path> configuration option." exit -1 fi fi @@ -5275,6 +5460,7 @@ s,@IMLIB2_LIBS@,$IMLIB2_LIBS,;t t s,@PDP_PIDIP_VERSION@,$PDP_PIDIP_VERSION,;t t s,@MAGICK_LIBS@,$MAGICK_LIBS,;t t s,@MAGICK_CFLAGS@,$MAGICK_CFLAGS,;t t +s,@THEORA_LIBS@,$THEORA_LIBS,;t t s,@PD_DIR@,$PD_DIR,;t t s,@PDP_DIR@,$PDP_DIR,;t t s,@FFMPEG_SOURCE_DIR@,$FFMPEG_SOURCE_DIR,;t t diff --git a/configure.ac b/configure.ac index 759dd2a..9bf0afb 100644 --- a/configure.ac +++ b/configure.ac @@ -2,19 +2,71 @@ dnl Process this file with autoconf to produce a configure script. AC_INIT AC_CONFIG_HEADER(include/pidip_config.h) -AC_ARG_ENABLE(ffmpeg, - [ --enable-ffmpeg enable ffmpeg streaming support (no)], , - enable_ffmpeg=no) -AC_ARG_ENABLE(mpeg4ip, - [ --enable-mpeg4ip enable mpeg4ip streaming support (no)], , - enable_mpeg4ip=no) - -PDP_PIDIP_VERSION="0.12.14" + +PDP_PIDIP_VERSION="0.12.17" PD_DIR=/usr/local/pd PDP_DIR=/usr/local/pd/pdp FFMPEG_SOURCE_DIR=/SOURCES/ffmpeg MPEG4IP_SOURCE_DIR=/SOURCES/mpeg4ip PDP_STREAMING_OBJECTS= +enable_ffmpeg=no +enable_mpeg4ip=no + +AC_ARG_WITH(pdsources, [ --with-pd=PATH pd source tree]) +if ! test -z "${with_pd}" +then + pd_tree="`cd ${with_pd} 2>/dev/null && pwd`" + if test -z "${pd_tree}" + then + dnl The given directory can't be found + AC_MSG_ERROR([pd sources not found in ${with_pd}]) + else + PD_DIR=${pd_tree} + fi +fi + +AC_ARG_WITH(pdpsources, [ --with-pdp=PATH pdp source tree]) +if ! test -z "${with_pdp}" +then + pdp_tree="`cd ${with_pdp} 2>/dev/null && pwd`" + if test -z "${pdp_tree}" + then + dnl The given directory can't be found + AC_MSG_ERROR([pdp sources not found in ${with_pdp}]) + else + PDP_DIR=${pdp_tree} + fi +fi + +AC_ARG_WITH(ffmpeg, [ --with-ffmpeg=PATH ffmpeg source tree]) +if ! test -z "${with_ffmpeg}" +then + ffmpeg_tree="`cd ${with_ffmpeg} 2>/dev/null && pwd`" + if test -z "${ffmpeg_tree}" + then + dnl The given directory can't be found + AC_MSG_ERROR([ffmpeg sources not found in ${with_ffmpeg}]) + else + FFMPEG_SOURCE_DIR=${ffmpeg_tree} + enable_ffmpeg=yes + fi +fi + +AC_ARG_WITH(mpeg4ip, [ --with-mpeg4ip=PATH mpeg4ip source tree]) +if ! test -z "${with_mpeg4ip}" +then + mpeg4ip_tree="`cd ${with_mpeg4ip} 2>/dev/null && pwd`" + if test -z "${mpeg4ip_tree}" + then + dnl The given directory can't be found + AC_MSG_RESULT(no) + AC_MSG_ERROR([mpeg4ip sources not found in ${with_mpeg4ip}]) + else + MPEG4IP_SOURCE_DIR=${mpeg4ip_tree} + enable_mpeg4ip=yes + fi +fi + PDP_PIDIP_LIBS="$PDP_PIDIP_LIBS -lbz2 -lz -ldl -lmp3lame -logg -lvorbis -lvorbisenc" PDP_PIDIP_INCLUDES="-I$PD_DIR/src -I. -I$PDP_DIR/include -I../include -I../charmaps" @@ -50,6 +102,7 @@ AC_CHECK_LIB(mp3lame, InitMP3, , AC_MSG_ERROR(streaming requires lame library!!) AC_CHECK_LIB(ogg, ogg_stream_init, , AC_MSG_ERROR(streaming requires ogg library!!), -lm) AC_CHECK_LIB(vorbis, vorbis_analysis_init, , AC_MSG_ERROR(streaming requires vorbis library!!), -lm) AC_CHECK_LIB(vorbisenc, vorbis_encode_setup_init, , AC_MSG_ERROR(streaming requires vorbis encoder library!!), -lm) +AC_CHECK_LIB(theora, theora_encode_init, , AC_MSG_ERROR(theora library needed! sorry...), -lm) AC_SUBST(PDP_PIDIP_VERSION) @@ -58,13 +111,49 @@ MAGICK_CFLAGS="-I/usr/X11R6/include `Magick-config --cflags` " AC_SUBST(MAGICK_LIBS) AC_SUBST(MAGICK_CFLAGS) +THEORA_LIBS="" +if test -f /usr/lib/libtheora.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libtheora.a" +fi +if test -f /usr/local/lib/libtheora.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libtheora.a" +fi +if test -f /usr/lib/libogg.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libogg.a" +fi +if test -f /usr/local/lib/libogg.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libogg.a" +fi +if test -f /usr/lib/libvorbis.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libvorbis.a" +fi +if test -f /usr/local/lib/libvorbis.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libvorbis.a" +fi +if test -f /usr/lib/libvorbisenc.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libvorbisenc.a" +fi +if test -f /usr/local/lib/libvorbisenc.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libvorbisenc.a" +fi + +AC_SUBST(THEORA_LIBS) + echo -n "looking for pd sources (required) ... " if test -f $PD_DIR/src/m_pd.h then AC_SUBST(PD_DIR) echo "ok." else - echo "pd source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "pd source tree not found... install it and use the --with-pd=<path> configuration option." exit -1 fi @@ -74,7 +163,7 @@ then AC_SUBST(PDP_DIR) echo "ok." else - echo "pdp source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "pdp source tree not found... install it and use the --with-pdp=<path> configuration option." exit -1 fi @@ -84,13 +173,13 @@ then if test -f $FFMPEG_SOURCE_DIR/libavformat/avformat.h then AC_SUBST(FFMPEG_SOURCE_DIR) - PDP_STREAMING_OBJECTS="$PDP_STREAMING_OBJECTS pdp_live~.o pdp_ffmpeg~.o" + PDP_STREAMING_OBJECTS="pdp_live~.o pdp_ffmpeg~.o" AC_DEFINE(HAVE_PIDIP_FFMPEG, 1, build pdp_live~/pdp_ffmpeg~) PDP_PIDIP_LIBS="$PDP_PIDIP_LIBS $FFMPEG_SOURCE_DIR/libavformat/libavformat.a $FFMPEG_SOURCE_DIR/libavcodec/libavcodec.a" PDP_PIDIP_INCLUDES="$PDP_PIDIP_INCLUDES -I$FFMPEG_SOURCE_DIR/libavcodec -I$FFMPEG_SOURCE_DIR/libavformat" echo "ok." else - echo "ffmpeg source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "ffmpeg source tree not found... install it and use the --with-ffmpeg=<path> configuration option." exit -1 fi fi @@ -101,7 +190,7 @@ then if test -f $MPEG4IP_SOURCE_DIR/server/mp4live/mp4live_common.h then AC_SUBST(MPEG4IP_SOURCE_DIR) - PDP_STREAMING_OBJECTS="$PDP_STREAMING_OBJECTS pdp_mp4config.o pdp_mp4videosource.o pdp_mp4audiosource.o pdp_mp4live~.o pdp_mp4player~.o pdp_mp4audiosync.o pdp_mp4videosync.o pdp_mp4playermedia.o pdp_mp4playersession.o" + PDP_STREAMING_OBJECTS="pdp_mp4config.o pdp_mp4videosource.o pdp_mp4audiosource.o pdp_mp4live~.o pdp_mp4player~.o pdp_mp4audiosync.o pdp_mp4videosync.o pdp_mp4playermedia.o pdp_mp4playersession.o" AC_DEFINE(HAVE_PIDIP_MPEG4IP, 1, build pdp_mp4live~/pdp_mp4player~) PDP_PIDIP_LIBS="$PDP_PIDIP_LIBS $MPEG4IP_SOURCE_DIR/player/src/our_bytestream_file.o $MPEG4IP_SOURCE_DIR/player/src/our_config_file.o $MPEG4IP_SOURCE_DIR/player/src/qtime_file.o $MPEG4IP_SOURCE_DIR/player/src/mp4_file.o $MPEG4IP_SOURCE_DIR/player/src/mpeg3_file.o $MPEG4IP_SOURCE_DIR/player/src/avi_file.o $MPEG4IP_SOURCE_DIR/player/src/ip_port.o $MPEG4IP_SOURCE_DIR/player/src/media_utils.o $MPEG4IP_SOURCE_DIR/player/src/mpeg2t_thread.o $MPEG4IP_SOURCE_DIR/player/src/mpeg2t_thread_nx.o $MPEG4IP_SOURCE_DIR/player/src/*bytestream.o $MPEG4IP_SOURCE_DIR/player/src/*plugin.o $MPEG4IP_SOURCE_DIR/player/src/player_sdp.o $MPEG4IP_SOURCE_DIR/player/src/player_util.o $MPEG4IP_SOURCE_DIR/player/src/audio.o $MPEG4IP_SOURCE_DIR/player/src/video.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_util_mpeg4.o $MPEG4IP_SOURCE_DIR/server/mp4live/sdp_file.o $MPEG4IP_SOURCE_DIR/server/mp4live/util.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_encoder.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_xvid.o $MPEG4IP_SOURCE_DIR/server/mp4live/media_source.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_util_rgb.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_util_resize.o $MPEG4IP_SOURCE_DIR/server/mp4live/resample.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_encoder_base.o $MPEG4IP_SOURCE_DIR/server/mp4live/audio_encoder.o $MPEG4IP_SOURCE_DIR/server/mp4live/audio_encoder_base.o $MPEG4IP_SOURCE_DIR/server/mp4live/audio_encoder_tables.o $MPEG4IP_SOURCE_DIR/server/mp4live/audio_lame.o $MPEG4IP_SOURCE_DIR/server/mp4live/audio_faac.o $MPEG4IP_SOURCE_DIR/server/mp4live/rtp_transmitter.o $MPEG4IP_SOURCE_DIR/server/mp4live/h261/.libs/*.a $MPEG4IP_SOURCE_DIR/lib/sdp/.libs/libsdp.so $MPEG4IP_SOURCE_DIR/player/lib/mp4util/.libs/libmp4util.so $MPEG4IP_SOURCE_DIR/player/lib/libhttp/.libs/libhttp.a $MPEG4IP_SOURCE_DIR/lib/config_file/.libs/libconfig_file.so $MPEG4IP_SOURCE_DIR/lib/msg_queue/.libs/libmsg_queue.so $MPEG4IP_SOURCE_DIR/lib/mp4av/.libs/libmp4av.so $MPEG4IP_SOURCE_DIR/lib/mp4/.libs/libmp4.so $MPEG4IP_SOURCE_DIR/lib/mp4v2/.libs/libmp4v2.so $MPEG4IP_SOURCE_DIR/lib/SDL/src/.libs/libSDL.so $MPEG4IP_SOURCE_DIR/lib/rtp/*.o $MPEG4IP_SOURCE_DIR/player/lib/rtsp/.libs/librtsp.a $MPEG4IP_SOURCE_DIR/common/video/libmpeg32/.libs/*.a $MPEG4IP_SOURCE_DIR/lib/avi/.libs/libavi.al $MPEG4IP_SOURCE_DIR/lib/mpeg2t/.libs/libmpeg2_transport.al $MPEG4IP_SOURCE_DIR/player/lib/audio/mp3util/.libs/libmp3utils.al -lm -L/usr/X11R6/lib -lX11 -lXext -lpthread $MPEG4IP_SOURCE_DIR/lib/SDL/src/main/libSDLmain.a -ldl -Wl,--rpath -Wl,/usr/local/lib -lfaac -lmpeg4ip_xvid" PDP_PIDIP_INCLUDES="$PDP_PIDIP_INCLUDES -I/usr/include/SDL -I/usr/local/include/SDL -I$MPEG4IP_SOURCE_DIR/server/mp4live -I$MPEG4IP_SOURCE_DIR/player/src -I$MPEG4IP_SOURCE_DIR/player/lib -I$MPEG4IP_SOURCE_DIR/lib/msg_queue -I$MPEG4IP_SOURCE_DIR/lib" @@ -109,7 +198,7 @@ then AC_SUBST(MPEG4IP_CFLAGS) echo "ok." else - echo "mpeg4ip source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "mpeg4ip source tree not found... install it and use the --with-mpeg4ip=<path> configuration option." exit -1 fi fi diff --git a/configure.in b/configure.in index 759dd2a..9bf0afb 100644 --- a/configure.in +++ b/configure.in @@ -2,19 +2,71 @@ dnl Process this file with autoconf to produce a configure script. AC_INIT AC_CONFIG_HEADER(include/pidip_config.h) -AC_ARG_ENABLE(ffmpeg, - [ --enable-ffmpeg enable ffmpeg streaming support (no)], , - enable_ffmpeg=no) -AC_ARG_ENABLE(mpeg4ip, - [ --enable-mpeg4ip enable mpeg4ip streaming support (no)], , - enable_mpeg4ip=no) - -PDP_PIDIP_VERSION="0.12.14" + +PDP_PIDIP_VERSION="0.12.17" PD_DIR=/usr/local/pd PDP_DIR=/usr/local/pd/pdp FFMPEG_SOURCE_DIR=/SOURCES/ffmpeg MPEG4IP_SOURCE_DIR=/SOURCES/mpeg4ip PDP_STREAMING_OBJECTS= +enable_ffmpeg=no +enable_mpeg4ip=no + +AC_ARG_WITH(pdsources, [ --with-pd=PATH pd source tree]) +if ! test -z "${with_pd}" +then + pd_tree="`cd ${with_pd} 2>/dev/null && pwd`" + if test -z "${pd_tree}" + then + dnl The given directory can't be found + AC_MSG_ERROR([pd sources not found in ${with_pd}]) + else + PD_DIR=${pd_tree} + fi +fi + +AC_ARG_WITH(pdpsources, [ --with-pdp=PATH pdp source tree]) +if ! test -z "${with_pdp}" +then + pdp_tree="`cd ${with_pdp} 2>/dev/null && pwd`" + if test -z "${pdp_tree}" + then + dnl The given directory can't be found + AC_MSG_ERROR([pdp sources not found in ${with_pdp}]) + else + PDP_DIR=${pdp_tree} + fi +fi + +AC_ARG_WITH(ffmpeg, [ --with-ffmpeg=PATH ffmpeg source tree]) +if ! test -z "${with_ffmpeg}" +then + ffmpeg_tree="`cd ${with_ffmpeg} 2>/dev/null && pwd`" + if test -z "${ffmpeg_tree}" + then + dnl The given directory can't be found + AC_MSG_ERROR([ffmpeg sources not found in ${with_ffmpeg}]) + else + FFMPEG_SOURCE_DIR=${ffmpeg_tree} + enable_ffmpeg=yes + fi +fi + +AC_ARG_WITH(mpeg4ip, [ --with-mpeg4ip=PATH mpeg4ip source tree]) +if ! test -z "${with_mpeg4ip}" +then + mpeg4ip_tree="`cd ${with_mpeg4ip} 2>/dev/null && pwd`" + if test -z "${mpeg4ip_tree}" + then + dnl The given directory can't be found + AC_MSG_RESULT(no) + AC_MSG_ERROR([mpeg4ip sources not found in ${with_mpeg4ip}]) + else + MPEG4IP_SOURCE_DIR=${mpeg4ip_tree} + enable_mpeg4ip=yes + fi +fi + PDP_PIDIP_LIBS="$PDP_PIDIP_LIBS -lbz2 -lz -ldl -lmp3lame -logg -lvorbis -lvorbisenc" PDP_PIDIP_INCLUDES="-I$PD_DIR/src -I. -I$PDP_DIR/include -I../include -I../charmaps" @@ -50,6 +102,7 @@ AC_CHECK_LIB(mp3lame, InitMP3, , AC_MSG_ERROR(streaming requires lame library!!) AC_CHECK_LIB(ogg, ogg_stream_init, , AC_MSG_ERROR(streaming requires ogg library!!), -lm) AC_CHECK_LIB(vorbis, vorbis_analysis_init, , AC_MSG_ERROR(streaming requires vorbis library!!), -lm) AC_CHECK_LIB(vorbisenc, vorbis_encode_setup_init, , AC_MSG_ERROR(streaming requires vorbis encoder library!!), -lm) +AC_CHECK_LIB(theora, theora_encode_init, , AC_MSG_ERROR(theora library needed! sorry...), -lm) AC_SUBST(PDP_PIDIP_VERSION) @@ -58,13 +111,49 @@ MAGICK_CFLAGS="-I/usr/X11R6/include `Magick-config --cflags` " AC_SUBST(MAGICK_LIBS) AC_SUBST(MAGICK_CFLAGS) +THEORA_LIBS="" +if test -f /usr/lib/libtheora.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libtheora.a" +fi +if test -f /usr/local/lib/libtheora.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libtheora.a" +fi +if test -f /usr/lib/libogg.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libogg.a" +fi +if test -f /usr/local/lib/libogg.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libogg.a" +fi +if test -f /usr/lib/libvorbis.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libvorbis.a" +fi +if test -f /usr/local/lib/libvorbis.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libvorbis.a" +fi +if test -f /usr/lib/libvorbisenc.a +then + THEORA_LIBS="$THEORA_LIBS /usr/lib/libvorbisenc.a" +fi +if test -f /usr/local/lib/libvorbisenc.a +then + THEORA_LIBS="$THEORA_LIBS /usr/local/lib/libvorbisenc.a" +fi + +AC_SUBST(THEORA_LIBS) + echo -n "looking for pd sources (required) ... " if test -f $PD_DIR/src/m_pd.h then AC_SUBST(PD_DIR) echo "ok." else - echo "pd source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "pd source tree not found... install it and use the --with-pd=<path> configuration option." exit -1 fi @@ -74,7 +163,7 @@ then AC_SUBST(PDP_DIR) echo "ok." else - echo "pdp source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "pdp source tree not found... install it and use the --with-pdp=<path> configuration option." exit -1 fi @@ -84,13 +173,13 @@ then if test -f $FFMPEG_SOURCE_DIR/libavformat/avformat.h then AC_SUBST(FFMPEG_SOURCE_DIR) - PDP_STREAMING_OBJECTS="$PDP_STREAMING_OBJECTS pdp_live~.o pdp_ffmpeg~.o" + PDP_STREAMING_OBJECTS="pdp_live~.o pdp_ffmpeg~.o" AC_DEFINE(HAVE_PIDIP_FFMPEG, 1, build pdp_live~/pdp_ffmpeg~) PDP_PIDIP_LIBS="$PDP_PIDIP_LIBS $FFMPEG_SOURCE_DIR/libavformat/libavformat.a $FFMPEG_SOURCE_DIR/libavcodec/libavcodec.a" PDP_PIDIP_INCLUDES="$PDP_PIDIP_INCLUDES -I$FFMPEG_SOURCE_DIR/libavcodec -I$FFMPEG_SOURCE_DIR/libavformat" echo "ok." else - echo "ffmpeg source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "ffmpeg source tree not found... install it and use the --with-ffmpeg=<path> configuration option." exit -1 fi fi @@ -101,7 +190,7 @@ then if test -f $MPEG4IP_SOURCE_DIR/server/mp4live/mp4live_common.h then AC_SUBST(MPEG4IP_SOURCE_DIR) - PDP_STREAMING_OBJECTS="$PDP_STREAMING_OBJECTS pdp_mp4config.o pdp_mp4videosource.o pdp_mp4audiosource.o pdp_mp4live~.o pdp_mp4player~.o pdp_mp4audiosync.o pdp_mp4videosync.o pdp_mp4playermedia.o pdp_mp4playersession.o" + PDP_STREAMING_OBJECTS="pdp_mp4config.o pdp_mp4videosource.o pdp_mp4audiosource.o pdp_mp4live~.o pdp_mp4player~.o pdp_mp4audiosync.o pdp_mp4videosync.o pdp_mp4playermedia.o pdp_mp4playersession.o" AC_DEFINE(HAVE_PIDIP_MPEG4IP, 1, build pdp_mp4live~/pdp_mp4player~) PDP_PIDIP_LIBS="$PDP_PIDIP_LIBS $MPEG4IP_SOURCE_DIR/player/src/our_bytestream_file.o $MPEG4IP_SOURCE_DIR/player/src/our_config_file.o $MPEG4IP_SOURCE_DIR/player/src/qtime_file.o $MPEG4IP_SOURCE_DIR/player/src/mp4_file.o $MPEG4IP_SOURCE_DIR/player/src/mpeg3_file.o $MPEG4IP_SOURCE_DIR/player/src/avi_file.o $MPEG4IP_SOURCE_DIR/player/src/ip_port.o $MPEG4IP_SOURCE_DIR/player/src/media_utils.o $MPEG4IP_SOURCE_DIR/player/src/mpeg2t_thread.o $MPEG4IP_SOURCE_DIR/player/src/mpeg2t_thread_nx.o $MPEG4IP_SOURCE_DIR/player/src/*bytestream.o $MPEG4IP_SOURCE_DIR/player/src/*plugin.o $MPEG4IP_SOURCE_DIR/player/src/player_sdp.o $MPEG4IP_SOURCE_DIR/player/src/player_util.o $MPEG4IP_SOURCE_DIR/player/src/audio.o $MPEG4IP_SOURCE_DIR/player/src/video.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_util_mpeg4.o $MPEG4IP_SOURCE_DIR/server/mp4live/sdp_file.o $MPEG4IP_SOURCE_DIR/server/mp4live/util.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_encoder.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_xvid.o $MPEG4IP_SOURCE_DIR/server/mp4live/media_source.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_util_rgb.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_util_resize.o $MPEG4IP_SOURCE_DIR/server/mp4live/resample.o $MPEG4IP_SOURCE_DIR/server/mp4live/video_encoder_base.o $MPEG4IP_SOURCE_DIR/server/mp4live/audio_encoder.o $MPEG4IP_SOURCE_DIR/server/mp4live/audio_encoder_base.o $MPEG4IP_SOURCE_DIR/server/mp4live/audio_encoder_tables.o $MPEG4IP_SOURCE_DIR/server/mp4live/audio_lame.o $MPEG4IP_SOURCE_DIR/server/mp4live/audio_faac.o $MPEG4IP_SOURCE_DIR/server/mp4live/rtp_transmitter.o $MPEG4IP_SOURCE_DIR/server/mp4live/h261/.libs/*.a $MPEG4IP_SOURCE_DIR/lib/sdp/.libs/libsdp.so $MPEG4IP_SOURCE_DIR/player/lib/mp4util/.libs/libmp4util.so $MPEG4IP_SOURCE_DIR/player/lib/libhttp/.libs/libhttp.a $MPEG4IP_SOURCE_DIR/lib/config_file/.libs/libconfig_file.so $MPEG4IP_SOURCE_DIR/lib/msg_queue/.libs/libmsg_queue.so $MPEG4IP_SOURCE_DIR/lib/mp4av/.libs/libmp4av.so $MPEG4IP_SOURCE_DIR/lib/mp4/.libs/libmp4.so $MPEG4IP_SOURCE_DIR/lib/mp4v2/.libs/libmp4v2.so $MPEG4IP_SOURCE_DIR/lib/SDL/src/.libs/libSDL.so $MPEG4IP_SOURCE_DIR/lib/rtp/*.o $MPEG4IP_SOURCE_DIR/player/lib/rtsp/.libs/librtsp.a $MPEG4IP_SOURCE_DIR/common/video/libmpeg32/.libs/*.a $MPEG4IP_SOURCE_DIR/lib/avi/.libs/libavi.al $MPEG4IP_SOURCE_DIR/lib/mpeg2t/.libs/libmpeg2_transport.al $MPEG4IP_SOURCE_DIR/player/lib/audio/mp3util/.libs/libmp3utils.al -lm -L/usr/X11R6/lib -lX11 -lXext -lpthread $MPEG4IP_SOURCE_DIR/lib/SDL/src/main/libSDLmain.a -ldl -Wl,--rpath -Wl,/usr/local/lib -lfaac -lmpeg4ip_xvid" PDP_PIDIP_INCLUDES="$PDP_PIDIP_INCLUDES -I/usr/include/SDL -I/usr/local/include/SDL -I$MPEG4IP_SOURCE_DIR/server/mp4live -I$MPEG4IP_SOURCE_DIR/player/src -I$MPEG4IP_SOURCE_DIR/player/lib -I$MPEG4IP_SOURCE_DIR/lib/msg_queue -I$MPEG4IP_SOURCE_DIR/lib" @@ -109,7 +198,7 @@ then AC_SUBST(MPEG4IP_CFLAGS) echo "ok." else - echo "mpeg4ip source tree not found... install it, fix the path in configure.ac and run autoconf" + echo "mpeg4ip source tree not found... install it and use the --with-mpeg4ip=<path> configuration option." exit -1 fi fi diff --git a/doc/help-pdp_ascii.pd b/doc/help-pdp_ascii.pd index d678c46..120ea20 100644 --- a/doc/help-pdp_ascii.pd +++ b/doc/help-pdp_ascii.pd @@ -1,8 +1,8 @@ -#N canvas 84 12 763 664 10; +#N canvas 368 56 763 664 10; #X obj 268 64 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 -1; #X msg 123 136 loop \$1; -#X obj 124 114 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 1 +#X obj 124 114 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 0 1; #X msg 370 44 open \$1; #X obj 369 20 openpanel; @@ -33,7 +33,6 @@ #X msg 302 372 brightness \$1; #X floatatom 404 373 5 0 0 0 - - -; #X floatatom 302 398 5 0 0 0 - - -; -#X obj 191 444 pdp_xv; #X obj 366 300 openpanel; #X obj 438 301 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 -1; @@ -45,7 +44,8 @@ #X text 393 347 Activate/suppress colors; #X text 462 300 Load a characters map; #X obj 346 203 pdp_v4l; -#X obj 95 307 pdp_scale 800 600; +#X obj 95 307 pdp_scale 600 480; +#X obj 191 444 pdp_xv; #X connect 0 0 9 0; #X connect 1 0 14 0; #X connect 2 0 1 0; @@ -56,23 +56,23 @@ #X connect 7 0 9 0; #X connect 8 0 6 0; #X connect 9 0 14 0; -#X connect 10 0 37 0; +#X connect 10 0 36 0; #X connect 11 0 10 0; #X connect 12 0 10 0; -#X connect 13 0 37 0; -#X connect 14 0 38 0; +#X connect 13 0 36 0; +#X connect 14 0 37 0; #X connect 15 0 17 0; #X connect 16 0 19 0; #X connect 17 0 16 0; #X connect 19 0 18 0; -#X connect 22 0 32 0; +#X connect 22 0 31 0; #X connect 23 0 22 0; -#X connect 24 0 32 0; +#X connect 24 0 31 0; #X connect 25 0 24 0; -#X connect 26 0 32 1; -#X connect 28 0 30 0; -#X connect 29 0 28 0; -#X connect 30 0 32 0; -#X connect 32 0 27 0; -#X connect 37 0 38 0; -#X connect 38 0 32 0; +#X connect 26 0 31 1; +#X connect 27 0 29 0; +#X connect 28 0 27 0; +#X connect 29 0 31 0; +#X connect 31 0 38 0; +#X connect 36 0 37 0; +#X connect 37 0 31 0; diff --git a/doc/help-pdp_compose.pd b/doc/help-pdp_compose.pd index 4c4e8f7..2404bff 100644 --- a/doc/help-pdp_compose.pd +++ b/doc/help-pdp_compose.pd @@ -3,7 +3,7 @@ #X obj 100 167 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 -1; #X msg 54 201 loop \$1; -#X obj 55 179 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 0 1 +#X obj 55 179 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 1 1 ; #X msg 39 146 open \$1; #X obj 38 122 openpanel; @@ -12,20 +12,20 @@ #X msg 123 144 stop; #X obj 121 168 metro 70; #X obj 116 200 pdp_yqt; -#X floatatom 244 273 5 0 0; -#X floatatom 253 294 5 0 0; -#X floatatom 270 315 5 0 0; -#X floatatom 288 339 5 0 0; +#X floatatom 244 273 5 0 0 0 - - -; +#X floatatom 253 294 5 0 0 0 - - -; +#X floatatom 270 315 5 0 0 0 - - -; +#X floatatom 288 339 5 0 0 0 - - -; #X text 269 614 written by Yves Degoyon ( ydegoyon@free.fr ); #X text 290 273 R component; #X text 298 293 G component; #X text 315 314 B component; -#X floatatom 299 360 5 0 0; +#X floatatom 299 360 5 0 0 0 - - -; #X text 336 338 X coordinate of cursor ( pick ); #X text 347 359 Y coordinate of cursor ( pick ); #X msg 14 443 pick; #X text 11 422 Pick up the color; -#X floatatom 309 380 5 0 0; +#X floatatom 309 380 5 0 0 0 - - -; #X text 356 380 Tolerance ( default = 50 ); #X text 269 583 pdp_compose : video compositor; #X text 269 599 change all pixels of a given color by a second video @@ -48,12 +48,12 @@ source; 1; #X obj 589 507 pdp_control; #X msg 589 480 thread \$1; -#X floatatom 589 568 5 0 0; +#X floatatom 589 568 5 0 0 0 - - -; #X obj 589 539 route pdp_drop; #X obj 97 305 pdp_form ---------; #X msg 116 246 ellipse 69 124 59 78; -#X floatatom 130 274 5 0 0; -#X floatatom 176 274 5 0 0; +#X floatatom 130 274 5 0 0 0 - - -; +#X floatatom 176 274 5 0 0 0 - - -; #X msg 317 410 luminosity \$1; #X obj 419 411 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 1; @@ -62,7 +62,6 @@ source; #X obj 362 524 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 -1; #X msg 322 523 stop; -#X text 269 628 idea suggested by liz; #X obj 165 466 pdp_compose ----; #X obj 394 132 pdp_v4l; #X obj 403 101 metro 70; @@ -71,7 +70,7 @@ source; #X msg 405 68 stop; #X msg 490 99 open /dev/video; #X text 471 67 Live; -#X floatatom 514 66 5 0 0; +#X floatatom 514 66 5 0 0 0 - - -; #X obj 401 437 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 1; #X msg 325 436 cursor \$1; @@ -82,7 +81,8 @@ source; #X msg 155 561 cursor \$1; #X obj 233 562 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X connect 0 0 64 0; +#X obj 16 517 route press; +#X connect 0 0 69 0; #X connect 1 0 8 0; #X connect 2 0 9 0; #X connect 3 0 2 0; @@ -92,13 +92,13 @@ source; #X connect 7 0 8 0; #X connect 8 0 9 0; #X connect 9 0 43 0; -#X connect 10 0 54 2; -#X connect 11 0 54 3; -#X connect 12 0 54 4; -#X connect 13 0 54 5; -#X connect 18 0 54 6; -#X connect 21 0 54 0; -#X connect 23 0 54 7; +#X connect 10 0 53 2; +#X connect 11 0 53 3; +#X connect 12 0 53 4; +#X connect 13 0 53 5; +#X connect 18 0 53 6; +#X connect 21 0 53 0; +#X connect 23 0 53 7; #X connect 27 0 34 0; #X connect 28 0 35 0; #X connect 29 0 28 0; @@ -107,31 +107,32 @@ source; #X connect 32 0 31 0; #X connect 33 0 34 0; #X connect 34 0 35 0; -#X connect 35 0 54 1; +#X connect 35 0 53 1; #X connect 38 0 40 0; #X connect 39 0 42 0; #X connect 40 0 39 0; #X connect 42 0 41 0; -#X connect 43 0 54 0; +#X connect 43 0 53 0; #X connect 44 0 43 0; #X connect 45 0 43 2; #X connect 46 0 43 3; -#X connect 47 0 54 0; +#X connect 47 0 53 0; #X connect 48 0 47 0; -#X connect 49 0 54 1; +#X connect 49 0 53 1; #X connect 50 0 49 0; #X connect 51 0 50 0; #X connect 52 0 50 0; -#X connect 54 0 0 0; -#X connect 55 0 43 0; +#X connect 53 0 0 0; +#X connect 54 0 43 0; +#X connect 55 0 54 0; #X connect 56 0 55 0; -#X connect 57 0 56 0; -#X connect 58 0 56 0; -#X connect 59 0 55 0; -#X connect 61 0 56 1; -#X connect 62 0 63 0; -#X connect 63 0 54 0; -#X connect 64 0 54 0; -#X connect 64 0 21 0; -#X connect 68 0 0 0; -#X connect 69 0 68 0; +#X connect 57 0 55 0; +#X connect 58 0 54 0; +#X connect 60 0 55 1; +#X connect 61 0 62 0; +#X connect 62 0 53 0; +#X connect 63 0 53 0; +#X connect 63 0 21 0; +#X connect 67 0 0 0; +#X connect 68 0 67 0; +#X connect 69 0 63 0; diff --git a/doc/help-pdp_ctrack.pd b/doc/help-pdp_ctrack.pd index 85687c4..7850e1d 100644 --- a/doc/help-pdp_ctrack.pd +++ b/doc/help-pdp_ctrack.pd @@ -1,9 +1,9 @@ #N canvas 42 26 781 666 10; -#X obj 35 493 pdp_xv; +#X obj 19 504 pdp_xv; #X obj 268 64 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 -1; #X msg 123 136 loop \$1; -#X obj 124 114 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 0 +#X obj 124 114 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 1 1; #X msg 370 44 open \$1; #X obj 369 20 openpanel; @@ -67,13 +67,13 @@ #X obj 594 281 route pdp_drop; #X msg 118 379 setcur \$1 \$2; #X text 6 378 Set the cursor; -#X msg 12 527 cursor \$1; -#X obj 85 529 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 1 +#X msg 7 425 cursor \$1; +#X obj 80 427 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 1 1 ; #X floatatom 123 591 5 0 0 0 - - -; #X floatatom 173 592 5 0 0 0 - - -; #X floatatom 220 591 5 0 0 0 - - -; -#X text 140 631 Color components; +#X text 139 624 Color components; #X text 135 609 R; #X text 186 609 G; #X text 230 609 B; diff --git a/doc/help-pdp_ffmpeg~.pd b/doc/help-pdp_ffmpeg~.pd index 5b9f10a..bcb5394 100644 --- a/doc/help-pdp_ffmpeg~.pd +++ b/doc/help-pdp_ffmpeg~.pd @@ -62,8 +62,8 @@ server; #X obj 501 251 spigot~; #X floatatom 128 194 5 0 0 0 - - -; #X obj 122 273 pdp_affine; -#X msg 319 358 feed http://www.xicnet.com:8000/feed1.ffm; #X msg 318 415 feed http://localhost:8090/feed1.ffm; +#X msg 320 357 feed http://www.xicnet.com:8000/sin1.ffm; #X connect 0 0 9 0; #X connect 1 0 46 0; #X connect 2 0 1 0; diff --git a/doc/help-pdp_form.pd b/doc/help-pdp_form.pd index 8fd8871..8be2e0c 100644 --- a/doc/help-pdp_form.pd +++ b/doc/help-pdp_form.pd @@ -21,12 +21,12 @@ #X msg 357 139 stop; #X msg 442 170 open /dev/video; #X obj 252 167 pdp_yqt; -#X obj 606 530 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 628 513 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 606 582 pdp_control; -#X msg 606 555 thread \$1; -#X floatatom 606 643 5 0 0 0 - - -; -#X obj 606 614 route pdp_drop; +#X obj 628 565 pdp_control; +#X msg 628 538 thread \$1; +#X floatatom 628 626 5 0 0 0 - - -; +#X obj 628 597 route pdp_drop; #X text 222 631 written by Yves Degoyon (ydegoyon@free.fr); #X obj 189 362 hdl 15 1 0 10 empty empty empty 0 -6 0 8 -262144 -1 -1 0; @@ -59,6 +59,9 @@ #X msg 179 333 ellipse 89 120 56 78 0 255 0; #X text 222 605 pdp_form : geometric forms addition in PDP; #X obj 144 562 pdp_form -----------------; +#X obj 346 540 hsl 128 15 0 1 0 0 empty empty empty -2 -6 0 8 -262144 +-1 -1 0 1; +#X text 487 540 alpha ( global ); #X connect 1 0 10 0; #X connect 2 0 16 0; #X connect 3 0 2 0; @@ -94,3 +97,4 @@ #X connect 48 0 51 0; #X connect 49 0 51 0; #X connect 51 0 0 0; +#X connect 52 0 51 9; diff --git a/doc/help-pdp_live~.pd b/doc/help-pdp_live~.pd index a12f862..a490a18 100644 --- a/doc/help-pdp_live~.pd +++ b/doc/help-pdp_live~.pd @@ -2,14 +2,16 @@ #X obj 128 113 rs_pdp_live~; #X obj 156 158 dac~; #X text 51 321 written by Yves Degoyon (ydegoyon@free.fr); -#X text 51 308 ( at least from ffserver ); -#X text 51 295 pdp_live~ : decodes a live video stream; #X text 236 112 <-- everything is in this box; #X text 265 127 where the block size is redefined; #X text 265 142 this is necessary for an; #X text 266 154 ( acceptable? ) audio decoding; #X obj 395 221 loadbang; #X msg 395 251 \; pd dsp 1; +#X text 51 308 and the video files supported by your ffmpeg (avi \, +mpg \, ..); +#X text 51 295 pdp_live~ : decodes a live video stream from ffmpeg +; #X connect 0 0 1 0; #X connect 0 1 1 1; -#X connect 9 0 10 0; +#X connect 7 0 8 0; diff --git a/doc/help-pdp_ocanvas.pd b/doc/help-pdp_ocanvas.pd index 2069ead..c0191ae 100644 --- a/doc/help-pdp_ocanvas.pd +++ b/doc/help-pdp_ocanvas.pd @@ -2,7 +2,7 @@ #X obj 227 100 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 -1; #X msg 123 139 loop \$1; -#X obj 124 117 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 1 +#X obj 124 117 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 0 1; #X msg 119 80 open \$1; #X obj 118 56 openpanel; @@ -68,14 +68,14 @@ overlay; #X floatatom 697 165 5 0 0 0 - - -; #X text 36 605 note : the maximum number of inputs is 10; #X text 36 618 ( easily hackable in the code ); -#X text 544 397 Change offsets of first video source; -#X obj 548 351 pack f f; -#X floatatom 549 312 5 0 0 0 - - -; -#X floatatom 599 312 5 0 0 0 - - -; -#X obj 589 331 t b f; -#X text 564 294 X; -#X text 609 293 Y; -#X msg 548 375 offset 1 \$1 \$2; +#X text 530 349 Change offsets of first video source; +#X obj 534 303 pack f f; +#X floatatom 639 304 5 0 0 0 - - -; +#X floatatom 699 304 5 0 0 0 - - -; +#X obj 597 302 t b f; +#X text 679 302 X; +#X text 740 304 Y; +#X msg 534 327 offset 1 \$1 \$2; #X obj 81 315 loadbang; #X msg 173 540 select \$1 \$2; #X msg 279 539 drag \$1 \$2; @@ -86,11 +86,11 @@ overlay; #X obj 307 255 pdp_scale 320 240; #X obj 496 254 pdp_scale 320 240; #X obj 234 497 route press drag release; -#X msg 546 428 average \$1; -#X obj 629 429 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +#X msg 535 438 average \$1; +#X obj 615 439 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X text 544 451 Average sources at intersections; -#X text 544 463 ( default = 0 ); +#X text 533 461 Average sources at intersections; +#X text 533 473 ( default = 0 ); #X msg 104 476 cursor 0; #X obj 224 425 pdp_ocanvas 640 480 3; #X obj 234 469 pdp_xv; @@ -98,6 +98,15 @@ overlay; #X obj 228 449 pdp_scale 320 240; #X msg 105 446 cursor 1; #X obj 358 315 pdp_i 5000; +#X obj 535 369 pack f f; +#X floatatom 640 370 5 0 0 0 - - -; +#X floatatom 737 370 5 0 0 0 - - -; +#X obj 598 368 t b f; +#X msg 535 393 alpha \$1 \$2; +#X text 680 368 S; +#X text 531 415 Change alpha values for each source; +#X text 697 391 Alpha [0.0-1.0]; +#X obj 696 368 / 100; #X connect 0 0 7 0; #X connect 1 0 8 0; #X connect 2 0 1 0; @@ -172,3 +181,10 @@ overlay; #X connect 79 0 77 0; #X connect 80 0 77 0; #X connect 81 0 76 3; +#X connect 82 0 86 0; +#X connect 83 0 82 0; +#X connect 84 0 90 0; +#X connect 85 0 82 0; +#X connect 85 1 82 1; +#X connect 86 0 76 0; +#X connect 90 0 85 0; diff --git a/doc/help-pdp_pen.pd b/doc/help-pdp_pen.pd index b82766f..5b8436b 100644 --- a/doc/help-pdp_pen.pd +++ b/doc/help-pdp_pen.pd @@ -2,7 +2,7 @@ #X obj 268 64 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 -1; #X msg 123 136 loop \$1; -#X obj 124 114 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 0 +#X obj 124 114 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 1 1; #X msg 370 44 open \$1; #X obj 369 20 openpanel; @@ -30,42 +30,45 @@ #X text 85 498 pdp_pen : free hand drawing object; #X text 85 514 written by Yves Degoyon ( ydegoyon@free.fr ); #X text 85 528 on request from patrick ( 11h11.com ); -#X obj 238 387 pdp_xv; #X msg 282 463 draw \$1 \$2; -#X msg 383 241 clear; -#X text 431 242 Clear all drawings; -#X msg 382 270 width \$1; -#X floatatom 455 271 5 0 0 0 - - -; -#X text 503 271 Width of the pen ( default = 3 ); -#X msg 381 302 rgb \$1 \$2 \$3; -#X obj 479 305 pack f f f; -#X floatatom 513 330 5 0 0 0 - - -; -#X text 524 343 R; -#X floatatom 562 331 5 0 0 0 - - -; -#X floatatom 610 331 5 0 0 0 - - -; -#X text 622 343 B; -#X obj 610 303 t b f; -#X text 572 343 G; -#X obj 563 304 t b f; -#X text 381 328 Color of the pen; -#X msg 381 358 mode \$1; -#X obj 447 360 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +#X msg 403 238 clear; +#X text 451 239 Clear all drawings; +#X msg 402 267 width \$1; +#X floatatom 470 267 5 0 0 0 - - -; +#X text 523 268 Width of the pen ( default = 3 ); +#X msg 401 299 rgb \$1 \$2 \$3; +#X obj 499 302 pack f f f; +#X floatatom 533 327 5 0 0 0 - - -; +#X text 544 340 R; +#X floatatom 582 328 5 0 0 0 - - -; +#X floatatom 630 328 5 0 0 0 - - -; +#X text 642 340 B; +#X obj 630 300 t b f; +#X text 592 340 G; +#X obj 583 301 t b f; +#X text 401 325 Color of the pen; +#X msg 401 355 mode \$1; +#X obj 467 357 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X text 473 361 Mode ( 0=drawing \, 1=erase ); -#X text 473 374 ( default=0 ); -#X obj 466 396 unpack f f; -#X obj 469 418 f; -#X obj 515 418 f; -#X msg 381 395 fill \$1 \$2; -#X obj 469 441 pack f f; -#X obj 551 397 t b b; -#X msg 600 397 bang; -#X text 640 398 Fill a region; +#X text 493 358 Mode ( 0=drawing \, 1=erase ); +#X text 493 371 ( default=0 ); +#X obj 486 393 unpack f f; +#X obj 489 415 f; +#X obj 535 415 f; +#X msg 401 392 fill \$1 \$2; +#X obj 489 438 pack f f; +#X obj 571 394 t b b; +#X msg 620 394 bang; +#X text 660 395 Fill a region; #X obj 238 419 route press drag release; #X floatatom 280 214 5 0 0 0 - - -; #X floatatom 333 213 5 0 0 0 - - -; #X text 273 197 X Offset; #X text 329 197 Y Offset; +#X obj 406 213 hsl 128 15 0 1 0 0 empty empty empty -2 -6 0 8 -262144 +-1 -1 8800 1; +#X text 543 213 alpha; +#X obj 239 387 pdp_xv; #X connect 0 0 9 0; #X connect 1 0 10 0; #X connect 2 0 1 0; @@ -86,33 +89,34 @@ #X connect 17 0 20 0; #X connect 18 0 17 0; #X connect 20 0 19 0; -#X connect 21 0 25 0; -#X connect 25 0 55 0; +#X connect 21 0 61 0; +#X connect 25 0 21 0; #X connect 26 0 21 0; -#X connect 27 0 21 0; -#X connect 29 0 21 0; -#X connect 30 0 29 0; -#X connect 32 0 21 0; +#X connect 28 0 21 0; +#X connect 29 0 28 0; +#X connect 31 0 21 0; +#X connect 32 0 31 0; #X connect 33 0 32 0; -#X connect 34 0 33 0; -#X connect 36 0 41 0; -#X connect 37 0 39 0; -#X connect 39 0 33 0; -#X connect 39 1 33 2; -#X connect 41 0 33 0; -#X connect 41 1 33 1; -#X connect 43 0 21 0; -#X connect 44 0 43 0; -#X connect 47 0 48 1; -#X connect 47 1 49 1; -#X connect 48 0 51 0; -#X connect 49 0 51 1; -#X connect 50 0 21 0; -#X connect 51 0 50 0; -#X connect 52 0 48 0; -#X connect 52 1 49 0; -#X connect 53 0 52 0; -#X connect 55 0 47 0; -#X connect 55 1 26 0; -#X connect 56 0 21 1; -#X connect 57 0 21 2; +#X connect 35 0 40 0; +#X connect 36 0 38 0; +#X connect 38 0 32 0; +#X connect 38 1 32 2; +#X connect 40 0 32 0; +#X connect 40 1 32 1; +#X connect 42 0 21 0; +#X connect 43 0 42 0; +#X connect 46 0 47 1; +#X connect 46 1 48 1; +#X connect 47 0 50 0; +#X connect 48 0 50 1; +#X connect 49 0 21 0; +#X connect 50 0 49 0; +#X connect 51 0 47 0; +#X connect 51 1 48 0; +#X connect 52 0 51 0; +#X connect 54 0 46 0; +#X connect 54 1 25 0; +#X connect 55 0 21 1; +#X connect 56 0 21 2; +#X connect 59 0 21 3; +#X connect 61 0 54 0; diff --git a/doc/help-pdp_streaming.pd b/doc/help-pdp_streaming.pd index f8a26ad..0cc34e5 100644 --- a/doc/help-pdp_streaming.pd +++ b/doc/help-pdp_streaming.pd @@ -3,7 +3,7 @@ #X obj 263 66 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 -1; #X msg 165 92 loop \$1; -#X obj 166 70 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 0 1 +#X obj 166 70 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 1 1 ; #X msg 150 45 open \$1; #X obj 149 21 openpanel; @@ -13,7 +13,7 @@ #X msg 227 66 stop; #X obj 233 92 metro 70; #X text 386 588 written by Yves Degoyon ( ydegoyon@free.fr ); -#X obj 169 156 pdp_yqt; +#X obj 155 165 pdp_yqt; #X obj 160 315 pdp_o; #X msg 267 154 connect localhost 4578; #X msg 267 179 disconnect; @@ -24,8 +24,8 @@ #X floatatom 180 512 5 0 0 0 - - -; #X text 229 512 Connection state; #X text 249 492 Number of frames received; -#X symbolatom 220 470 10 0 0 0 - - -; -#X text 301 472 Address of the emitter; +#X symbolatom 220 470 15 0 0 0 - - -; +#X text 332 470 Address of the emitter; #X msg 267 253 refresh; #X msg 267 279 framerate \$1; #X floatatom 366 280 5 0 0 0 - - -; @@ -50,6 +50,7 @@ #X text 413 255 by changing these two parameters :; #X floatatom 207 341 5 0 0 0 - - -; #X text 259 340 Bandwidth (in kb); +#X msg 268 133 connect 193.171.120.173 4578; #X connect 1 0 9 0; #X connect 2 0 11 0; #X connect 3 0 2 0; @@ -81,3 +82,4 @@ #X connect 38 0 37 0; #X connect 40 0 41 0; #X connect 41 0 12 0; +#X connect 47 0 12 0; diff --git a/doc/help-pdp_text.pd b/doc/help-pdp_text.pd index dd03714..735afc0 100644 --- a/doc/help-pdp_text.pd +++ b/doc/help-pdp_text.pd @@ -1,5 +1,5 @@ #N canvas 84 12 763 664 10; -#X obj 92 608 pdp_xv; +#X obj 152 627 pdp_xv; #X obj 268 64 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 -1; #X msg 123 136 loop \$1; @@ -21,12 +21,12 @@ #X msg 357 139 stop; #X msg 442 170 open /dev/video; #X obj 252 167 pdp_yqt; -#X obj 606 530 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 648 451 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 606 582 pdp_control; -#X msg 606 555 thread \$1; -#X floatatom 606 643 5 0 0 0 - - -; -#X obj 606 614 route pdp_drop; +#X obj 648 503 pdp_control; +#X msg 648 476 thread \$1; +#X floatatom 648 564 5 0 0 0 - - -; +#X obj 648 535 route pdp_drop; #X text 221 617 pdp_text : text rendering in PDP; #X text 222 631 written by Yves Degoyon (ydegoyon@free.fr); #X msg 144 282 text moshi-moshi 34 58; @@ -57,7 +57,7 @@ #X msg 30 387 delete 1; #X msg 30 421 resize 20; #X msg 30 489 font helmetr/14; -#X obj 155 585 pdp_text -----------------; +#X obj 155 598 pdp_text -----------------; #X text 139 254 text <text> x y [ r g b angle ]; #X floatatom 331 554 5 0 0 0 - - -; #X text 379 553 Angle; @@ -68,8 +68,11 @@ #X floatatom 14 562 5 0 0 0 - - -; #X msg 64 560 antialias \$1; #X msg 29 458 font helmetr/5; -#X floatatom 365 577 5 0 0 0 - - -; -#X text 411 577 Scroll; +#X floatatom 354 572 5 0 0 0 - - -; +#X text 400 572 Scroll; +#X obj 380 594 hsl 128 15 0 1 0 0 empty empty empty -2 -6 0 8 -262144 +-1 -1 0 1; +#X text 517 594 Alpha ( global ); #X connect 1 0 10 0; #X connect 2 0 16 0; #X connect 3 0 2 0; @@ -116,3 +119,4 @@ #X connect 60 0 51 0; #X connect 61 0 51 0; #X connect 62 0 51 8; +#X connect 64 0 51 9; diff --git a/doc/help-pdp_yqt.pd b/doc/help-pdp_yqt.pd index b3b6809..70c671b 100644 --- a/doc/help-pdp_yqt.pd +++ b/doc/help-pdp_yqt.pd @@ -3,7 +3,7 @@ #X obj 268 64 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 -1; #X msg 123 136 loop \$1; -#X obj 124 114 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 0 +#X obj 124 114 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 1 1; #X msg 370 44 open \$1; #X obj 369 20 openpanel; diff --git a/doc/rs_pdp_live~.pd b/doc/rs_pdp_live~.pd index 50f6b80..e30e721 100644 --- a/doc/rs_pdp_live~.pd +++ b/doc/rs_pdp_live~.pd @@ -1,73 +1,108 @@ -#N canvas 168 29 842 529 10; -#X text 460 551 written by Yves Degoyon (ydegoyon@free.fr); -#X floatatom 223 475 5 0 0 0 - - -; -#X text 269 474 Streaming status; -#X floatatom 244 453 5 0 0 0 - - -; -#X obj 36 449 pdp_xv; +#N canvas 393 46 872 636 10; +#X text 455 594 written by Yves Degoyon (ydegoyon@free.fr); +#X floatatom 223 540 5 0 0 0 - - -; +#X text 268 540 Streaming status; +#X floatatom 243 519 5 0 0 0 - - -; #X text 611 77 Connect to a live stream; -#X text 325 118 Disconnect from the current stream; -#X msg 247 116 disconnect; -#X text 293 454 Number of video frames decoded; -#X text 457 527 ( at least from ffserver ); -#X text 23 547 NOTE : as for pdp_ffmpeg~ \, transmitting audio; -#X text 22 565 with the video stream produces some unsteady sound; -#X text 23 580 a prefered solution would be to use mp3cast~/mp3amp~ +#X text 325 111 Disconnect from the current stream; +#X msg 247 109 disconnect; +#X text 292 520 Number of video frames decoded; +#X text 452 570 ( at least from ffserver ); +#X text 21 570 NOTE : as for pdp_ffmpeg~ \, transmitting audio; +#X text 20 588 with the video stream produces some unsteady sound; +#X text 21 603 a prefered solution would be to use mp3cast~/mp3amp~ ; -#X msg 246 335 priority \$1; -#X floatatom 335 336 5 0 0 0 - - -; -#X text 385 357 ( optional \, if you know what you're doing ); -#X obj 70 493 outlet~; -#X obj 146 486 outlet~; -#X text 387 342 ([-20 \, 20 ] default : 0 ); -#X text 390 329 Set the priority of decoding thread; -#X msg 247 225 connect \$1; -#X text 460 513 pdp_live~ : decodes a live video stream; -#X text 458 539 and reads most common files ( avi \, mpg \, .... ) +#X msg 253 415 priority \$1; +#X floatatom 342 416 5 0 0 0 - - -; +#X text 388 439 ( optional \, if you know what you're doing ); +#X obj 72 543 outlet~; +#X text 393 411 Set the priority of decoding thread; +#X msg 247 214 connect \$1; +#X text 455 556 pdp_live~ : decodes a live video stream; +#X text 453 582 and reads most common files ( avi \, mpg \, .... ) ; -#X text 325 175 Read video file; -#X obj 247 154 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 +#X text 325 164 Read video file; +#X obj 247 143 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 -1; -#X obj 247 176 openpanel; -#X msg 248 296 audio \$1; -#X obj 317 298 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 247 165 openpanel; +#X msg 253 384 audio \$1; +#X obj 322 386 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X text 348 298 Activate decoding of audio ( default : off ); -#X obj 247 200 makefilename file://%s; -#X msg 9 388 autocreate 1; +#X text 353 386 Activate decoding of audio ( default : off ); +#X obj 247 189 makefilename file://%s; #X msg 244 52 connect http://localhost:8090/test1.mpg; -#X obj 65 61 block~ 1024; -#X obj 322 261 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 1 +#X obj 327 355 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 1 1; -#X msg 248 259 thread \$1; -#X obj 378 259 loadbang; -#X msg 343 259 1; -#X text 449 259 Activate threading ( default : on ); -#X floatatom 260 430 5 0 0 0 - - -; -#X text 306 430 Reception framerate; -#X text 333 411 End of stream reached; -#X floatatom 287 409 5 0 0 0 - - -; +#X msg 253 355 thread \$1; +#X obj 383 355 loadbang; +#X msg 348 355 1; +#X text 451 355 Activate threading ( default : on ); +#X floatatom 259 496 5 0 0 0 - - -; +#X text 305 496 Reception framerate; +#X text 333 476 End of stream reached; +#X floatatom 286 475 5 0 0 0 - - -; +#X obj 115 424 pdp_live~; +#X obj 341 257 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 1 +1; +#X obj 397 255 loadbang; +#X msg 362 255 1; +#X msg 250 256 autoplay \$1; +#X text 465 255 Activate auto play mode ( default : on ); +#X msg 252 291 bang; +#X msg 392 293 bang; +#X floatatom 433 294 5 0 0 0 - - -; +#X text 485 292 In manual mode \, read next frame ( autoplay = off +); +#X obj 328 293 metro 70; +#X msg 254 319 loop \$1; +#X obj 316 320 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 1 +1; +#X obj 372 318 loadbang; +#X msg 337 318 1; +#X text 440 318 Activate loop mode for files ( default : on ); +#X floatatom 75 252 5 0 0 0 - - -; +#X text 6 194 Frame seek; +#X msg 289 292 stop; +#X obj 134 543 outlet~; +#X text 390 424 ([0 \, 20 ] default : 1 ); +#X text 6 222 ffmpeg >= 0.4.9; +#X text 6 207 warning : works only with; +#X obj 35 501 pdp_xv; +#X obj 66 61 block~ 1024; #X msg 246 78 connect http://gollum.artefacte.org:8090/osas.mpg; -#X obj 113 374 pdp_live~; -#X connect 7 0 43 0; -#X connect 13 0 43 0; -#X connect 14 0 13 0; -#X connect 20 0 43 0; -#X connect 24 0 25 0; -#X connect 25 0 29 0; -#X connect 26 0 43 0; -#X connect 27 0 26 0; -#X connect 29 0 20 0; -#X connect 30 0 4 0; -#X connect 31 0 43 0; -#X connect 33 0 34 0; -#X connect 34 0 43 0; -#X connect 35 0 36 0; -#X connect 36 0 33 0; -#X connect 42 0 43 0; -#X connect 43 0 4 0; -#X connect 43 1 16 0; -#X connect 43 2 17 0; -#X connect 43 3 1 0; -#X connect 43 4 3 0; -#X connect 43 5 38 0; -#X connect 43 6 41 0; +#X connect 6 0 37 0; +#X connect 12 0 37 0; +#X connect 13 0 12 0; +#X connect 17 0 37 0; +#X connect 21 0 22 0; +#X connect 22 0 26 0; +#X connect 23 0 37 0; +#X connect 24 0 23 0; +#X connect 26 0 17 0; +#X connect 27 0 37 0; +#X connect 28 0 29 0; +#X connect 29 0 37 0; +#X connect 30 0 31 0; +#X connect 31 0 28 0; +#X connect 37 0 60 0; +#X connect 37 1 15 0; +#X connect 37 2 56 0; +#X connect 37 3 1 0; +#X connect 37 4 3 0; +#X connect 37 5 33 0; +#X connect 37 6 36 0; +#X connect 38 0 41 0; +#X connect 39 0 40 0; +#X connect 40 0 38 0; +#X connect 41 0 37 0; +#X connect 43 0 37 0; +#X connect 44 0 47 0; +#X connect 45 0 47 1; +#X connect 47 0 37 0; +#X connect 48 0 37 0; +#X connect 49 0 48 0; +#X connect 50 0 51 0; +#X connect 51 0 49 0; +#X connect 53 0 37 1; +#X connect 55 0 47 0; +#X connect 62 0 37 0; diff --git a/include/pdp_streaming.h b/include/pdp_streaming.h index 648c0c6..6f3f038 100644 --- a/include/pdp_streaming.h +++ b/include/pdp_streaming.h @@ -30,5 +30,5 @@ typedef struct _hpacket int width; int height; struct timeval etime; // valid until 2038 - unsigned int clength; + int clength; } t_hpacket; diff --git a/modules/Makefile b/modules/Makefile index 1bca11a..66847ff 100644 --- a/modules/Makefile +++ b/modules/Makefile @@ -15,7 +15,10 @@ OBJECTS = pdp_intrusion.o pdp_yqt.o pdp_simura.o pdp_underwatch.o \ pdp_capture.o pdp_smuck.o pdp_lumafilt.o \ pdp_transition.o pdp_imgloader.o pdp_imgsaver.o pdp_cache.o \ pdp_canvas.o pdp_pen.o pdp_shape.o pdp_fqt.o pdp_fcqt.o \ - pdp_ocanvas.o pdp_spotlight.o pdp_colorgrid.o pdp_live~.o pdp_ffmpeg~.o - # pdp_xcanvas.o pdp_aa.o + pdp_ocanvas.o pdp_spotlight.o pdp_colorgrid.o \ + pdp_binary.o pdp_erode.o pdp_dilate.o pdp_hitandmiss.o \ + pdp_disintegration.o pdp_distance.o pdp_theorin~.o \ + pdp_theorout~.o pdp_cropper.o pdp_background.o \ + pdp_live~.o pdp_ffmpeg~.o # pdp_xcanvas.o pdp_aa.o all_modules: $(OBJECTS) diff --git a/modules/Makefile.in b/modules/Makefile.in index 7d9daad..56fe02b 100644 --- a/modules/Makefile.in +++ b/modules/Makefile.in @@ -15,7 +15,10 @@ OBJECTS = pdp_intrusion.o pdp_yqt.o pdp_simura.o pdp_underwatch.o \ pdp_capture.o pdp_smuck.o pdp_lumafilt.o \ pdp_transition.o pdp_imgloader.o pdp_imgsaver.o pdp_cache.o \ pdp_canvas.o pdp_pen.o pdp_shape.o pdp_fqt.o pdp_fcqt.o \ - pdp_ocanvas.o pdp_spotlight.o pdp_colorgrid.o @PDP_STREAMING_OBJECTS@ - # pdp_xcanvas.o pdp_aa.o + pdp_ocanvas.o pdp_spotlight.o pdp_colorgrid.o \ + pdp_binary.o pdp_erode.o pdp_dilate.o pdp_hitandmiss.o \ + pdp_disintegration.o pdp_distance.o pdp_theorin~.o \ + pdp_theorout~.o pdp_cropper.o pdp_background.o \ + @PDP_STREAMING_OBJECTS@ # pdp_xcanvas.o pdp_aa.o all_modules: $(OBJECTS) diff --git a/modules/pdp_ascii.c b/modules/pdp_ascii.c index a43956c..e81d3f2 100644 --- a/modules/pdp_ascii.c +++ b/modules/pdp_ascii.c @@ -27,6 +27,7 @@ #include "yuv.h" #include "default.map" #include <math.h> +#include <stdio.h> #define LINE_MAX_LENGTH 1024 diff --git a/modules/pdp_compose.c b/modules/pdp_compose.c index aad03a9..998c3a3 100644 --- a/modules/pdp_compose.c +++ b/modules/pdp_compose.c @@ -61,7 +61,9 @@ typedef struct pdp_compose_struct t_float x_f; t_int x_packet0; + t_int x_packet1; t_int x_dropped; + t_int x_queue_id; t_int x_vwidth; t_int x_vheight; @@ -228,6 +230,8 @@ static void pdp_compose_process_yv12(t_pdp_compose *x) { t_pdp *header = pdp_packet_header(x->x_packet0); short int *data = (short int *)pdp_packet_data(x->x_packet0); + t_pdp *newheader = pdp_packet_header(x->x_packet1); + short int *newdata = (short int *)pdp_packet_data(x->x_packet1); t_int i, cf; t_int px=0, py=0, ppx=0, ppy=0, found=0, xcell=0, ycell=0; t_int celldiff=0, cellwidth=0, cellheight=0; @@ -285,9 +289,9 @@ static void pdp_compose_process_yv12(t_pdp_compose *x) pfY = x->x_frame; pfV = x->x_frame+x->x_vsize; pfU = x->x_frame+x->x_vsize+(x->x_vsize>>2); - pdY = data; - pdV = data+x->x_vsize; - pdU = data+x->x_vsize+(x->x_vsize>>2); + pdY = newdata; + pdV = newdata+x->x_vsize; + pdU = newdata+x->x_vsize+(x->x_vsize>>2); prY = x->x_right_frame; prV = x->x_right_frame+x->x_vsize; prU = x->x_right_frame+x->x_vsize+(x->x_vsize>>2); @@ -326,11 +330,18 @@ static void pdp_compose_process_yv12(t_pdp_compose *x) } } - pdp_packet_pass_if_valid(x->x_pdp_output, &x->x_packet0); - return; } +static void pdp_compose_sendpacket(t_pdp_compose *x) +{ + pdp_packet_mark_unused(x->x_packet0); + x->x_packet0=-1; + + /* unregister and propagate if valid dest packet */ + pdp_packet_pass_if_valid(x->x_pdp_output, &x->x_packet1); +} + static void pdp_compose_process(t_pdp_compose *x) { int encoding; @@ -344,7 +355,8 @@ static void pdp_compose_process(t_pdp_compose *x) switch(pdp_packet_header(x->x_packet0)->info.image.encoding){ case PDP_IMAGE_YV12: - pdp_compose_process_yv12(x); + x->x_packet1 = pdp_packet_clone_rw(x->x_packet0); + pdp_queue_add(x, pdp_compose_process_yv12, pdp_compose_sendpacket, &x->x_queue_id); break; case PDP_IMAGE_GREY: @@ -365,20 +377,24 @@ static void pdp_compose_input_1(t_pdp_compose *x, t_symbol *s, t_floatarg f) { short int *rightdata = (short int *)pdp_packet_data((int)f); - if (s== gensym("register_rw")) memcpy(x->x_right_frame, rightdata, (x->x_vsize + (x->x_vsize>>1))<<1 ); + if ( s== gensym("register_rw") ) + { + memcpy(x->x_right_frame, rightdata, (x->x_vsize + (x->x_vsize>>1))<<1 ); + } + + pdp_packet_mark_unused( (int)f ); } static void pdp_compose_input_0(t_pdp_compose *x, t_symbol *s, t_floatarg f) { - /* if this is a register_ro message or register_rw message, register with packet factory */ - - if (s== gensym("register_rw")) + if ( s== gensym("register_rw") ) + { x->x_dropped = pdp_packet_convert_ro_or_drop(&x->x_packet0, (int)f, pdp_gensym("image/YCrCb/*") ); + } - if ((s == gensym("process")) && (-1 != x->x_packet0) && (!x->x_dropped)){ - + if ((s == gensym("process")) && (-1 != x->x_packet0) && (!x->x_dropped)) + { pdp_compose_process(x); - } } @@ -386,7 +402,8 @@ static void pdp_compose_free(t_pdp_compose *x) { int i; - pdp_packet_mark_unused(x->x_packet0); + pdp_queue_finish(x->x_queue_id); + pdp_packet_mark_unused(x->x_packet1); pdp_compose_free_ressources( x ); } @@ -416,6 +433,8 @@ void *pdp_compose_new(void) x->x_colorV = (yuv_RGBtoV( (x->x_colorR << 16) + (x->x_colorG << 8) + x->x_colorB )-128)<<8; x->x_packet0 = -1; + x->x_packet1 = -1; + x->x_queue_id = -1; x->x_cursX = -1; x->x_cursY = -1; diff --git a/modules/pdp_ctrack.c b/modules/pdp_ctrack.c index ed35c9b..fa56ea6 100644 --- a/modules/pdp_ctrack.c +++ b/modules/pdp_ctrack.c @@ -86,8 +86,8 @@ typedef struct pdp_ctrack_struct t_outlet *x_x2; // output x2 coordinate of block which has been detected t_outlet *x_y2; // output y2 coordinate of block which has been detected t_outlet *x_R; // output R component of selected color - t_outlet *x_G; // output R component of selected color - t_outlet *x_B; // output R component of selected color + t_outlet *x_G; // output G component of selected color + t_outlet *x_B; // output B component of selected color t_canvas *x_canvas; diff --git a/modules/pdp_ffmpeg~.c b/modules/pdp_ffmpeg~.c index 58cdd61..3e229af 100644 --- a/modules/pdp_ffmpeg~.c +++ b/modules/pdp_ffmpeg~.c @@ -441,9 +441,18 @@ static void pdp_ffmpeg_process_yv12(t_pdp_ffmpeg *x) oheight = x->x_avcontext->streams[i]->codec.height; if (x->x_img_resample_ctx) img_resample_close(x->x_img_resample_ctx); + +#if LIBAVCODEC_BUILD > 4715 + x->x_img_resample_ctx = img_resample_full_init( + owidth, oheight, + x->x_vwidth, x->x_vheight, + 0, 0, 0, 0, + 0, 0, 0, 0); +#else x->x_img_resample_ctx = img_resample_full_init( owidth, oheight, x->x_vwidth, x->x_vheight, 0, 0, 0, 0); +#endif size = avpicture_get_size(x->x_avcontext->streams[i]->codec.pix_fmt, owidth, oheight ); @@ -472,6 +481,9 @@ static void pdp_ffmpeg_process_yv12(t_pdp_ffmpeg *x) // encode and send the picture { AVFrame aframe; +#if LIBAVCODEC_BUILD > 4715 + AVPacket vpkt; +#endif t_int fsize, ret; memset(&aframe, 0, sizeof(AVFrame)); @@ -482,7 +494,21 @@ static void pdp_ffmpeg_process_yv12(t_pdp_ffmpeg *x) fsize = avcodec_encode_video(&x->x_avcontext->streams[i]->codec, x->x_video_buffer, VIDEO_BUFFER_SIZE, &aframe); + +#if LIBAVCODEC_BUILD > 4715 + av_init_packet(&vpkt); + + vpkt.pts = aframe.pts; + if((&x->x_avcontext->streams[i]->codec)->coded_frame->key_frame) + vpkt.flags |= PKT_FLAG_KEY; + vpkt.stream_index= i; + vpkt.data= (uint8_t *)x->x_video_buffer; + vpkt.size= fsize; + + if ( ( ret = av_write_frame( x->x_avcontext, &vpkt) ) < 0 ) +#else if ( ( ret = av_write_frame( x->x_avcontext, i, x->x_video_buffer, fsize) ) < 0 ) +#endif { post ("pdp_ffmpeg~ : error : could not send frame : (ret=%d)", ret ); return; @@ -549,10 +575,26 @@ static void pdp_ffmpeg_process_yv12(t_pdp_ffmpeg *x) while (fifo_read(&x->x_audio_fifo[saudioindex], (uint8_t*)pencbuf, framebytes, &x->x_audio_fifo[saudioindex].rptr) == 0) { +#if LIBAVCODEC_BUILD > 4715 + AVPacket apkt; +#endif encsize = avcodec_encode_audio(&x->x_avcontext->streams[i]->codec, (uint8_t*)&x->x_audio_out, sizeof(x->x_audio_out), (short *)pencbuf); +#if LIBAVCODEC_BUILD > 4715 + av_init_packet(&apkt); + + apkt.pts = etime.tv_sec*1000000 + etime.tv_usec; + if((&x->x_avcontext->streams[i]->codec)->coded_frame->key_frame) + apkt.flags |= PKT_FLAG_KEY; + apkt.stream_index= i; + apkt.data= (uint8_t *)x->x_audio_out; + apkt.size= encsize; + + av_write_frame(x->x_avcontext, &apkt); +#else av_write_frame(x->x_avcontext, i, x->x_audio_out, encsize); +#endif } saudioindex++; } diff --git a/modules/pdp_form.c b/modules/pdp_form.c index ccbd510..b3a59b3 100644 --- a/modules/pdp_form.c +++ b/modules/pdp_form.c @@ -74,6 +74,7 @@ typedef struct pdp_form_struct t_int x_nbforms; t_int x_current; t_int x_capacity; + t_float x_alpha; /* imlib data */ Imlib_Image x_image; @@ -312,6 +313,14 @@ static void pdp_form_delete(t_pdp_form *x, t_floatarg fnum ) } } +static void pdp_form_alpha(t_pdp_form *x, t_floatarg falpha ) +{ + if ( ( falpha >= 0. ) && ( falpha <= 1. ) ) + { + x->x_alpha = falpha; + } +} + static void pdp_form_resize(t_pdp_form *x, t_floatarg fnewsize ) { t_form *forms; @@ -448,11 +457,11 @@ static void pdp_form_process_yv12(t_pdp_form *x) u = yuv_RGBtoU(imdata[py*x->x_vwidth+px]); v = yuv_RGBtoV(imdata[py*x->x_vwidth+px]); - *(pY) = y<<7; + *(pY) = (y<<7)*x->x_alpha + (*pY)*(1-x->x_alpha); if ( (px%2==0) && (py%2==0) ) { - *(pV) = (v-128)<<8; - *(pU) = (u-128)<<8; + *(pV) = ((v-128)<<8)*x->x_alpha + (*pV)*(1-x->x_alpha); + *(pU) = ((u-128)<<8)*x->x_alpha + (*pU)*(1-x->x_alpha); } } pY++; @@ -549,6 +558,7 @@ void *pdp_form_new(void) inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("r")); inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("g")); inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("b")); + inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("alpha")); x->x_outlet0 = outlet_new(&x->x_obj, &s_anything); x->x_packet0 = -1; @@ -567,6 +577,7 @@ void *pdp_form_new(void) x->x_nbforms = 0; x->x_current = -1; + x->x_alpha = 1.; return (void *)x; } @@ -601,6 +612,7 @@ void pdp_form_setup(void) class_addmethod(pdp_form_class, (t_method)pdp_form_clear, gensym("clear"), A_NULL); class_addmethod(pdp_form_class, (t_method)pdp_form_delete, gensym("delete"), A_DEFFLOAT, A_NULL); class_addmethod(pdp_form_class, (t_method)pdp_form_resize, gensym("resize"), A_DEFFLOAT, A_NULL); + class_addmethod(pdp_form_class, (t_method)pdp_form_alpha, gensym("alpha"), A_DEFFLOAT, A_NULL); class_sethelpsymbol( pdp_form_class, gensym("pdp_form.pd") ); } diff --git a/modules/pdp_i.c b/modules/pdp_i.c index e18a077..a89a56c 100644 --- a/modules/pdp_i.c +++ b/modules/pdp_i.c @@ -178,7 +178,7 @@ static void pdp_i_recv(t_pdp_i *x) t_hpacket *pheader; if ( ( ret = recv(x->x_socket, (void*) (x->x_inbuffer + x->x_inwriteposition), - (size_t)((x->x_inbuffersize-x->x_inwriteposition)), + (size_t)((x->x_inbuffersize-x->x_inwriteposition-1)), MSG_NOSIGNAL) ) < 0 ) { post( "pdp_i : receive error" ); @@ -189,7 +189,7 @@ static void pdp_i_recv(t_pdp_i *x) { // post( "pdp_i : received %d bytes at %d on %d ( up to %d)", // ret, x->x_inwriteposition, x->x_socket, - // x->x_inbuffersize-x->x_inwriteposition*sizeof( unsigned long) ); + // x->x_inbuffersize-x->x_inwriteposition ); if ( ret == 0 ) { @@ -197,29 +197,34 @@ static void pdp_i_recv(t_pdp_i *x) outlet_float( x->x_connection_status, 0 ); pdp_i_closesocket( x->x_socket ); sys_rmpollfn(x->x_socket); + post( "pdp_i : lost the connection." ); x->x_socket = -1; } else { // check we don't overflow input buffer - if ( x->x_inwriteposition+ret >= x->x_inbuffersize ) + if ( x->x_inwriteposition+ret >= x->x_inbuffersize/2 ) { post( "pdp_i : too much input...resetting" ); x->x_inwriteposition=0; + memset( (char*) x->x_inbuffer, 0x00, x->x_inbuffersize ); return; } x->x_inwriteposition += ret; - if ( pheader = (t_hpacket*) strstr( (char*) x->x_inbuffer, PDP_PACKET_START ) ) + if ( ( ( pheader = (t_hpacket*) strstr( (char*) x->x_inbuffer, PDP_PACKET_START ) ) != NULL ) || + ( ( pheader = (t_hpacket*) strstr( (char*) x->x_inbuffer, PDP_PACKET_DIFF ) ) != NULL ) ) { // check if a full packet is present - if ( x->x_inwriteposition >= (int)((char*)pheader - (char*)(x->x_inbuffer)) + (int)sizeof(t_hpacket) + (int)pheader->clength ) + if ( x->x_inwriteposition >= + (int)((char*)pheader - (char*)(x->x_inbuffer)) + + (int)sizeof(t_hpacket) + (int)ntohl(pheader->clength) ) { - if ( ( x->x_vwidth != pheader->width ) || - ( x->x_vheight != pheader->height ) ) + if ( ( x->x_vwidth != (t_int)ntohl(pheader->width) ) || + ( x->x_vheight != (t_int)ntohl(pheader->height) ) ) { pdp_i_free_ressources(x); - x->x_vheight = pheader->height; - x->x_vwidth = pheader->width; + x->x_vheight = ntohl(pheader->height); + x->x_vwidth = ntohl(pheader->width); x->x_vsize = x->x_vheight*x->x_vwidth; pdp_i_allocate(x); post( "pdp_i : allocated buffers : vsize=%d : hsize=%d", x->x_vsize, x->x_hsize ); @@ -230,18 +235,18 @@ static void pdp_i_recv(t_pdp_i *x) x->x_data = (short int *)pdp_packet_data(x->x_packet); memcpy( x->x_data, x->x_bdata, x->x_bsize ); - // post( "pdp_i : decompress %d in %d bytes", pheader->clength, x->x_hsize ); + // post( "pdp_i : decompress %d in %d bytes", ntohl(pheader->clength), x->x_hsize ); x->x_bzsize = x->x_hsize; if ( ( ret = BZ2_bzBuffToBuffDecompress( (char*)x->x_hdata, &x->x_bzsize, (char *) pheader+sizeof(t_hpacket), - pheader->clength, + ntohl(pheader->clength), 0, 0 ) ) == BZ_OK ) { - // post( "pdp_i : bz2 decompression (%d)->(%d)", pheader->clength, x->x_bzsize ); + // post( "pdp_i : bz2 decompression (%d)->(%d)", ntohl(pheader->clength), x->x_bzsize ); - switch( pheader->encoding ) + switch( ntohl(pheader->encoding) ) { case REGULAR : memcpy( x->x_ddata, x->x_hdata, x->x_bzsize ); @@ -285,8 +290,8 @@ static void pdp_i_recv(t_pdp_i *x) x->x_header->info.image.width = x->x_vwidth; x->x_header->info.image.height = x->x_vheight; - pdp_packet_pass_if_valid(x->x_pdp_output, &x->x_packet); // post( "pdp_i : propagate packet : %d", x->x_packet ); + pdp_packet_pass_if_valid(x->x_pdp_output, &x->x_packet); outlet_float( x->x_frames, ++x->x_framesreceived ); } else @@ -297,8 +302,20 @@ static void pdp_i_recv(t_pdp_i *x) memcpy( x->x_bdata, x->x_data, x->x_bsize ); // roll buffer - x->x_inwriteposition -= (int)((char*)pheader-(char*)(x->x_inbuffer)) + sizeof(t_hpacket) + pheader->clength; - memcpy( x->x_inbuffer, pheader+sizeof(t_hpacket) + pheader->clength, x->x_inwriteposition ); + x->x_inwriteposition -= (int)((char*)pheader-(char*)(x->x_inbuffer)) + sizeof(t_hpacket) + ntohl(pheader->clength); + if ( x->x_inwriteposition > 0 ) + { + memcpy( x->x_inbuffer, pheader+sizeof(t_hpacket) + ntohl(pheader->clength), x->x_inwriteposition ); + } + else + { + x->x_inwriteposition = 0; + memset( (char*) x->x_inbuffer, 0x00, x->x_inbuffersize ); + } + } + else + { + // post( "pdp_i : not a full frame" ); } } } diff --git a/modules/pdp_live~.c b/modules/pdp_live~.c index cae6a65..c403a15 100644 --- a/modules/pdp_live~.c +++ b/modules/pdp_live~.c @@ -35,6 +35,8 @@ #include <sys/time.h> #include <sys/resource.h> #include <avformat.h> +#include <sys/types.h> +#include <signal.h> #define VIDEO_BUFFER_SIZE (1024*1024) #define MAX_AUDIO_PACKET_SIZE (128 * 1024) @@ -46,8 +48,8 @@ #define DEFAULT_HEIGHT 240 #define DEFAULT_FRAME_RATE 25 #define END_OF_STREAM 20 -#define MIN_PRIORITY -20 -#define DEFAULT_PRIORITY 0 +#define MIN_PRIORITY 0 +#define DEFAULT_PRIORITY 1 #define MAX_PRIORITY 20 /* a trick to cope with ffmpeg versions */ @@ -66,7 +68,7 @@ typedef struct pdp_live_struct t_int x_dropped; t_pdp *x_header; - short int *x_data; + unsigned char *x_data; t_int x_vwidth; t_int x_vheight; t_int x_vsize; @@ -82,10 +84,14 @@ typedef struct pdp_live_struct pthread_t x_connectchild; // thread used for connecting to a stream pthread_t x_decodechild; // stream decoding thread t_int x_usethread; // flag to activate decoding in a thread + t_int x_autoplay; // flag to autoplay the file ( default = true ) + t_int x_nextimage; // flag to play next image in manual mode t_int x_priority; // priority of decoding thread char *x_url; t_int x_streaming; // streaming flag + t_int x_decoding; // decoding flag + t_int x_loop; // looping flag ( default = on ) t_int x_nopackets; // no packet to decode t_int x_endofstream; // end of the stream reached t_int x_nbframes; // number of frames emitted @@ -108,6 +114,7 @@ typedef struct pdp_live_struct AVPicture x_picture_decoded; long long int x_pts; // presentation time stamp long long int x_previouspts; // previous presentation time stamp + long long int x_firstpts; // first presentation time stamp ( time origin ) t_int x_newpicture; /* audio structures */ @@ -137,19 +144,80 @@ static void pdp_live_threadify(t_pdp_live *x, t_floatarg fusethread ) static void pdp_live_audio(t_pdp_live *x, t_floatarg faudio ) { - if ( ( faudio == 0.0 ) || ( faudio == 1 ) ) + if ( ( faudio == 0. ) || ( faudio == 1. ) ) { x->x_audio = (int)faudio; } } +static void pdp_live_autoplay(t_pdp_live *x, t_floatarg fautoplay ) +{ + if ( ( fautoplay == 0. ) || ( fautoplay == 1. ) ) + { + x->x_autoplay = (int)fautoplay; + } +} + +static void pdp_live_loop(t_pdp_live *x, t_floatarg floop ) +{ + if ( ( floop == 0. ) || ( floop == 1. ) ) + { + x->x_loop = (int)floop; + } +} + +static void pdp_live_bang(t_pdp_live *x) +{ + if ( x->x_nextimage == 1 ) + { + // post( "pdp_live~ : banging too fast, previous image is not decoded yet... ignored" ); + return; + } + x->x_nextimage = 1; +} + +static void pdp_live_frame_cold(t_pdp_live *x, t_floatarg frameindex) +{ + int frame = (int)frameindex; + int ret; + uint64_t newpts; + + if (!(x->x_streaming)) return; + +#if FFMPEG_VERSION_INT >= 0x000409 + if ( ( ( x->x_avcontext->iformat->flags & AVFMT_NOFILE ) == 0 ) && ( x->x_videoindex != -1 ) ) + { + if ( x->x_framerate != 0 ) + { + newpts = x->x_firstpts + ( frame * 1000000 ) / x->x_framerate; + } + else + { + post( "pdp_live~ : couldn't seek requested frame ( framerate = %d )", x->x_framerate ); + return; + } + if ( ( ret = av_seek_frame(x->x_avcontext, x->x_videoindex, newpts) ) < 0 ) + { + post( "pdp_live~ : couldn't seek the requested frame (ret=%d)", ret ); + } + } +#else + post( "pdp_live~ : no seek function with ffmpeg < 4.0.9"); +#endif +} + static t_int pdp_live_decode_packet(t_pdp_live *x) { - t_int chunksize=0, length; + t_int chunksize=0, length, err, ret; t_int audiosize, sizeout, imagesize, pictureok; AVFrame frame; uint8_t *pcktptr; - struct timeval etime; + unsigned char *pY, *pU, *pV; + uint8_t *psY, *psU, *psV; + t_int px, py; + long long tplaying; + long long ttheoretical; + struct timeval ctime; struct timespec mwait; if ( !x->x_streaming ) @@ -159,13 +227,35 @@ static t_int pdp_live_decode_packet(t_pdp_live *x) // post( "pdp_live~ : trying to read packet" ); // read new packet on the stream - if (av_read_packet(x->x_avcontext, &x->x_pkt) < 0) + if ( x->x_streaming && av_read_packet(x->x_avcontext, &x->x_pkt) < 0) { x->x_nopackets++; // post( "pdp_live~ : decoding thread : nothing to decode : no packets :%d", x->x_nopackets ); if ( x->x_nopackets > END_OF_STREAM ) { x->x_endofstream = 1; + if ( x->x_loop ) + { + +#if FFMPEG_VERSION_INT >= 0x000409 + + if ( ( x->x_avcontext->iformat->flags & AVFMT_NOFILE ) == 0 ) + { + post( "pdp_live~ : looping file reading..." ); + if ( ( ret = av_seek_frame(x->x_avcontext, x->x_videoindex, 0) ) < 0 ) + { + post( "pdp_live~ : couldn't seek the requested frame (ret=%d)", ret ); + } + else + { + x->x_endofstream = 0; + } + } + +#else + post( "pdp_live~ : no seek function with ffmpeg < 4.0.9"); +#endif + } } return -1; } @@ -182,6 +272,7 @@ static t_int pdp_live_decode_packet(t_pdp_live *x) pcktptr = x->x_pkt.data; while (length > 0) { + if ( !x->x_streaming ) break; switch(x->x_avcontext->streams[x->x_pkt.stream_index]->codec.codec_type) { case CODEC_TYPE_AUDIO: @@ -240,7 +331,7 @@ static t_int pdp_live_decode_packet(t_pdp_live *x) post( "pdp_live~ : audio overflow : packet ignored..."); x->x_audioin_position = 0; } - if ( ( x->x_audioin_position > x->x_blocksize ) && (!x->x_audioon) ) + if ( ( x->x_audioin_position > 4*x->x_blocksize ) && (!x->x_audioon) ) { x->x_audioon = 1; // post( "pdp_live~ : audio on" ); @@ -253,20 +344,9 @@ static t_int pdp_live_decode_packet(t_pdp_live *x) x->x_avcontext->streams[x->x_pkt.stream_index]->codec.height * 3) / 2; // yuv planar x->x_framerate = x->x_avcontext->streams[x->x_pkt.stream_index]->codec.frame_rate / 10000; + if ( x->x_framerate == 0 ) x->x_framerate = DEFAULT_FRAME_RATE; x->x_videoindex = x->x_pkt.stream_index; - // calculate actual frame rate - // if ( gettimeofday(&etime, NULL) == -1) - // { - // post("pdp_live~ : could not read time" ); - // } - // if ( ( etime.tv_sec - x->x_starttime.tv_sec ) > 0 ) - // { - // x->x_framerate = x->x_nbframes / ( etime.tv_sec - x->x_starttime.tv_sec ); - // } - // if ( x->x_framerate == 0 ) x->x_framerate = 1; - // post ("pdp_live~ : frame rate is %d", x->x_framerate ); - chunksize = avcodec_decode_video( &x->x_avcontext->streams[x->x_pkt.stream_index]->codec, &frame, &pictureok, @@ -304,37 +384,74 @@ static t_int pdp_live_decode_packet(t_pdp_live *x) else { x->x_newpicture=1; - x->x_previouspts = x->x_pts; - x->x_pts = frame.pts; - // post( "pdp_live : frame pts : %ld", x->x_pts ); x->x_vwidth = x->x_avcontext->streams[x->x_pkt.stream_index]->codec.width; x->x_vheight = x->x_avcontext->streams[x->x_pkt.stream_index]->codec.height; x->x_vsize = x->x_vwidth*x->x_vheight; - if ( x->x_previouspts != -1 ) + // create a new pdp packet from BITMAP YV12 image format + x->x_packet0 = pdp_packet_new_bitmap_yv12( x->x_vwidth, x->x_vheight ); + x->x_header = pdp_packet_header(x->x_packet0); + x->x_data = (unsigned char *)pdp_packet_data(x->x_packet0); + + pY = x->x_data; + pV = x->x_data+x->x_vsize; + pU = x->x_data+x->x_vsize+(x->x_vsize>>2); + + psY = x->x_picture_decoded.data[0]; + psU = x->x_picture_decoded.data[1]; + psV = x->x_picture_decoded.data[2]; + + for ( py=0; py<x->x_vheight; py++) + { + memcpy( (void*)pY, (void*)psY, x->x_vwidth ); + pY += x->x_vwidth; + psY += x->x_picture_decoded.linesize[0]; + if ( py%2==0 ) + { + memcpy( (void*)pU, (void*)psU, (x->x_vwidth>>1) ); + memcpy( (void*)pV, (void*)psV, (x->x_vwidth>>1) ); + pU += (x->x_vwidth>>1); + pV += (x->x_vwidth>>1); + psU += x->x_picture_decoded.linesize[1]; + psV += x->x_picture_decoded.linesize[2]; + } + } + + if ( x->x_firstpts == -1 ) { - mwait.tv_sec = 0; - mwait.tv_nsec = (x->x_pts - x->x_previouspts)*1000; - - if ( ( x->x_pts == 0 ) ) - { - // post("pdp_live~ : no presentation time stamp, using framerate :%d", - // x->x_framerate ); - mwait.tv_sec = 0; - mwait.tv_nsec = 1000000000/((x->x_framerate+5)); // the +5 is experimental - // it comes from the time used in decoding - } - - nanosleep( &mwait, NULL ); // wait between the two successive frames - // i know, cheap flow control + x->x_firstpts = x->x_pts; } + x->x_previouspts = x->x_pts; + x->x_pts = frame.pts; + // post( "pdp_live : frame pts : %ld", x->x_pts ); + if ( x->x_nbframes > 0 ) + { + if ( gettimeofday(&ctime, NULL) == -1) + { + post("pdp_theorin~ : could not read time" ); + } + + tplaying = ( ctime.tv_sec-x->x_starttime.tv_sec )*1000 + + ( ctime.tv_usec-x->x_starttime.tv_usec )/1000; + ttheoretical = ((x->x_nbframes)*1000 )/x->x_framerate; + // post( "pdp-theorin~ : %d playing since : %lldms ( theory : %lldms )", + // x->x_nbframes, tplaying, ttheoretical ); + + if ( tplaying < ttheoretical ) + { + mwait.tv_sec = 0; + mwait.tv_nsec = (ttheoretical - tplaying)*1000000; + + // wait between the two successive frames + if ( x->x_autoplay ) nanosleep( &mwait, NULL ); + } + } } break; } pcktptr += chunksize; length -= chunksize; - if ( !x->x_streaming ) break; } av_free_packet(&x->x_pkt); @@ -353,18 +470,10 @@ static void *pdp_decode_stream_from_url(void *tdata) twait.tv_sec = 0; twait.tv_nsec = 10000000; // 10 ms - schedprio.sched_priority = 0; - if ( sched_setscheduler(0,SCHED_OTHER,&schedprio) == -1) - { - post("pdp_live~ : couldn't set scheduler for decoding thread.\n"); - } - if ( setpriority( PRIO_PROCESS, 0, x->x_priority ) < 0 ) - { - post("pdp_live~ : couldn't set priority to %d for decoding thread.\n", x->x_priority ); - } - else + schedprio.sched_priority = sched_get_priority_min(SCHED_FIFO) + x->x_priority; + if ( sched_setscheduler(0,SCHED_FIFO,&schedprio) == -1) { - post("pdp_live~ : priority set to %d for thread %d.\n", x->x_priority, x->x_decodechild ); + post("pdp_theorin~ : couldn't set priority for decoding thread."); } if ( ! (x->x_avcontext->iformat->flags & AVFMT_NOHEADER ) ) @@ -376,19 +485,27 @@ static void *pdp_decode_stream_from_url(void *tdata) post( "pdp_live~ : read header." ); } - while ( x->x_streaming ) + while ( x->x_decodechild ) { - while ( x->x_newpicture ) nanosleep( &twait, NULL ); + if ( ( x->x_streaming ) && ( ( x->x_autoplay ) || ( x->x_nextimage == 1 ) ) ) + { + x->x_decoding = 1; + while ( x->x_newpicture ) nanosleep( &twait, NULL ); - // decode incoming packets - if ( pdp_live_decode_packet( x ) < 0 ) + // decode incoming packets + if ( ( x->x_streaming ) && ( pdp_live_decode_packet( x ) < 0 ) ) + { + nanosleep( &twait, NULL ); // nothing to read, just wait + } + x->x_nextimage = -1; + } + else { - nanosleep( &twait, NULL ); // nothing to read, just wait + x->x_decoding = 0; + nanosleep( &twait, NULL ); // nothing to do, just wait } - } - post( "pdp_live~ : decoding thread %d exiting....", x->x_decodechild ); x->x_decodechild = 0; pthread_exit(NULL); } @@ -419,7 +536,6 @@ static void *pdp_live_connect_to_url(void *tdata) if ( err == -5 ) post( "pdp_live~ : not enough memory" ); if ( err == -6 ) post( "pdp_live~ : unknown format ( stream not found? )" ); x->x_connectchild = 0; - x->x_avcontext = av_mallocz(sizeof(AVFormatContext)); pthread_exit(NULL); } /* If not enough info to get the stream parameters, we decode the @@ -507,11 +623,13 @@ static void *pdp_live_connect_to_url(void *tdata) x->x_nopackets = 0; x->x_endofstream = 0; x->x_nbframes = 0; + x->x_pts = -1; + x->x_previouspts = -1; + x->x_firstpts = -1; - x->x_connectchild = 0; - - if ( x->x_usethread ) + if ( x->x_usethread && ( x->x_decodechild == 0 )) { + x->x_decodechild = 1; // trick & treets // launch decoding thread if ( pthread_attr_init( &decode_child_attr ) < 0 ) { @@ -556,15 +674,15 @@ static void pdp_live_disconnect(t_pdp_live *x) { x->x_streaming = 0; x->x_newpicture = 0; - post("pdp_live~ : waiting for the end of decoding thread..." ); - while ( x->x_decodechild && ( count < 100 ) ) + post("pdp_live~ : waiting end of decoding..." ); + while ( x->x_decoding ) nanosleep( &twait, NULL ); + /* close each decoder */ + for(i=0;i<x->x_avcontext->nb_streams;i++) { - count++; - sleep( 1 ); - } - if ( x->x_decodechild ) - { - post("pdp_live~ : zombie thread, i guess" ); + if (avcodec_close(&x->x_avcontext->streams[i]->codec) < 0) + { + post("pdp_live~ : error while closing codec for stream #%d", i); + } } post("pdp_live~ : closing input file..." ); av_close_input_file(x->x_avcontext); @@ -631,9 +749,6 @@ static t_int *pdp_live_perform(t_int *w) t_float *out2 = (t_float *)(w[2]); // right audio inlet t_pdp_live *x = (t_pdp_live *)(w[3]); int n = (int)(w[4]); // number of samples - short int *pY, *pU, *pV; - uint8_t *psY, *psU, *psV; - t_int pixRGB, px, py; short sampleL, sampleR; struct timeval etime; t_int sn; @@ -650,7 +765,6 @@ static t_int *pdp_live_perform(t_int *w) if ( x->x_audioon ) { sn=0; - n=n*DEFAULT_CHANNELS; while (n--) { sampleL=x->x_audio_in[ sn++ ]; @@ -670,7 +784,7 @@ static t_int *pdp_live_perform(t_int *w) memcpy( &x->x_audio_in[0], &x->x_audio_in[sn], 4*MAX_AUDIO_PACKET_SIZE-sn ); x->x_audioin_position-=sn; // post( "pdp_live~ : audio in position : %d", x->x_audioin_position ); - if ( x->x_audioin_position <= sn ) + if ( x->x_audioin_position <= 0 ) { x->x_audioon = 0; // post( "pdp_live~ : audio off" ); @@ -694,7 +808,7 @@ static t_int *pdp_live_perform(t_int *w) if ( etime.tv_sec != x->x_cursec ) { x->x_cursec = etime.tv_sec; - if (x->x_streaming) outlet_float( x->x_outlet_framerate, x->x_framerate ); + if (x->x_streaming) outlet_float( x->x_outlet_framerate, x->x_secondcount ); x->x_secondcount = 0; } if ( x->x_secondcount >= x->x_framerate ) @@ -705,45 +819,13 @@ static t_int *pdp_live_perform(t_int *w) // output image if there's a new one decoded if ( x->x_newpicture ) { - // create a new pdp packet from PIX_FMT_YUV420P image format - x->x_packet0 = pdp_packet_new_image_YCrCb( x->x_vwidth, x->x_vheight ); - x->x_header = pdp_packet_header(x->x_packet0); - x->x_data = (short int *)pdp_packet_data(x->x_packet0); - - pY = x->x_data; - pV = x->x_data+x->x_vsize; - pU = x->x_data+x->x_vsize+(x->x_vsize>>2); - - psY = x->x_picture_decoded.data[0]; - psU = x->x_picture_decoded.data[1]; - psV = x->x_picture_decoded.data[2]; - - for ( py=0; py<x->x_vheight; py++) - { - for ( px=0; px<x->x_vwidth; px++) - { - *(pY) = ( *(psY+px) << 7 ); - *(pV) = ( ((*(psV+(px>>1)))-128) << 8 ); - *(pU) = ( ((*(psU+(px>>1)))-128) << 8 ); - pY++; - if ( (px%2==0) && (py%2==0) ) - { - pV++; pU++; - } - } - psY += x->x_picture_decoded.linesize[0]; - if ( py%2==0 ) psU += x->x_picture_decoded.linesize[1]; - if ( py%2==0 ) psV += x->x_picture_decoded.linesize[2]; - } - pdp_packet_pass_if_valid(x->x_pdp_out, &x->x_packet0); + x->x_newpicture = 0; // update streaming status x->x_nbframes++; x->x_secondcount++; outlet_float( x->x_outlet_nbframes, x->x_nbframes ); - - x->x_newpicture = 0; } outlet_float( x->x_outlet_streaming, x->x_streaming ); outlet_float( x->x_outlet_endofstream, x->x_endofstream ); @@ -760,18 +842,19 @@ static void pdp_live_free(t_pdp_live *x) { int i; + if ( x->x_decodechild ) + { + x->x_decodechild = 0; + x->x_decoding = 0; + sleep( 5 ); // let the decoding thread exiting + } + if ( x->x_streaming ) { pdp_live_disconnect(x); - sleep(3); } post( "pdp_live~ : freeing object" ); pdp_packet_mark_unused(x->x_packet0); - if (x->x_audio_resample_ctx) - { - audio_resample_close(x->x_audio_resample_ctx); - x->x_audio_resample_ctx = NULL; - } av_free_static(); } @@ -783,6 +866,8 @@ void *pdp_live_new(void) t_pdp_live *x = (t_pdp_live *)pd_new(pdp_live_class); + inlet_new(&x->x_obj, &x->x_obj.ob_pd, gensym("float"), gensym("frame_cold")); + x->x_pdp_out = outlet_new(&x->x_obj, &s_anything); x->x_outlet_left = outlet_new(&x->x_obj, &s_signal); @@ -796,6 +881,7 @@ void *pdp_live_new(void) x->x_packet0 = -1; x->x_connectchild = 0; x->x_decodechild = 0; + x->x_decoding = 0; x->x_usethread = 1; x->x_priority = DEFAULT_PRIORITY; x->x_framerate = DEFAULT_FRAME_RATE; @@ -807,15 +893,19 @@ void *pdp_live_new(void) x->x_secondcount = 0; x->x_audio_resample_ctx = NULL; x->x_nbvideostreams = 0; - x->x_videoindex = 0; + x->x_videoindex = -1; x->x_audioin_position = 0; x->x_newpicture = 0; x->x_endofstream = 0; x->x_nopackets = 0; x->x_blocksize = MIN_AUDIO_SIZE; + x->x_autoplay = 1; + x->x_loop = 1; + x->x_nextimage = 0; x->x_pts = -1; x->x_previouspts = -1; + x->x_firstpts = -1; x->x_avcontext = av_mallocz(sizeof(AVFormatContext)); if ( !x->x_avcontext ) @@ -851,7 +941,11 @@ void pdp_live_tilde_setup(void) class_addmethod(pdp_live_class, (t_method)pdp_live_disconnect, gensym("disconnect"), A_NULL); class_addmethod(pdp_live_class, (t_method)pdp_live_priority, gensym("priority"), A_FLOAT, A_NULL); class_addmethod(pdp_live_class, (t_method)pdp_live_audio, gensym("audio"), A_FLOAT, A_NULL); + class_addmethod(pdp_live_class, (t_method)pdp_live_autoplay, gensym("autoplay"), A_FLOAT, A_NULL); + class_addmethod(pdp_live_class, (t_method)pdp_live_loop, gensym("loop"), A_FLOAT, A_NULL); class_addmethod(pdp_live_class, (t_method)pdp_live_threadify, gensym("thread"), A_FLOAT, A_NULL); + class_addmethod(pdp_live_class, (t_method)pdp_live_bang, gensym("bang"), A_NULL); + class_addmethod(pdp_live_class, (t_method)pdp_live_frame_cold, gensym("frame_cold"), A_FLOAT, A_NULL); class_sethelpsymbol( pdp_live_class, gensym("pdp_live~.pd") ); } diff --git a/modules/pdp_o.c b/modules/pdp_o.c index ee5e084..30157cf 100644 --- a/modules/pdp_o.c +++ b/modules/pdp_o.c @@ -182,7 +182,7 @@ static void pdp_o_smoothe(t_pdp_o *x, short int *source, t_int size ) static int pdp_o_huffman(t_pdp_o *x, char *source, char *dest, t_int size, t_int *csize ) { t_int i; - char value = source[0]; + int value = source[0]; char count = 0; t_int tcount=0; char *pcount=dest; @@ -198,14 +198,14 @@ static int pdp_o_huffman(t_pdp_o *x, char *source, char *dest, t_int size, t_int } else { - value=source[i]; *(pcount)=count; *(pvalue) = value; tcount+=count; - count=1; pcount+=2; pvalue+=2; *(csize)+=2; + value=source[i]; + count=1; } } *(pcount)=count; @@ -221,7 +221,7 @@ static int pdp_o_huffman(t_pdp_o *x, char *source, char *dest, t_int size, t_int else { // post( "pdp_o : huffman : compression ratio %d/%d : %f (total count=%d)", size, (*csize), - // (t_float)size/(t_float)(*csize), tcount ); + // (t_float)size/(t_float)(*csize), tcount ); return HUFFMAN; } } @@ -349,7 +349,8 @@ static void pdp_o_process_yv12(t_pdp_o *x) { // post( "pdp_o : y value out of range : %d", downvalue ); } - if ( data[i] != x->x_previous_frame[i] ) + if ( ( data[i] != x->x_previous_frame[i] ) || + ( !strcmp( x->x_hpacket.tag, PDP_PACKET_TAG ) ) ) { x->x_diff_frame[i] = (char)downvalue; } @@ -368,7 +369,8 @@ static void pdp_o_process_yv12(t_pdp_o *x) { // post( "pdp_o : y value out of range : %d", downvalue ); } - if ( data[i] != x->x_previous_frame[i] ) + if ( ( data[i] != x->x_previous_frame[i] ) || + ( !strcmp( x->x_hpacket.tag, PDP_PACKET_TAG ) ) ) { x->x_diff_frame[i] = (char)downvalue; } @@ -378,8 +380,8 @@ static void pdp_o_process_yv12(t_pdp_o *x) } } - x->x_hpacket.width = x->x_vwidth; - x->x_hpacket.height = x->x_vheight; + x->x_hpacket.width = htonl(x->x_vwidth); + x->x_hpacket.height = htonl(x->x_vheight); if ( gettimeofday(&x->x_hpacket.etime, NULL) == -1) { post("pdp_o : could not set emit time" ); @@ -391,13 +393,16 @@ static void pdp_o_process_yv12(t_pdp_o *x) x->x_bandwidthcount = 0; } + x->x_hpacket.etime.tv_sec = htonl( x->x_hpacket.etime.tv_sec ); + x->x_hpacket.etime.tv_usec = htonl( x->x_hpacket.etime.tv_usec ); + // do not send the frame if too many frames // have been sent in the current second if ( x->x_secondcount < x->x_framerate ) { // try a huffman coding - x->x_hpacket.encoding = pdp_o_huffman(x, x->x_diff_frame, x->x_hdata, x->x_vsize+(x->x_vsize>>1), &x->x_hsize ); + x->x_hpacket.encoding = htonl( pdp_o_huffman(x, x->x_diff_frame, x->x_hdata, x->x_vsize+(x->x_vsize>>1), &x->x_hsize ) ); x->x_hpacket.clength = (x->x_vsize+(x->x_vsize>>1))*1.01+600; // compress the graphic data @@ -415,6 +420,7 @@ static void pdp_o_process_yv12(t_pdp_o *x) memcpy( x->x_previous_frame, data, (x->x_vsize+(x->x_vsize>>1))<<1 ); // send header + x->x_hpacket.clength = htonl( x->x_hpacket.clength ); count = send(x->x_fd, &x->x_hpacket, sizeof(x->x_hpacket), MSG_NOSIGNAL); if(count < 0) { @@ -430,6 +436,7 @@ static void pdp_o_process_yv12(t_pdp_o *x) } x->x_bandwidthcount += count/1024; } + x->x_hpacket.clength = ntohl( x->x_hpacket.clength ); // send data count = send(x->x_fd, x->x_cdata, x->x_hpacket.clength, MSG_NOSIGNAL); diff --git a/modules/pdp_ocanvas.c b/modules/pdp_ocanvas.c index c92253b..598821e 100644 --- a/modules/pdp_ocanvas.c +++ b/modules/pdp_ocanvas.c @@ -53,6 +53,7 @@ typedef struct pdp_ocanvas_struct t_int *x_heights; t_float *x_xoffsets; t_float *x_yoffsets; + t_float *x_alphas; t_int *x_sizes; t_int x_owidth; @@ -105,7 +106,7 @@ static void pdp_ocanvas_process_yv12(t_pdp_ocanvas *x) piU = idata+x->x_sizes[ii]+(x->x_sizes[ii]>>2); ppx = px-(int)x->x_xoffsets[ii]; ppy = py-(int)x->x_yoffsets[ii]; - *(pY+py*x->x_owidth+px) += *(piY+ppy*x->x_widths[ii]+ppx); + *(pY+py*x->x_owidth+px) += *(piY+ppy*x->x_widths[ii]+ppx)*x->x_alphas[ii]; if ( (px%2==0) && (py%2==0) ) { *(pU+(py>>1)*(x->x_owidth>>1)+(px>>1)) += @@ -175,6 +176,21 @@ static void pdp_ocanvas_offset(t_pdp_ocanvas *x, t_floatarg ni, t_floatarg xoffs x->x_yoffsets[(int)ni-1] = yoffset; } +static void pdp_ocanvas_alpha(t_pdp_ocanvas *x, t_floatarg ni, t_floatarg xalpha) +{ + if ( ( ni < 1 ) || ( ni > x->x_nbinputs ) ) + { + post( "pdp_ocanvas : alpha : wrong source : %d : must be between 1 and %d", ni, x->x_nbinputs ); + return; + } + if ( ( xalpha < .0 ) || ( xalpha > 1.0 ) ) + { + post( "pdp_ocanvas : alpha : wrong alpha value : %f : must be between 0 and 1", xalpha ); + return; + } + x->x_alphas[(int)ni-1] = xalpha; +} + static void pdp_ocanvas_select(t_pdp_ocanvas *x, t_floatarg X, t_floatarg Y) { t_int ii; @@ -324,6 +340,7 @@ static void pdp_ocanvas_free(t_pdp_ocanvas *x) if ( x->x_sizes ) freebytes( x->x_sizes, x->x_nbinputs*sizeof(t_int) ); if ( x->x_xoffsets ) freebytes( x->x_xoffsets, x->x_nbinputs*sizeof(t_float) ); if ( x->x_yoffsets ) freebytes( x->x_yoffsets, x->x_nbinputs*sizeof(t_float) ); + if ( x->x_alphas ) freebytes( x->x_alphas, x->x_nbinputs*sizeof(t_float) ); } t_class *pdp_ocanvas_class; @@ -381,6 +398,7 @@ void *pdp_ocanvas_new(t_symbol *s, int argc, t_atom *argv) x->x_sizes = ( t_int* ) getbytes( x->x_nbinputs*sizeof(t_int) ); x->x_xoffsets = ( t_float* ) getbytes( x->x_nbinputs*sizeof(t_float) ); x->x_yoffsets = ( t_float* ) getbytes( x->x_nbinputs*sizeof(t_float) ); + x->x_alphas = ( t_float* ) getbytes( x->x_nbinputs*sizeof(t_float) ); x->x_opacket = pdp_packet_new_image_YCrCb( x->x_owidth, x->x_oheight ); @@ -391,6 +409,7 @@ void *pdp_ocanvas_new(t_symbol *s, int argc, t_atom *argv) x->x_packets[ii] = -1; x->x_xoffsets[ii] = 0.; x->x_yoffsets[ii] = 0.; + x->x_alphas[ii] = 1.; } x->x_current = -1; x->x_average = 0; @@ -426,6 +445,7 @@ void pdp_ocanvas_setup(void) class_addmethod(pdp_ocanvas_class, (t_method)pdp_ocanvas_input8, gensym("pdp8"), A_SYMBOL, A_DEFFLOAT, A_NULL); class_addmethod(pdp_ocanvas_class, (t_method)pdp_ocanvas_input9, gensym("pdp9"), A_SYMBOL, A_DEFFLOAT, A_NULL); class_addmethod(pdp_ocanvas_class, (t_method)pdp_ocanvas_offset, gensym("offset"), A_DEFFLOAT, A_DEFFLOAT, A_DEFFLOAT, A_NULL); + class_addmethod(pdp_ocanvas_class, (t_method)pdp_ocanvas_alpha, gensym("alpha"), A_DEFFLOAT, A_DEFFLOAT, A_NULL); class_addmethod(pdp_ocanvas_class, (t_method)pdp_ocanvas_select, gensym("select"), A_DEFFLOAT, A_DEFFLOAT, A_NULL); class_addmethod(pdp_ocanvas_class, (t_method)pdp_ocanvas_drag, gensym("drag"), A_DEFFLOAT, A_DEFFLOAT, A_NULL); class_addmethod(pdp_ocanvas_class, (t_method)pdp_ocanvas_unselect, gensym("unselect"), A_NULL); diff --git a/modules/pdp_pen.c b/modules/pdp_pen.c index dad5167..6aa263c 100644 --- a/modules/pdp_pen.c +++ b/modules/pdp_pen.c @@ -52,6 +52,7 @@ typedef struct pdp_pen_struct t_int x_blue; t_int x_xoffset; t_int x_yoffset; + t_float x_alpha; t_int x_pwidth; t_int x_mode; // 0=draw ( default), 1=erase @@ -317,6 +318,14 @@ static void pdp_pen_yoffset(t_pdp_pen *x, t_floatarg yoffset) x->x_yoffset = (int) yoffset; } +static void pdp_pen_alpha(t_pdp_pen *x, t_floatarg falpha) +{ + if ( falpha >= 0. && falpha <= 1. ) + { + x->x_alpha = falpha; + } +} + static void pdp_pen_mode(t_pdp_pen *x, t_floatarg mode) { if ( ( mode == 0. ) || ( mode == 1. ) ) @@ -394,11 +403,15 @@ static void pdp_pen_process_yv12(t_pdp_pen *x) { if ( *(pbY+(py-x->x_yoffset)*x->x_vwidth+(px-x->x_xoffset)) != 0 ) { - *(pnY+py*x->x_vwidth+px) = *(pbY+(py-x->x_yoffset)*x->x_vwidth+(px-x->x_xoffset)); + *(pnY+py*x->x_vwidth+px) = + (*(pbY+(py-x->x_yoffset)*x->x_vwidth+(px-x->x_xoffset))*x->x_alpha) + + (*(pnY+py*x->x_vwidth+px)*(1-x->x_alpha)); *(pnU+(py>>1)*(x->x_vwidth>>1)+(px>>1)) = - *(pbU+((py-x->x_yoffset)>>1)*(x->x_vwidth>>1)+((px-x->x_xoffset)>>1)); + (*(pbU+((py-x->x_yoffset)>>1)*(x->x_vwidth>>1)+((px-x->x_xoffset)>>1))*x->x_alpha) + + (*(pnU+(py>>1)*(x->x_vwidth>>1)+(px>>1))*(1-x->x_alpha)); *(pnV+(py>>1)*(x->x_vwidth>>1)+(px>>1)) = - *(pbV+((py-x->x_yoffset)>>1)*(x->x_vwidth>>1)+((px-x->x_xoffset)>>1)); + (*(pbV+((py-x->x_yoffset)>>1)*(x->x_vwidth>>1)+((px-x->x_xoffset)>>1))*x->x_alpha) + + (*(pnV+(py>>1)*(x->x_vwidth>>1)+(px>>1))*(1-x->x_alpha)); } } } @@ -482,6 +495,7 @@ void *pdp_pen_new(void) x->x_outlet0 = outlet_new(&x->x_obj, &s_anything); inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("xoffset")); inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("yoffset")); + inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("alpha")); x->x_packet0 = -1; x->x_packet1 = -1; @@ -498,6 +512,7 @@ void *pdp_pen_new(void) x->x_pwidth = 3; x->x_mode = 0; + x->x_alpha = 1.; return (void *)x; } @@ -525,6 +540,7 @@ void pdp_pen_setup(void) class_addmethod(pdp_pen_class, (t_method)pdp_pen_mode, gensym("mode"), A_DEFFLOAT, A_NULL); class_addmethod(pdp_pen_class, (t_method)pdp_pen_xoffset, gensym("xoffset"), A_DEFFLOAT, A_NULL); class_addmethod(pdp_pen_class, (t_method)pdp_pen_yoffset, gensym("yoffset"), A_DEFFLOAT, A_NULL); + class_addmethod(pdp_pen_class, (t_method)pdp_pen_alpha, gensym("alpha"), A_DEFFLOAT, A_NULL); } diff --git a/modules/pdp_rec~.c b/modules/pdp_rec~.c index 2a0d68e..5b217dd 100644 --- a/modules/pdp_rec~.c +++ b/modules/pdp_rec~.c @@ -445,8 +445,8 @@ static t_int *pdp_rec_perform(t_int *w) if (fsample < -1.0) { fsample = -1.0; } isample=(short) (32767.0 * fsample); x->x_audio_buf[1][x->x_audioin_position]=isample; - x->x_audioin_position=(x->x_audioin_position+1)%(2*MAX_AUDIO_PACKET_SIZE); - if ( x->x_audioin_position == 2*MAX_AUDIO_PACKET_SIZE-1 ) + x->x_audioin_position=(x->x_audioin_position+1)%(MAX_AUDIO_PACKET_SIZE); + if ( x->x_audioin_position == MAX_AUDIO_PACKET_SIZE-1 ) { post( "pdp_rec~ : reaching end of audio buffer" ); } @@ -624,6 +624,7 @@ static void pdp_rec_free(t_pdp_rec *x) pdp_packet_mark_unused(x->x_packet0); // close video file if existing pdp_rec_close(x); + pdp_rec_free_ressources(x); for ( i=0; i<x->x_channels; i++) { if ( x->x_audio_buf[i] ) freebytes( x->x_audio_buf[i], MAX_AUDIO_PACKET_SIZE*sizeof(int16_t) ); diff --git a/modules/pdp_shape.c b/modules/pdp_shape.c index 27239c4..5f21518 100644 --- a/modules/pdp_shape.c +++ b/modules/pdp_shape.c @@ -26,7 +26,7 @@ #include "yuv.h" #include <math.h> -static char *pdp_shape_version = "pdp_shape: version 0.1, shape recongnition object written by Yves Degoyon (ydegoyon@free.fr)"; +static char *pdp_shape_version = "pdp_shape: version 0.1, shape recognition object written by Yves Degoyon (ydegoyon@free.fr)"; typedef struct pdp_shape_struct { @@ -79,15 +79,15 @@ static void pdp_shape_allocate(t_pdp_shape *x, t_int newsize) { int i; - if ( x->x_bdata ) freebytes( x->x_bdata, (( x->x_vsize + (x->x_vsize>>1))<<1)); - if ( x->x_bbdata ) freebytes( x->x_bbdata, (( x->x_vsize + (x->x_vsize>>1))<<1)); - if ( x->x_checked ) freebytes( x->x_checked, x->x_vsize ); + if ( x->x_bdata ) free( x->x_bdata ); + if ( x->x_bbdata ) free( x->x_bbdata ); + if ( x->x_checked ) free( x->x_checked ); x->x_vsize = newsize; - x->x_bdata = (short int *)getbytes((( x->x_vsize + (x->x_vsize>>1))<<1)); - x->x_bbdata = (short int *)getbytes((( x->x_vsize + (x->x_vsize>>1))<<1)); - x->x_checked = (char *)getbytes( x->x_vsize ); + x->x_bdata = (short int *)malloc((( x->x_vsize + (x->x_vsize>>1))<<1)); + x->x_bbdata = (short int *)malloc((( x->x_vsize + (x->x_vsize>>1))<<1)); + x->x_checked = (char *)malloc( x->x_vsize ); } static void pdp_shape_tolerance(t_pdp_shape *x, t_floatarg ftolerance ) @@ -451,12 +451,15 @@ static void pdp_shape_process_yv12(t_pdp_shape *x) if ( x->x_cursX != -1 ) pdp_shape_frame_detect( x, x->x_cursX, x->x_cursY ); // paint cursor in red for debug purpose - pbbY = x->x_bbdata; - pbbU = (x->x_bbdata+x->x_vsize); - pbbV = (x->x_bbdata+x->x_vsize+(x->x_vsize>>2)); - *(pbbY+x->x_cursY*x->x_vwidth+x->x_cursX) = (yuv_RGBtoY( 0xff ))<<7; - *(pbbU+(x->x_cursY>>1)*(x->x_vwidth>>1)+(x->x_cursX>>1)) = ((yuv_RGBtoU( 0xff )-128)<<8); - *(pbbV+(x->x_cursY>>1)*(x->x_vwidth>>1)+(x->x_cursX>>1)) = ((yuv_RGBtoV( 0xff )-128)<<8); + if ( x->x_cursX != -1 ) + { + pbbY = x->x_bbdata; + pbbU = (x->x_bbdata+x->x_vsize); + pbbV = (x->x_bbdata+x->x_vsize+(x->x_vsize>>2)); + *(pbbY+x->x_cursY*x->x_vwidth+x->x_cursX) = (yuv_RGBtoY( 0xff ))<<7; + *(pbbU+(x->x_cursY>>1)*(x->x_vwidth>>1)+(x->x_cursX>>1)) = ((yuv_RGBtoU( 0xff )-128)<<8); + *(pbbV+(x->x_cursY>>1)*(x->x_vwidth>>1)+(x->x_cursX>>1)) = ((yuv_RGBtoV( 0xff )-128)<<8); + } memcpy( newdata, x->x_bbdata, (x->x_vsize+(x->x_vsize>>1))<<1 ); diff --git a/modules/pdp_text.c b/modules/pdp_text.c index d4eef94..5d2d633 100644 --- a/modules/pdp_text.c +++ b/modules/pdp_text.c @@ -60,6 +60,7 @@ typedef struct pdp_text_struct t_int *x_g; t_int *x_b; t_float *x_angle; + t_float x_alpha; t_int *x_scroll; t_int x_nbtexts; @@ -154,7 +155,7 @@ static void pdp_text_add(t_pdp_text *x, t_symbol *s, int argc, t_atom *argv) { x->x_angle[x->x_nbtexts] = argv[6].a_w.w_float; } - if ( (argc>=8) && (argv[7].a_type == A_FLOAT) ) + if ( (argc>=8) && (argv[7].a_type == A_FLOAT) ) { x->x_scroll[x->x_nbtexts] = (int)argv[7].a_w.w_float; } @@ -224,6 +225,14 @@ static void pdp_text_angle(t_pdp_text *x, t_floatarg fangle ) } } +static void pdp_text_alpha(t_pdp_text *x, t_floatarg falpha ) +{ + if ( ( falpha >= 0. ) && ( falpha <= 1. ) ) + { + x->x_alpha = falpha; + } +} + static void pdp_text_scroll(t_pdp_text *x, t_floatarg fscroll ) { if ( ( x->x_current >= 0 ) && ( x->x_current < x->x_nbtexts ) ) @@ -456,11 +465,11 @@ static void pdp_text_process_yv12(t_pdp_text *x) u = yuv_RGBtoU(imdata[py*x->x_vwidth+px]); v = yuv_RGBtoV(imdata[py*x->x_vwidth+px]); - *(pY) = y<<7; + *(pY) = ((y)<<7)*x->x_alpha + (*pY)*(1-x->x_alpha); if ( (px%2==0) && (py%2==0) ) { - *(pV) = (v-128)<<8; - *(pU) = (u-128)<<8; + *(pV) = ((v-128)<<8)*x->x_alpha + *(pV)*(1-x->x_alpha); + *(pU) = ((u-128)<<8)*x->x_alpha + *(pU)*(1-x->x_alpha); } } pY++; @@ -557,6 +566,7 @@ void *pdp_text_new(void) inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("textb")); inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("angle")); inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("scroll")); + inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("alpha")); x->x_outlet0 = outlet_new(&x->x_obj, &s_anything); x->x_packet0 = -1; @@ -585,6 +595,7 @@ void *pdp_text_new(void) x->x_nbtexts = 0; x->x_current = -1; + x->x_alpha = 1.; return (void *)x; } @@ -618,6 +629,7 @@ void pdp_text_setup(void) class_addmethod(pdp_text_class, (t_method)pdp_text_resize, gensym("resize"), A_DEFFLOAT, A_NULL); class_addmethod(pdp_text_class, (t_method)pdp_text_font, gensym("font"), A_SYMBOL, A_NULL); class_addmethod(pdp_text_class, (t_method)pdp_text_angle, gensym("angle"), A_DEFFLOAT, A_NULL); + class_addmethod(pdp_text_class, (t_method)pdp_text_alpha, gensym("alpha"), A_DEFFLOAT, A_NULL); class_addmethod(pdp_text_class, (t_method)pdp_text_scroll, gensym("scroll"), A_DEFFLOAT, A_NULL); class_addmethod(pdp_text_class, (t_method)pdp_text_dither, gensym("dither"), A_DEFFLOAT, A_NULL); class_addmethod(pdp_text_class, (t_method)pdp_text_blend, gensym("blend"), A_DEFFLOAT, A_NULL); diff --git a/modules/pdp_underwatch.c b/modules/pdp_underwatch.c index 674582f..c999ceb 100644 --- a/modules/pdp_underwatch.c +++ b/modules/pdp_underwatch.c @@ -73,19 +73,12 @@ static void pdp_underwatch_process_yv12(t_pdp_underwatch *x) short int *p=0, *po=0, *pu=0, *pv=0, *pou=0, *pov=0; int i; - unsigned int u_offset; - unsigned int v_offset; - unsigned int totnbpixels; int px, py, pd, t; x->x_vwidth = header->info.image.width; x->x_vheight = header->info.image.height; x->x_vsize = x->x_vwidth*x->x_vheight; - u_offset = x->x_vsize; - v_offset = x->x_vsize + (x->x_vsize>>2); - totnbpixels = x->x_vsize + (x->x_vsize>>1); - newheader->info.image.encoding = header->info.image.encoding; newheader->info.image.width = x->x_vwidth; newheader->info.image.height = x->x_vheight; diff --git a/modules/pdp_yqt.c b/modules/pdp_yqt.c index d0ada83..8795f77 100644 --- a/modules/pdp_yqt.c +++ b/modules/pdp_yqt.c @@ -237,7 +237,7 @@ static void pdp_yqt_bang(t_pdp_yqt *x) if ( gettimeofday(&etime, NULL) == -1) { - post("pdp_fcqt : could not get time" ); + post("pdp_yqt : could not get time" ); } if ( etime.tv_sec != x->x_cursec ) { @@ -248,7 +248,6 @@ static void pdp_yqt_bang(t_pdp_yqt *x) x->x_framescount++; outlet_float(x->x_curframe, (float)pos); - pdp_packet_pass_if_valid(x->x_outlet0, &object); // fills in the audio buffer with a chunk if necessary if ( x->x_audio && x->x_outunread < MIN_AUDIO_INPUT ) @@ -285,6 +284,8 @@ static void pdp_yqt_bang(t_pdp_yqt *x) } } + pdp_packet_pass_if_valid(x->x_outlet0, &object); + } static void pdp_yqt_loop(t_pdp_yqt *x, t_floatarg loop) diff --git a/patches/help_pdp-tatiana.pd b/patches/help_pdp-tatiana.pd index b1382ea..f73a5ef 100644 --- a/patches/help_pdp-tatiana.pd +++ b/patches/help_pdp-tatiana.pd @@ -1,481 +1,509 @@ -#N canvas 4 0 986 675 10; -#X msg 143 146 loop \$1; -#X msg 63 170 open \$1; -#X floatatom 215 155 5 0 0 0 - - -; -#X obj 260 113 metro 70; -#X obj 168 186 pdp_yqt; -#X obj 316 188 pdp_v4l; -#X obj 315 161 metro 70; -#X obj 453 120 bng 15 250 50 0 empty webcam1 empty 20 8 0 8 -262144 +#N canvas 4 0 780 312 10; +#X msg 157 21 loop \$1; +#X msg 77 45 open \$1; +#X floatatom 229 30 5 0 0 0 - - -; +#X obj 274 -12 metro 70; +#X obj 182 61 pdp_yqt; +#X obj 330 63 pdp_v4l; +#X obj 329 36 metro 70; +#X obj 467 -5 bng 15 250 50 0 empty webcam1 empty 20 8 0 8 -262144 -1 -1; -#X msg 470 188 stop; -#X msg 518 163 open /dev/video; -#X obj 102 219 tgl 15 0 empty aging empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 29 228 pdp_spigot; -#X text 419 119 Live; -#X obj 226 220 tgl 15 0 empty baltan empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 151 233 pdp_spigot; -#X floatatom 28 278 5 0 0 0 - ag1 -; -#X floatatom 69 279 5 0 0 0 - ag2 -; -#X obj 28 255 pdp_aging; -#X obj 153 255 pdp_baltan; -#X floatatom 153 274 10 0 0 0 - balt1 -; -#X obj 339 221 tgl 15 0 empty edge empty 0 -6 0 8 -262144 -1 -1 0 1 +#X msg 484 63 stop; +#X msg 532 38 open /dev/video; +#X obj 116 94 tgl 15 0 empty aging empty 0 -6 0 8 -262144 -1 -1 0 1 ; -#X obj 267 232 pdp_spigot; -#X obj 265 255 pdp_edge; -#X obj 448 220 tgl 15 0 empty intr1 empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 375 231 pdp_spigot; -#X msg 389 282 bang; -#X floatatom 424 283 5 0 0 0 - intr2 -; -#X obj 375 253 pdp_intrusion; -#X obj 556 219 tgl 15 0 empty lens empty 0 -6 0 8 -262144 -1 -1 0 1 +#X obj 43 103 pdp_spigot; +#X text 433 -6 Live; +#X obj 240 95 tgl 15 0 empty baltan empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 165 108 pdp_spigot; +#X floatatom 42 153 5 0 0 0 - ag1 -; +#X floatatom 83 154 5 0 0 0 - ag2 -; +#X obj 42 130 pdp_aging; +#X obj 167 130 pdp_baltan; +#X floatatom 167 149 10 0 0 0 - balt1 -; +#X obj 353 96 tgl 15 0 empty edge empty 0 -6 0 8 -262144 -1 -1 0 1 ; -#X obj 484 228 pdp_spigot; -#X obj 484 252 pdp_lens; -#X floatatom 483 276 5 0 0 0 - - -; -#X floatatom 522 276 5 0 0 0 - - -; -#X floatatom 483 291 5 0 0 0 - - -; -#X floatatom 522 291 5 0 0 0 - - -; -#X obj 551 252 tgl 15 0 empty lensmove empty 0 -6 0 8 -262144 -1 -1 +#X obj 281 107 pdp_spigot; +#X obj 279 130 pdp_edge; +#X obj 462 95 tgl 15 0 empty intr1 empty 0 -6 0 8 -262144 -1 -1 0 1 +; +#X obj 389 106 pdp_spigot; +#X msg 403 157 bang; +#X floatatom 438 158 5 0 0 0 - intr2 -; +#X obj 389 128 pdp_intrusion; +#X obj 570 94 tgl 15 0 empty lens empty 0 -6 0 8 -262144 -1 -1 0 1 +; +#X obj 498 103 pdp_spigot; +#X obj 498 127 pdp_lens; +#X floatatom 497 151 5 0 0 0 - - -; +#X floatatom 536 151 5 0 0 0 - - -; +#X floatatom 497 166 5 0 0 0 - - -; +#X floatatom 536 166 5 0 0 0 - - -; +#X obj 565 127 tgl 15 0 empty lensmove empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 670 217 tgl 15 0 empty mosaic empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 684 92 tgl 15 0 empty mosaic empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 599 228 pdp_spigot; -#X msg 600 269 bang; -#X obj 600 250 pdp_mosaic; -#X floatatom 637 271 5 0 0 0 - mosaic2 -; -#X obj 745 304 tgl 15 0 empty nervous empty 0 -6 0 8 -262144 -1 -1 +#X obj 613 103 pdp_spigot; +#X msg 614 144 bang; +#X obj 614 125 pdp_mosaic; +#X floatatom 651 146 5 0 0 0 - mosaic2 -; +#X obj 759 179 tgl 15 0 empty nervous empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 674 315 pdp_spigot; -#X obj 675 337 pdp_nervous; -#X obj 676 360 tgl 15 0 empty nervous1 empty 0 -6 0 8 -262144 -1 -1 +#X obj 688 190 pdp_spigot; +#X obj 689 212 pdp_nervous; +#X obj 690 235 tgl 15 0 empty nervous1 empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 566 309 tgl 15 0 empty quark empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 580 184 tgl 15 0 empty quark empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 494 320 pdp_spigot; -#X obj 494 343 pdp_quark; -#X obj 454 308 tgl 15 0 empty radiac empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 508 195 pdp_spigot; +#X obj 508 218 pdp_quark; +#X obj 468 183 tgl 15 0 empty radiac empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 381 318 pdp_spigot; -#X floatatom 382 380 5 0 0 0 - radi1 -; -#X obj 381 341 pdp_radioactiv; -#X obj 381 363 hdl 15 1 0 4 empty empty empty 0 -6 0 8 -262144 -1 -1 +#X obj 395 193 pdp_spigot; +#X floatatom 396 255 5 0 0 0 - radi1 -; +#X obj 395 216 pdp_radioactiv; +#X obj 395 238 hdl 15 1 0 4 empty empty empty 0 -6 0 8 -262144 -1 -1 0; -#X floatatom 426 379 5 0 0 0 - radi2 -; -#X obj 349 308 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 278 319 pdp_spigot; -#X floatatom 275 360 5 0 0 0 - rev1 -; -#X floatatom 316 360 5 0 0 0 - rev2 -; -#X floatatom 275 375 5 0 0 0 - rev3 -; -#X floatatom 316 377 5 0 0 0 - rev4 -; -#X obj 278 341 pdp_rev; -#X obj 235 303 tgl 15 0 empty ripple empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 164 316 pdp_spigot; -#X msg 177 363 bang; -#X obj 161 365 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 164 343 pdp_ripple; -#X floatatom 160 382 5 0 0 0 - rip1 -; -#X floatatom 199 381 5 0 0 0 - rip2 -; -#X obj 116 302 tgl 15 0 empty simura empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 43 312 pdp_spigot; -#X obj 43 336 pdp_simura; -#X floatatom 41 374 5 0 0 0 - simura2 -; -#X obj 28 356 hdl 15 1 0 9 empty empty empty 0 -6 0 8 -262144 -1 -1 +#X floatatom 440 254 5 0 0 0 - radi2 -; +#X obj 363 183 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 292 194 pdp_spigot; +#X floatatom 289 235 5 0 0 0 - rev1 -; +#X floatatom 330 235 5 0 0 0 - rev2 -; +#X floatatom 289 250 5 0 0 0 - rev3 -; +#X floatatom 330 252 5 0 0 0 - rev4 -; +#X obj 292 216 pdp_rev; +#X obj 249 178 tgl 15 0 empty ripple empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 178 191 pdp_spigot; +#X msg 191 238 bang; +#X obj 175 240 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 178 218 pdp_ripple; +#X floatatom 174 257 5 0 0 0 - rip1 -; +#X floatatom 213 256 5 0 0 0 - rip2 -; +#X obj 130 177 tgl 15 0 empty simura empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 57 187 pdp_spigot; +#X obj 57 211 pdp_simura; +#X floatatom 55 249 5 0 0 0 - simura2 -; +#X obj 42 231 hdl 15 1 0 9 empty empty empty 0 -6 0 8 -262144 -1 -1 0; -#X obj 97 398 tgl 15 0 empty spiral empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 111 273 tgl 15 0 empty spiral empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 25 409 pdp_spigot; -#X floatatom 25 466 5 0 0 0 - spi1 -; -#X obj 19 447 hdl 15 1 0 8 empty empty empty 0 -6 0 8 -262144 -1 -1 +#X obj 39 284 pdp_spigot; +#X floatatom 39 341 5 0 0 0 - spi1 -; +#X obj 33 322 hdl 15 1 0 8 empty empty empty 0 -6 0 8 -262144 -1 -1 0; -#X floatatom 66 465 5 0 0 0 - spi2 -; -#X floatatom 110 466 5 0 0 0 - spi3 -; -#X floatatom 26 484 5 0 0 0 - spi4 -; -#X floatatom 67 483 5 0 0 0 - spi5 -; -#X obj 110 481 tgl 15 0 empty spi6 empty 0 -6 0 8 -262144 -1 -1 0 1 +#X floatatom 80 340 5 0 0 0 - spi2 -; +#X floatatom 124 341 5 0 0 0 - spi3 -; +#X floatatom 40 359 5 0 0 0 - spi4 -; +#X floatatom 81 358 5 0 0 0 - spi5 -; +#X obj 124 356 tgl 15 0 empty spi6 empty 0 -6 0 8 -262144 -1 -1 0 1 ; -#X obj 129 481 tgl 15 0 empty spi7 empty 0 -6 0 8 -262144 -1 -1 0 1 +#X obj 143 356 tgl 15 0 empty spi7 empty 0 -6 0 8 -262144 -1 -1 0 1 ; -#X obj 25 430 pdp_spiral; -#X obj 236 397 tgl 15 0 empty under empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 164 408 pdp_spigot; -#X floatatom 163 448 5 0 0 0 - under2 -; -#X obj 163 426 pdp_underwatch; -#X obj 358 397 tgl 15 0 empty verti empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 285 408 pdp_spigot; -#X obj 481 398 tgl 15 0 empty warh1 empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 408 409 pdp_spigot; -#X obj 599 400 tgl 15 0 empty warp1 empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 529 409 pdp_spigot; -#X obj 284 426 pdp_vertigo; -#X floatatom 283 446 5 0 0 0 - verti1 -; -#X floatatom 322 446 5 0 0 0 - verti2 -; -#X floatatom 408 450 5 0 0 0 - warh2 -; -#X obj 408 430 pdp_warhol; -#X floatatom 452 450 5 0 0 0 - warh3 -; -#X obj 408 466 hdl 15 1 0 9 empty empty empty 0 -6 0 8 -262144 -1 -1 +#X obj 39 305 pdp_spiral; +#X obj 250 272 tgl 15 0 empty under empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 178 283 pdp_spigot; +#X floatatom 177 323 5 0 0 0 - under2 -; +#X obj 177 301 pdp_underwatch; +#X obj 372 272 tgl 15 0 empty verti empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 299 283 pdp_spigot; +#X obj 495 273 tgl 15 0 empty warh1 empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 422 284 pdp_spigot; +#X obj 613 275 tgl 15 0 empty warp1 empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 543 284 pdp_spigot; +#X obj 298 301 pdp_vertigo; +#X floatatom 297 321 5 0 0 0 - verti1 -; +#X floatatom 336 321 5 0 0 0 - verti2 -; +#X floatatom 422 325 5 0 0 0 - warh2 -; +#X obj 422 305 pdp_warhol; +#X floatatom 466 325 5 0 0 0 - warh3 -; +#X obj 422 341 hdl 15 1 0 9 empty empty empty 0 -6 0 8 -262144 -1 -1 0; -#X floatatom 410 484 5 0 0 0 - warh4 -; -#X floatatom 450 484 5 0 0 0 - warh5 -; -#X floatatom 490 484 5 0 0 0 - warh6 -; -#X obj 529 446 tgl 15 0 empty warp2 empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X floatatom 547 447 5 0 0 0 - warp3 -; -#X obj 529 429 pdp_warp; -#X obj 700 402 tgl 15 0 empty cyc1 empty 0 -6 0 8 -262144 -1 -1 0 1 +#X floatatom 424 359 5 0 0 0 - warh4 -; +#X floatatom 464 359 5 0 0 0 - warh5 -; +#X floatatom 504 359 5 0 0 0 - warh6 -; +#X obj 543 321 tgl 15 0 empty warp2 empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X floatatom 561 322 5 0 0 0 - warp3 -; +#X obj 543 304 pdp_warp; +#X obj 714 277 tgl 15 0 empty cyc1 empty 0 -6 0 8 -262144 -1 -1 0 1 ; -#X obj 631 412 pdp_spigot; -#X floatatom 499 126 5 0 0 0 - - -; -#X floatatom 403 650 5 0 0 0 - - -; -#X msg 485 583 open /tmp/output.mov; -#X msg 485 602 start; -#X msg 485 622 stop; -#X msg 164 689 cursor \$1; -#X obj 174 671 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 3 604 pdp_zoom; -#X floatatom 45 565 5 0 0 0 - - -; -#X obj 120 509 hsl 300 15 0.01 100 1 1 empty empty empty -2 -6 0 8 +#X obj 645 287 pdp_spigot; +#X floatatom 513 1 5 0 0 0 - - -; +#X floatatom 417 525 5 0 0 0 - - -; +#X msg 499 458 open /tmp/output.mov; +#X msg 499 477 start; +#X msg 499 497 stop; +#X msg 178 564 cursor \$1; +#X obj 188 546 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 17 479 pdp_zoom; +#X floatatom 59 440 5 0 0 0 - - -; +#X obj 134 384 hsl 300 15 0.01 100 1 1 empty zoomtot empty -2 -6 0 +8 -262144 -1 -1 14950 1; +#X floatatom 108 482 5 0 0 0 - - -; +#X obj 128 429 hsl 300 15 0.01 100 1 1 empty zoomh empty -2 -6 0 8 +-262144 -1 -1 14950 1; +#X msg 15 546 zoomx \$1; +#X msg 144 482 zoomy \$1; +#X floatatom 109 460 5 0 0 0 - - -; +#X obj 133 405 hsl 300 15 0.01 100 1 1 empty zoomv empty -2 -6 0 8 -262144 -1 -1 14950 1; -#X floatatom 94 607 5 0 0 0 - - -; -#X obj 114 554 hsl 300 15 0.01 100 1 1 empty empty empty -2 -6 0 8 --262144 -1 -1 14200 1; -#X msg 131 585 zoomx \$1; -#X msg 130 607 zoomy \$1; -#X floatatom 95 585 5 0 0 0 - - -; -#X obj 119 530 hsl 300 15 0.01 100 1 1 empty empty empty -2 -6 0 8 --262144 -1 -1 16000 1; -#X msg 230 642 centerx \$1; -#X floatatom 234 620 5 0 0 0 - - -; -#X floatatom 305 618 5 0 0 0 - - -; -#X msg 303 641 centery \$1; -#X obj 241 572 hsl 128 15 -1 1 0 1 empty empty empty -2 -6 0 8 -262144 --1 -1 6900 1; -#X obj 256 589 hsl 128 15 -1 1 0 1 empty empty empty -2 -6 0 8 -262144 +#X msg 244 517 centerx \$1; +#X floatatom 248 495 5 0 0 0 - - -; +#X floatatom 319 493 5 0 0 0 - - -; +#X msg 317 516 centery \$1; +#X obj 255 447 hsl 128 15 -1 1 0 1 empty empty empty -2 -6 0 8 -262144 +-1 -1 7900 1; +#X obj 270 464 hsl 128 15 -1 1 0 1 empty empty empty -2 -6 0 8 -262144 -1 -1 7300 1; -#X msg 1 523 center 0 0; -#X obj 630 433 pdp_cycle; -#X obj 627 453 tgl 15 0 empty cyc2 empty 0 -6 0 8 -262144 -1 -1 0 1 +#X msg 15 398 center 0 0; +#X obj 644 308 pdp_cycle; +#X obj 641 328 tgl 15 0 empty cyc2 empty 0 -6 0 8 -262144 -1 -1 0 1 ; -#X obj 653 454 tgl 15 0 empty cyc3 empty 0 -6 0 8 -262144 -1 -1 0 1 +#X obj 667 329 tgl 15 0 empty cyc3 empty 0 -6 0 8 -262144 -1 -1 0 1 ; -#X obj 675 454 tgl 15 0 empty cyc4 empty 0 -6 0 8 -262144 -1 -1 0 1 +#X obj 689 329 tgl 15 0 empty cyc4 empty 0 -6 0 8 -262144 -1 -1 0 1 ; -#X obj 793 402 tgl 15 0 empty transf empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 723 412 pdp_spigot; -#X obj 723 433 pdp_transform; -#X obj 723 455 hdl 15 1 0 6 empty empty empty 0 -6 0 8 -262144 -1 -1 +#X obj 807 277 tgl 15 0 empty transf empty 0 -6 0 8 -262144 -1 -1 0 +5; +#X obj 737 287 pdp_spigot; +#X obj 737 308 pdp_transform; +#X obj 737 330 hdl 15 1 0 6 empty empty empty 0 -6 0 8 -262144 -1 -1 0; -#X obj 840 308 tgl 15 0 empty shaga empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 854 183 tgl 15 0 empty shaga empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 770 316 pdp_spigot; -#X obj 769 338 pdp_shagadelic; -#X floatatom 769 360 5 0 0 0 - shaga1 -; -#X obj 814 359 * 100; -#X obj 776 219 tgl 15 0 empty dice empty 0 -6 0 8 -262144 -1 -1 0 1 +#X obj 784 191 pdp_spigot; +#X obj 783 213 pdp_shagadelic; +#X floatatom 783 235 5 0 0 0 - shaga1 -; +#X obj 828 234 * 100; +#X obj 790 94 tgl 15 0 empty dice empty 0 -6 0 8 -262144 -1 -1 0 1 ; -#X obj 705 228 pdp_spigot; -#X floatatom 705 270 5 0 0 0 - dice2 -; -#X obj 704 249 pdp_dice; -#X obj 780 481 tgl 15 0 empty puzz1 empty 0 -6 0 8 -262144 -1 -1 1 -1; -#X obj 711 491 pdp_spigot; -#X floatatom 807 510 5 0 0 0 - puzz2 -; -#X obj 710 512 pdp_puzzle; -#X msg 708 535 up; -#X msg 741 535 down; -#X msg 776 535 left; -#X msg 811 535 right; -#X obj 730 579 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 730 624 pdp_control; -#X msg 730 601 thread \$1; -#X floatatom 730 678 5 0 0 0 - - -; -#X obj 730 653 route pdp_drop; -#X msg 485 642 framerate 10; -#X obj 192 206 dac~; -#X floatatom 261 136 5 0 0 0 - - -; -#X obj 649 506 tgl 15 0 empty ascii1 empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 580 514 pdp_spigot; -#X obj 579 535 pdp_ascii; -#X floatatom 641 536 5 0 0 0 - ascii2 -; -#X floatatom 496 365 5 0 0 0 - qu1 -; -#X floatatom 715 359 5 0 0 0 - nervous2 -; -#X obj 260 158 t b f; -#X obj 417 586 adc~; -#X obj 655 311 tgl 15 0 empty noquark empty 0 -6 0 8 -262144 -1 -1 +#X obj 719 103 pdp_spigot; +#X floatatom 719 145 5 0 0 0 - dice2 -; +#X obj 718 124 pdp_dice; +#X obj 794 356 tgl 15 0 empty puzz1 empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 725 366 pdp_spigot; +#X floatatom 821 385 5 0 0 0 - puzz2 -; +#X obj 724 387 pdp_puzzle; +#X msg 722 410 up; +#X msg 755 410 down; +#X msg 790 410 left; +#X msg 825 410 right; +#X obj 744 454 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 744 499 pdp_control; +#X msg 744 476 thread \$1; +#X floatatom 744 553 5 0 0 0 - - -; +#X obj 744 528 route pdp_drop; +#X msg 499 517 framerate 10; +#X obj 206 81 dac~; +#X floatatom 275 11 5 0 0 0 - - -; +#X obj 663 381 tgl 15 0 empty ascii1 empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 594 389 pdp_spigot; +#X obj 593 410 pdp_ascii; +#X floatatom 655 411 5 0 0 0 - ascii2 -; +#X floatatom 510 240 5 0 0 0 - qu1 -; +#X floatatom 729 234 5 0 0 0 - nervous2 -; +#X obj 274 33 t b f; +#X obj 431 461 adc~; +#X obj 669 186 tgl 15 0 empty noquark empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 582 321 pdp_spigot; -#X floatatom 625 365 5 0 0 0 - noqu2 -; -#X obj 583 343 pdp_noquark; -#X floatatom 582 365 5 0 0 0 - noqu1 -; -#X floatatom 536 365 5 0 0 0 - qu2 -; -#X obj 236 666 pdp_affine; -#X floatatom 314 667 5 0 0 0 - - -; -#X floatatom 358 667 5 0 0 0 - - -; -#X msg 208 719 display 81.66.163.16:0; -#X obj 481 671 pdp_ffmpeg~; -#X msg 589 686 starve; -#X obj 76 654 pdp_i 2003; -#X obj 512 506 tgl 15 0 empty charc1 empty 0 -6 0 8 -262144 -1 -1 1 -1; -#X obj 436 527 pdp_spigot; -#X obj 459 556 pdp_charcoal; -#X floatatom 525 536 5 0 0 0 - charc2 -; -#X obj 26 198 pdp_scale 320 240; -#X msg 298 694 pos 0 0; -#X msg 353 693 dim 1024 768; -#X floatatom 151 205 5 0 0 0 - - -; -#X obj 582 642 adc~; -#X floatatom 459 707 5 0 0 0 - - -; -#X floatatom 499 705 5 0 0 0 - - -; -#X floatatom 537 704 5 0 0 0 - - -; -#X msg 179 484 1; -#X obj 221 479 loadbang; -#X msg 587 708 feed http://localhost:8090/feed1.ffm; -#X obj 403 624 pdp_rec~; -#X text 478 164 Load; -#X obj 73 96 r openp; -#X obj 73 119 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 +#X obj 596 196 pdp_spigot; +#X floatatom 639 240 5 0 0 0 - noqu2 -; +#X obj 597 218 pdp_noquark; +#X floatatom 596 240 5 0 0 0 - noqu1 -; +#X floatatom 550 240 5 0 0 0 - qu2 -; +#X obj 250 541 pdp_affine; +#X floatatom 328 542 5 0 0 0 - - -; +#X floatatom 372 542 5 0 0 0 - - -; +#X msg 222 594 display 81.66.163.16:0; +#X obj 495 546 pdp_ffmpeg~; +#X msg 603 561 starve; +#X obj 251 570 pdp_glx; +#X obj 90 529 pdp_i 2003; +#X obj 526 381 tgl 15 0 empty charc1 empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 450 402 pdp_spigot; +#X obj 473 431 pdp_charcoal; +#X floatatom 539 411 5 0 0 0 - charc2 -; +#X obj 40 73 pdp_scale 320 240; +#X msg 312 569 pos 0 0; +#X msg 367 568 dim 1024 768; +#X floatatom 165 80 5 0 0 0 - - -; +#X obj 618 506 adc~; +#X floatatom 473 582 5 0 0 0 - - -; +#X floatatom 513 580 5 0 0 0 - - -; +#X floatatom 551 579 5 0 0 0 - - -; +#X msg 193 359 1; +#X obj 235 354 loadbang; +#X obj 417 499 pdp_rec~; +#X obj 22 579 pdp_glx; +#X text 492 39 Load; +#X obj 86 13 openpanel; +#X obj 84 -16 r openp; +#X obj 45 -7 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 -1; -#X obj 145 97 r loop; -#X obj 307 93 r ventanaabr; -#X obj 145 122 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 1 -1; -#X obj 284 96 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 +#X obj 166 -16 r loop; +#X obj 333 -12 r ventanaabr; +#X obj 141 0 tgl 15 0 empty empty empty 20 8 0 8 -262144 -1 -1 0 1 +; +#X obj 294 -41 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 -1; -#X msg 200 123 stop; -#X obj 199 95 r stopenlat; -#X obj 6 -646 cnv 15 180 150 empty empty :::Enlatados::: 20 20 1 20 --257472 -1 0; -#X obj 188 -648 cnv 15 400 600 empty empty ::::Effectos:::: 20 20 1 +#X msg 220 6 stop; +#X obj 209 -18 r stopenlat; +#X obj -7 -364 cnv 15 120 100 empty empty :::Enlatados::: 2 10 1 12 +-198007 -1 0; +#X obj 114 -364 cnv 15 550 310 empty empty ::::Efectos:::: 20 20 1 20 -224508 -1 0; -#X text 234 -615 Aging; -#X obj 274 -614 tgl 15 0 aging empty empty 0 -6 0 8 -262144 -1 -1 0 +#X text 160 -331 Aging; +#X obj 200 -330 tgl 15 0 aging empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X text 229 -598 Baltan; -#X obj 274 -596 tgl 15 0 baltan empty empty 0 -6 0 8 -262144 -1 -1 +#X text 155 -314 Baltan; +#X obj 200 -312 tgl 15 0 baltan empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X text 240 -581 Edge; -#X obj 274 -579 tgl 15 0 edge empty empty 0 -6 0 8 -262144 -1 -1 0 +#X text 166 -297 Edge; +#X obj 200 -295 tgl 15 0 edge empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X floatatom 297 -614 5 0 0 0 - - ag1; -#X floatatom 338 -614 5 0 0 0 - - ag2; -#X floatatom 297 -596 10 0 0 0 - - balt1; -#X text 209 -563 Intrusion; -#X obj 274 -561 tgl 15 0 intr1 empty empty 0 -6 0 8 -262144 -1 -1 0 +#X floatatom 223 -330 5 0 0 0 - - ag1; +#X floatatom 264 -330 5 0 0 0 - - ag2; +#X floatatom 223 -312 10 0 0 0 - - balt1; +#X text 135 -279 Intrusion; +#X obj 200 -277 tgl 15 0 intr1 empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X floatatom 297 -561 5 0 0 0 - - intr2; -#X obj 336 -561 bng 15 250 50 0 intrbang empty BANG 18 8 1 12 -258699 +#X floatatom 223 -277 5 0 0 0 - - intr2; +#X obj 262 -277 bng 15 250 50 0 intrbang empty BANG 18 8 1 12 -62784 -1 -1; -#X obj 344 283 bng 15 250 50 0 empty intrbang empty 0 -6 0 8 -262144 +#X obj 358 158 bng 15 250 50 0 empty intrbang empty 0 -6 0 8 -262144 -1 -1; -#X text 240 -546 Lens; -#X obj 274 -544 tgl 15 0 lens empty empty 0 -6 0 8 -262144 -1 -1 0 +#X text 166 -262 Lens; +#X obj 200 -260 tgl 15 0 lens empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 274 -526 tgl 15 0 mosaic empty empty 0 -6 0 8 -262144 -1 -1 +#X obj 200 -242 tgl 15 0 mosaic empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 274 -508 tgl 15 0 dice empty empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 200 -224 tgl 15 0 dice empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 274 -491 tgl 15 0 simura empty empty 0 -6 0 8 -262144 -1 -1 +#X obj 200 -207 tgl 15 0 simura empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 297 -544 tgl 15 0 lensmove empty Move 18 8 1 8 -262144 -1 -258699 +#X obj 223 -260 tgl 15 0 lensmove empty Move 18 8 1 8 -262144 -1 -62784 0 1; -#X text 227 -528 Mosaic; -#X obj 334 -527 bng 15 250 50 0 mosaicbang empty BANG 18 8 1 12 -258699 +#X text 153 -244 Mosaic; +#X obj 260 -243 bng 15 250 50 0 mosaicbang empty BANG 18 8 1 12 -62784 -1 -1; -#X floatatom 297 -526 5 0 0 0 - - mosaic2; -#X obj 576 287 bng 15 250 50 0 empty mosaicbang empty 0 -6 0 8 -262144 +#X floatatom 223 -242 5 0 0 0 - - mosaic2; +#X obj 590 162 bng 15 250 50 0 empty mosaicbang empty 0 -6 0 8 -262144 -1 -1; -#X text 240 -510 Dice; -#X floatatom 297 -508 5 0 0 0 - - dice2; -#X text 226 -493 Simura; -#X floatatom 297 -491 5 0 0 0 - - simura2; -#X obj 274 -473 tgl 15 0 ripple empty empty 0 -6 0 8 -262144 -1 -1 +#X text 166 -224 Dice; +#X floatatom 223 -224 5 0 0 0 - - dice2; +#X text 152 -209 Simura; +#X floatatom 223 -207 5 0 0 0 - - simura2; +#X obj 200 -189 tgl 15 0 ripple empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X text 226 -476 Ripple; -#X obj 376 -474 bng 15 250 50 0 ripplebang empty BANG 18 8 1 12 -258699 +#X text 152 -192 Ripple; +#X obj 306 -191 bng 15 250 50 0 ripplebang empty BANG 18 8 1 12 -62784 -1 -1; -#X floatatom 339 -474 5 0 0 0 - - rip2; -#X floatatom 297 -474 5 0 0 0 - - rip1; -#X obj 239 360 bng 15 250 50 0 empty ripplebang empty 0 -6 0 8 -262144 +#X floatatom 265 -190 5 0 0 0 - - rip2; +#X floatatom 223 -190 5 0 0 0 - - rip1; +#X obj 253 235 bng 15 250 50 0 empty ripplebang empty 0 -6 0 8 -262144 -1 -1; -#X obj 274 -456 tgl 15 0 rev empty empty 0 -6 0 8 -262144 -1 -1 0 1 +#X obj 200 -172 tgl 15 0 rev empty empty 0 -6 0 8 -262144 -1 -1 0 1 ; -#X floatatom 339 -456 5 0 0 0 - - rev2; -#X floatatom 297 -456 5 0 0 0 - - rev1; -#X text 244 -457 Rev; -#X floatatom 424 -456 5 0 0 0 - - rev4; -#X floatatom 381 -456 5 0 0 0 - - rev3; -#X obj 274 -437 tgl 15 0 radiac empty empty 0 -6 0 8 -262144 -1 -1 +#X floatatom 265 -172 5 0 0 0 - - rev2; +#X floatatom 223 -172 5 0 0 0 - - rev1; +#X text 170 -173 Rev; +#X floatatom 350 -172 5 0 0 0 - - rev4; +#X floatatom 307 -172 5 0 0 0 - - rev3; +#X obj 200 -153 tgl 15 0 radiac empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X floatatom 339 -437 5 0 0 0 - - radi2; -#X floatatom 297 -437 5 0 0 0 - - radi1; -#X text 197 -438 Radioactive; -#X obj 274 -419 tgl 15 0 quark empty empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X floatatom 339 -419 5 0 0 0 - - qu2; -#X floatatom 297 -419 5 0 0 0 - - qu1; -#X text 232 -420 Quark; -#X obj 274 -401 tgl 15 0 noquark empty empty 0 -6 0 8 -262144 -1 -1 +#X floatatom 265 -153 5 0 0 0 - - radi2; +#X floatatom 223 -153 5 0 0 0 - - radi1; +#X text 123 -154 Radioactive; +#X obj 200 -135 tgl 15 0 quark empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X floatatom 265 -135 5 0 0 0 - - qu2; +#X floatatom 223 -135 5 0 0 0 - - qu1; +#X text 158 -136 Quark; +#X obj 200 -117 tgl 15 0 noquark empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X floatatom 339 -401 5 0 0 0 - - noqu2; -#X floatatom 297 -401 5 0 0 0 - - noqu1; -#X text 222 -402 NoQuark; -#X obj 296 -382 tgl 15 0 nervous1 empty empty 0 -6 0 8 -262144 -1 -1 +#X floatatom 265 -117 5 0 0 0 - - noqu2; +#X floatatom 223 -117 5 0 0 0 - - noqu1; +#X text 148 -118 NoQuark; +#X obj 222 -98 tgl 15 0 nervous1 empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X floatatom 319 -382 5 0 0 0 - - nervous2; -#X obj 274 -382 tgl 15 0 nervous empty empty 0 -6 0 8 -262144 -1 -1 +#X floatatom 245 -98 5 0 0 0 - - nervous2; +#X obj 200 -98 tgl 15 0 nervous empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X text 222 -383 Nervous; -#X obj 274 -363 tgl 15 0 shaga empty empty 0 -6 0 8 -262144 -1 -1 0 +#X text 148 -99 Nervous; +#X obj 200 -79 tgl 15 0 shaga empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X floatatom 297 -363 5 0 0 0 - - shaga1; -#X text 201 -363 Shagadelic; -#X floatatom 296 -327 5 0 0 0 - - spi1; -#X obj 296 -346 hdl 15 1 0 8 empty empty empty 0 -6 0 8 -262144 -1 +#X floatatom 223 -79 5 0 0 0 - - shaga1; +#X text 127 -79 Shagadelic; +#X floatatom 456 -294 5 0 0 0 - - spi1; +#X obj 456 -313 hdl 15 1 0 8 empty empty empty 0 -6 0 8 -262144 -1 -1 0; -#X floatatom 337 -328 5 0 0 0 - - spi2; -#X floatatom 380 -328 5 0 0 0 - - spi3; -#X floatatom 297 -309 5 0 0 0 - - spi4; -#X floatatom 339 -310 5 0 0 0 - - spi5; -#X obj 381 -310 tgl 15 0 spi6 empty empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X text 201 -363 Shagadelic; -#X obj 274 -346 tgl 15 0 spiral empty empty 0 -6 0 8 -262144 -1 -1 +#X floatatom 497 -295 5 0 0 0 - - spi2; +#X floatatom 540 -295 5 0 0 0 - - spi3; +#X floatatom 457 -276 5 0 0 0 - - spi4; +#X floatatom 499 -277 5 0 0 0 - - spi5; +#X obj 541 -277 tgl 15 0 spi6 empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X text 127 -79 Shagadelic; +#X obj 434 -313 tgl 15 0 spiral empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X text 228 -344 Spiral; -#X obj 339 -491 hdl 15 1 0 8 empty empty empty 0 -6 0 8 -262144 -1 +#X text 388 -311 Spiral; +#X obj 265 -207 hdl 15 1 0 8 empty empty empty 0 -6 0 8 -262144 -1 -1 0; -#X obj 432 -475 s simura3; -#X obj -6 315 r simura3; -#X obj 419 -332 s spirale; -#X obj 3 500 r spirale; -#X obj 398 -310 tgl 15 0 spi7 empty empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X obj 274 -292 tgl 15 0 under empty empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X floatatom 297 -292 5 0 0 0 - - under2; -#X text 201 -290 Underwatch; -#X obj 274 -274 tgl 15 0 verti empty empty 0 -6 0 8 -262144 -1 -1 0 -1; -#X floatatom 297 -274 5 0 0 0 - - verti1; -#X floatatom 339 -274 5 0 0 0 - - verti2; -#X text 220 -274 Vertigo; -#X floatatom 297 -256 5 0 0 0 - - warh2; -#X floatatom 341 -256 5 0 0 0 - - warh3; -#X obj 297 -240 hdl 15 1 0 9 empty empty empty 0 -6 0 8 -262144 -1 +#X obj 364 -192 s simura3; +#X obj 8 190 r simura3; +#X obj 579 -298 s spirale; +#X obj 17 375 r spirale; +#X obj 558 -277 tgl 15 0 spi7 empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 434 -259 tgl 15 0 under empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X floatatom 457 -259 5 0 0 0 - - under2; +#X text 361 -257 Underwatch; +#X obj 434 -241 tgl 15 0 verti empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X floatatom 457 -241 5 0 0 0 - - verti1; +#X floatatom 499 -241 5 0 0 0 - - verti2; +#X text 380 -241 Vertigo; +#X floatatom 499 -224 5 0 0 0 - - warh2; +#X floatatom 457 -224 5 0 0 0 - - warh3; +#X obj 457 -207 hdl 15 1 0 9 empty empty empty 0 -6 0 8 -262144 -1 -1 0; -#X floatatom 297 -222 5 0 0 0 - - warh4; -#X floatatom 338 -222 5 0 0 0 - - warh5; -#X floatatom 377 -222 5 0 0 0 - - warh6; -#X obj 274 -258 tgl 15 0 warh1 empty empty 0 -6 0 8 -262144 -1 -1 0 +#X floatatom 457 -189 5 0 0 0 - - warh4; +#X floatatom 498 -189 5 0 0 0 - - warh5; +#X floatatom 537 -189 5 0 0 0 - - warh6; +#X obj 434 -223 tgl 15 0 warh1 empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X text 220 -257 Warhol; -#X obj 326 477 r warh; -#X obj 421 -223 s warh; -#X obj 296 -204 tgl 15 0 warp2 empty empty 0 -6 0 8 -262144 -1 -1 0 +#X text 387 -222 Warhol; +#X obj 340 352 r warh; +#X obj 580 -192 s warh; +#X obj 456 -171 tgl 15 0 warp2 empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X floatatom 319 -204 5 0 0 0 - - warp3; -#X obj 274 -204 tgl 15 0 warp1 empty empty 0 -6 0 8 -262144 -1 -1 0 +#X floatatom 479 -171 5 0 0 0 - - warp3; +#X obj 434 -171 tgl 15 0 warp1 empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X text 224 -205 Warp; -#X obj 296 -183 tgl 15 0 cyc2 empty empty 0 -6 0 8 -262144 -1 -1 0 +#X text 401 -172 Warp; +#X obj 456 -150 tgl 15 0 cyc2 empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 274 -183 tgl 15 0 cyc1 empty empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 434 -150 tgl 15 0 cyc1 empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 341 -183 tgl 15 0 cyc4 empty empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 501 -150 tgl 15 0 cyc4 empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 319 -183 tgl 15 0 cyc3 empty empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 479 -150 tgl 15 0 cyc3 empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X text 224 -184 Cycle; -#X obj 274 -162 tgl 15 0 transf empty empty 0 -6 0 8 -262144 -1 -1 +#X text 393 -151 Cycle; +#X obj 434 -129 tgl 15 0 transf empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 299 -162 hdl 15 1 0 6 empty empty empty 0 -6 0 8 -262144 -1 +#X obj 459 -129 hdl 15 1 0 6 empty empty empty 0 -6 0 8 -262144 -1 -1 0; -#X obj 410 -145 s transf; -#X obj 623 485 r transf; -#X text 195 -162 Transform; -#X obj 273 -140 tgl 15 0 ascii1 empty empty 0 -6 0 8 -262144 -1 -1 +#X obj 551 -114 s transf; +#X obj 637 360 r transf; +#X text 364 -129 Transform; +#X obj 433 -107 tgl 15 0 ascii1 empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X floatatom 297 -140 5 0 0 0 - - ascii2; -#X text 223 -141 Ascii; -#X obj 273 -121 tgl 15 0 charc1 empty empty 0 -6 0 8 -262144 -1 -1 -1 1; -#X floatatom 297 -121 5 0 0 0 - - charc2; -#X text 206 -122 Charcoal; -#X obj 273 -102 tgl 15 0 puzz1 empty empty 0 -6 0 8 -262144 -1 -1 1 -1; -#X floatatom 297 -102 5 0 0 0 - - puzz2; -#X text 206 -103 Puzzle; -#X obj 356 -102 bng 15 250 50 0 left empty empty 0 -6 0 8 -262144 -1 +#X floatatom 457 -107 5 0 0 0 - - ascii2; +#X text 392 -108 Ascii; +#X obj 434 -332 tgl 15 0 charc1 empty empty 0 -6 0 8 -262144 -1 -1 +0 1; +#X floatatom 458 -332 5 0 0 0 - - charc2; +#X text 366 -333 Charcoal; +#X obj 434 -84 tgl 15 0 puzz1 empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X floatatom 458 -84 5 0 0 0 - - puzz2; +#X text 386 -85 Puzzle; +#X obj 507 -84 bng 15 250 50 0 left empty empty 0 -6 0 8 -62784 -1 -1; -#X obj 371 -117 bng 15 250 50 0 up empty empty 0 -6 0 8 -262144 -1 +#X obj 522 -99 bng 15 250 50 0 up empty empty 0 -6 0 8 -62784 -1 -1 +; +#X obj 536 -85 bng 15 250 50 0 right empty empty 0 -6 0 8 -62784 -1 -1; -#X obj 385 -103 bng 15 250 50 0 right empty empty 0 -6 0 8 -262144 --1 -1; -#X obj 371 -88 bng 15 250 50 0 down empty empty 0 -6 0 8 -262144 -1 +#X obj 522 -70 bng 15 250 50 0 down empty empty 0 -6 0 8 -62784 -1 -1; -#X obj 794 576 bng 15 250 50 0 empty left empty 0 -6 0 8 -262144 -1 +#X obj 808 451 bng 15 250 50 0 empty left empty 0 -6 0 8 -262144 -1 -1; -#X obj 809 561 bng 15 250 50 0 empty up empty 0 -6 0 8 -262144 -1 -1 +#X obj 823 436 bng 15 250 50 0 empty up empty 0 -6 0 8 -262144 -1 -1 ; -#X obj 823 575 bng 15 250 50 0 empty right empty 0 -6 0 8 -262144 -1 +#X obj 837 450 bng 15 250 50 0 empty right empty 0 -6 0 8 -262144 -1 -1; -#X obj 809 590 bng 15 250 50 0 empty down empty 0 -6 0 8 -262144 -1 +#X obj 823 465 bng 15 250 50 0 empty down empty 0 -6 0 8 -262144 -1 -1; -#X obj 140 -557 bng 15 250 50 0 ventanaabr empty empty 20 8 0 8 -262144 --1 -1; -#X obj 140 -580 tgl 15 0 loop empty empty 20 8 0 8 -262144 -1 -1 1 -1; -#X obj 139 -601 bng 15 250 50 0 openp empty empty 20 8 0 8 -262144 +#X obj 91 -307 bng 15 250 50 0 ventanaabr empty empty 20 8 0 8 -262144 -1 -1; -#X text 93 -603 Cargar; -#X text 43 -558 Abrir ventana; -#X text 99 -534 Parar; -#X text 105 -581 Loop; -#X obj 140 -535 bng 15 250 50 0 stopenlat empty empty 0 -6 0 8 -262144 +#X obj 91 -325 tgl 15 0 loop empty empty 20 8 0 8 -262144 -1 -1 0 1 +; +#X obj 91 -343 bng 15 250 50 0 openp empty empty 20 8 0 8 -262144 -1 +-1; +#X text 45 -345 Cargar; +#X text -5 -308 Abrir ventana; +#X text 51 -288 Parar; +#X text 57 -326 Loop; +#X obj 91 -289 bng 15 250 50 0 stopenlat empty empty 0 -6 0 8 -262144 -1 -1; -#X obj 8 -490 cnv 15 180 150 empty empty :::Webcam::: 20 20 1 20 -228992 +#X obj -7 -263 cnv 15 120 85 empty empty :::Webcam::: 2 10 1 12 -258740 -1 0; -#X obj 140 -423 bng 15 250 50 0 webcam1 empty empty 20 8 0 8 -262144 +#X obj 88 -220 bng 15 250 50 0 webcam1 empty empty 20 8 0 8 -262144 +-1 -1; +#X obj 88 -238 bng 15 250 50 0 loadwebcam empty empty 20 8 0 8 -262144 +-1 -1; +#X text 47 -201 Parar; +#X obj 88 -202 bng 15 250 50 0 webcam2 empty empty 0 -6 0 8 -262144 +-1 -1; +#X obj 583 12 bng 15 250 50 0 empty loadwebcam empty 0 -6 0 8 -262144 +-1 -1; +#X text 49 -220 Live; +#X obj 553 61 bng 15 250 50 0 empty webcam2 empty 0 -6 0 8 -262144 -1 -1; -#X obj 141 -445 bng 15 250 50 0 loadwebcam empty empty 20 8 0 8 -262144 +#X obj 665 -363 cnv 15 100 310 empty empty :::Zoom::: 2 10 1 12 -225271 +-1 0; +#X obj 680 -83 bng 15 250 50 0 zoom1 empty empty 20 8 0 8 -62784 -1 +-1; +#X obj 237 332 bng 15 250 50 0 empty zoom1 empty 0 -6 0 8 -262144 -1 +-1; +#X text 700 -82 Zoom 1:1; +#X obj 612 538 bng 15 250 50 0 empty starve empty 0 -6 0 8 -262144 -1 -1; -#X text 99 -400 Parar; -#X obj 140 -401 bng 15 250 50 0 webcam2 empty empty 0 -6 0 8 -262144 +#X obj 686 540 bng 15 250 50 0 empty stream empty 0 -6 0 8 -262144 -1 -1; -#X obj 569 137 bng 15 250 50 0 empty loadwebcam empty 0 -6 0 8 -262144 +#X obj -7 -177 cnv 15 120 110 empty empty :::Stream::: 2 10 1 12 -220278 +-1 0; +#X obj 87 -158 bng 15 250 50 0 stream empty empty 20 8 0 8 -262144 -1 -1; -#X text 101 -422 Live; -#X obj 539 186 bng 15 250 50 0 empty webcam2 empty 0 -6 0 8 -262144 +#X text 46 -135 Parar; +#X obj 87 -136 bng 15 250 50 0 starve empty empty 0 -6 0 8 -262144 -1 -1; -#X obj 240 688 pdp_xv; -#X obj 72 138 openpanel; -#X text 22 -447 Abrir /dev/video; +#X text 366 -333 Charcoal; +#X text 33 -157 Stream; +#X text 194 108 comment; +#X obj 678 -323 vsl 15 200 1.27 127 0 0 zoomtot empty Total -3 -8 0 +8 -44832 -1 -1 0 1; +#X obj 706 -324 vsl 15 200 -100 100 0 0 zoomv empty Horiz -4 -8 0 8 +-262144 -1 -1 0 1; +#X obj 732 -324 vsl 15 200 0 127 0 0 zoomh empty Vert -1 -8 0 8 -262144 +-1 -90133 0 1; +#X text -3 -239 Abrir camara; +#X msg 601 585 feed http://media1.fadaiat.net:8090/feed1.ffm; #X connect 0 0 4 0; #X connect 1 0 4 0; #X connect 2 0 3 1; #X connect 3 0 4 0; -#X connect 4 0 190 0; -#X connect 4 3 193 0; +#X connect 4 0 191 0; +#X connect 4 3 194 0; #X connect 4 4 163 0; #X connect 4 5 163 1; -#X connect 5 0 190 0; +#X connect 5 0 191 0; #X connect 6 0 5 0; #X connect 7 0 6 0; #X connect 8 0 6 0; @@ -600,7 +628,7 @@ #X connect 111 0 201 0; #X connect 112 0 201 0; #X connect 113 0 201 0; -#X connect 114 0 352 0; +#X connect 114 0 185 0; #X connect 115 0 114 0; #X connect 116 0 179 0; #X connect 117 0 116 1; @@ -654,9 +682,9 @@ #X connect 162 0 201 0; #X connect 164 0 171 0; #X connect 165 0 166 1; -#X connect 166 0 187 0; +#X connect 166 0 188 0; #X connect 166 1 167 0; -#X connect 167 0 187 0; +#X connect 167 0 188 0; #X connect 168 0 167 1; #X connect 169 0 47 1; #X connect 170 0 43 2; @@ -671,55 +699,57 @@ #X connect 176 0 46 0; #X connect 177 0 176 1; #X connect 178 0 47 2; -#X connect 179 0 201 0; -#X connect 179 0 352 0; +#X connect 179 0 185 0; #X connect 179 0 183 0; +#X connect 179 0 201 0; #X connect 180 0 179 1; #X connect 181 0 179 2; -#X connect 182 0 352 0; -#X connect 183 0 195 0; -#X connect 183 1 196 0; -#X connect 183 2 197 0; +#X connect 182 0 185 0; +#X connect 183 0 196 0; +#X connect 183 1 197 0; +#X connect 183 2 198 0; #X connect 184 0 183 0; -#X connect 185 0 352 0; -#X connect 186 0 187 1; -#X connect 187 0 116 0; -#X connect 187 1 188 0; +#X connect 186 0 185 0; +#X connect 187 0 188 1; #X connect 188 0 116 0; -#X connect 189 0 188 1; -#X connect 190 0 11 0; -#X connect 191 0 352 0; -#X connect 192 0 352 0; -#X connect 194 0 183 0; -#X connect 194 1 183 1; -#X connect 198 0 118 0; -#X connect 199 0 198 0; -#X connect 200 0 183 0; +#X connect 191 0 11 0; +#X connect 192 0 185 0; +#X connect 193 0 185 0; +#X connect 195 0 183 0; +#X connect 195 1 183 1; +#X connect 199 0 118 0; +#X connect 199 0 124 0; +#X connect 199 0 120 0; +#X connect 200 0 199 0; #X connect 201 0 110 0; -#X connect 203 0 204 0; -#X connect 204 0 353 0; -#X connect 205 0 207 0; -#X connect 206 0 208 0; -#X connect 207 0 0 0; -#X connect 208 0 3 0; -#X connect 209 0 3 0; -#X connect 210 0 209 0; -#X connect 226 0 25 0; -#X connect 236 0 38 0; -#X connect 246 0 63 0; -#X connect 273 0 285 0; -#X connect 282 0 283 0; -#X connect 284 0 72 0; -#X connect 286 0 76 0; -#X connect 297 0 304 0; -#X connect 303 0 100 0; -#X connect 315 0 316 0; -#X connect 317 0 139 0; -#X connect 332 0 155 0; -#X connect 333 0 153 0; -#X connect 334 0 156 0; -#X connect 335 0 154 0; -#X connect 349 0 9 0; -#X connect 351 0 8 0; -#X connect 353 0 1 0; +#X connect 204 0 1 0; +#X connect 205 0 206 0; +#X connect 206 0 204 0; +#X connect 207 0 209 0; +#X connect 208 0 210 0; +#X connect 209 0 0 0; +#X connect 210 0 3 0; +#X connect 211 0 3 0; +#X connect 212 0 211 0; +#X connect 228 0 25 0; +#X connect 238 0 38 0; +#X connect 248 0 63 0; +#X connect 275 0 287 0; +#X connect 284 0 285 0; +#X connect 286 0 72 0; +#X connect 288 0 76 0; +#X connect 299 0 306 0; +#X connect 305 0 100 0; +#X connect 317 0 318 0; +#X connect 319 0 139 0; +#X connect 334 0 155 0; +#X connect 335 0 153 0; +#X connect 336 0 156 0; +#X connect 337 0 154 0; +#X connect 351 0 9 0; +#X connect 353 0 8 0; +#X connect 356 0 199 0; +#X connect 358 0 184 0; +#X connect 359 0 371 0; +#X connect 371 0 183 0; #X coords 0 0 0.00151515 0.00153374 200 140 0; diff --git a/patches/help_pdp_effects_rack.pd b/patches/help_pdp_effects_rack.pd index 7654ac3..4c47cbb 100644 --- a/patches/help_pdp_effects_rack.pd +++ b/patches/help_pdp_effects_rack.pd @@ -1,4 +1,4 @@ -#N canvas 4 0 986 675 10; +#N canvas 39 1 986 675 10; #X obj 230 7 bng 15 250 50 0 empty empty empty 20 8 0 8 -262144 -1 -1; #X msg 150 44 loop \$1; @@ -139,7 +139,7 @@ #X floatatom 481 407 5 0 0 0 - - -; #X floatatom 527 407 5 0 0 0 - - -; #X floatatom 572 407 5 0 0 0 - - -; -#X obj 618 365 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 618 365 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 1 1; #X floatatom 638 366 5 0 0 0 - - -; #X obj 618 345 pdp_warp; @@ -156,16 +156,16 @@ 1; #X obj 19 544 pdp_zoom; #X floatatom 68 500 5 0 0 0 - - -; -#X obj 152 436 hsl 300 15 0.01 100 1 1 empty empty empty -2 -6 0 8 --262144 -1 -1 15104 1; +#X obj 119 437 hsl 300 15 0.01 100 1 1 empty empty empty -2 -6 0 8 +-262144 -1 -1 15314 1; #X floatatom 122 547 5 0 0 0 - - -; -#X obj 146 487 hsl 300 15 0.01 100 1 1 empty empty empty -2 -6 0 8 --262144 -1 -1 14200 1; +#X obj 118 484 hsl 300 15 0.01 100 1 1 empty empty empty -2 -6 0 8 +-262144 -1 -1 15200 1; #X msg 165 522 zoomx \$1; #X msg 164 548 zoomy \$1; #X floatatom 124 523 5 0 0 0 - - -; -#X obj 150 460 hsl 300 15 0.01 100 1 1 empty empty empty -2 -6 0 8 --262144 -1 -1 14800 1; +#X obj 118 460 hsl 300 15 0.01 100 1 1 empty empty empty -2 -6 0 8 +-262144 -1 -1 15900 1; #X msg 278 588 centerx \$1; #X floatatom 281 562 5 0 0 0 - - -; #X floatatom 363 560 5 0 0 0 - - -; @@ -217,11 +217,11 @@ #X msg 568 588 framerate 10; #X obj 246 93 dac~; #X floatatom 312 21 5 0 0 0 - - -; -#X obj 754 432 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 791 432 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 1 1; -#X obj 675 443 pdp_spigot; -#X obj 674 466 pdp_ascii; -#X floatatom 744 467 5 0 0 0 - - -; +#X obj 712 443 pdp_spigot; +#X obj 711 466 pdp_ascii; +#X floatatom 781 467 5 0 0 0 - - -; #X floatatom 580 272 5 0 0 0 - - -; #X floatatom 829 266 5 0 0 0 - - -; #X obj 313 44 t b f; @@ -243,17 +243,27 @@ #X msg 421 687 starve; #X obj 285 641 pdp_xv; #X obj 102 601 pdp_i 2003; -#X obj 598 433 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +#X obj 660 435 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 1; -#X obj 519 444 pdp_spigot; -#X obj 518 467 pdp_charcoal; -#X floatatom 613 468 5 0 0 0 - - -; +#X obj 581 446 pdp_spigot; +#X obj 581 467 pdp_charcoal; +#X floatatom 669 468 5 0 0 0 - - -; #X obj 45 82 pdp_scale 320 240; #X msg 355 646 pos 0 0; #X msg 418 645 dim 1024 768; #X floatatom 197 93 5 0 0 0 - - -; -#X msg 233 409 1; -#X obj 272 411 loadbang; +#X msg 204 411 1; +#X obj 240 411 loadbang; +#X obj 511 429 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 432 440 pdp_spigot; +#X floatatom 508 448 5 0 0 0 - - -; +#X obj 432 467 pdp_disintegration; +#X floatatom 537 428 5 0 0 0 - - -; +#X obj 776 498 openpanel; +#X obj 848 499 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 +-1; +#X msg 714 498 load \$1; #X connect 0 0 8 0; #X connect 1 0 9 0; #X connect 2 0 1 0; @@ -471,12 +481,21 @@ #X connect 189 0 116 0; #X connect 194 0 193 0; #X connect 195 0 196 1; -#X connect 196 0 122 0; +#X connect 196 0 206 0; #X connect 196 1 197 0; -#X connect 197 0 122 0; +#X connect 197 0 206 0; #X connect 198 0 197 1; #X connect 199 0 16 0; #X connect 200 0 193 0; #X connect 201 0 193 0; #X connect 203 0 124 0; #X connect 204 0 203 0; +#X connect 205 0 206 1; +#X connect 206 0 122 0; +#X connect 206 1 208 0; +#X connect 207 0 208 1; +#X connect 208 0 122 0; +#X connect 209 0 208 2; +#X connect 210 0 212 0; +#X connect 211 0 210 0; +#X connect 212 0 173 0; diff --git a/system/pidip.c b/system/pidip.c index 8a62a6f..21c8d2d 100644 --- a/system/pidip.c +++ b/system/pidip.c @@ -64,6 +64,16 @@ extern "C" void pdp_shape_setup(void); void pdp_spotlight_setup(void); void pdp_colorgrid_setup(void); + void pdp_binary_setup(void); + void pdp_erode_setup(void); + void pdp_dilate_setup(void); + void pdp_hitandmiss_setup(void); + void pdp_disintegration_setup(void); + void pdp_distance_setup(void); + void pdp_theorin_tilde_setup(void); + void pdp_theorout_tilde_setup(void); + void pdp_cropper_setup(void); + void pdp_background_setup(void); #ifdef HAVE_PIDIP_FFMPEG void pdp_ffmpeg_tilde_setup(void); @@ -135,6 +145,16 @@ void pidip_setup(void){ pdp_shape_setup(); pdp_spotlight_setup(); pdp_colorgrid_setup(); + pdp_binary_setup(); + pdp_erode_setup(); + pdp_dilate_setup(); + pdp_hitandmiss_setup(); + pdp_disintegration_setup(); + pdp_distance_setup(); + pdp_theorin_tilde_setup(); + pdp_theorout_tilde_setup(); + pdp_cropper_setup(); + pdp_background_setup(); #ifdef HAVE_PIDIP_FFMPEG pdp_ffmpeg_tilde_setup(); |