GEM ONLINE DOCUMENTATION CHAPTER 5: RELEASE NOTES --------------------------------------------------------------- ---------------------------- 0.91 ----------------------------- this is the first release for 3 years, codename 'tigital' it includes many changes, so probably i have forgotten most... openGL runtime checks: GEM now uses GLEW to detect openGL-features at runtime this allows you to use all the cool features of your brand-new graphics card with the same binary as you used for your old gfx-card...cool w32-installer: there is now a w32 installer (based on NSIS) to ease the installation of GEM on windows. single vs dual context: GEM uses a dual context approach to establish a valid openGL-context at startup; you can now turn this OFF by setting the environmental variable "GEM_SINGLE_CONTEXT=1" this should allow you to work if GEM crashes otherwise SIMD: better MMX/SSE2 handling pixes: fiducial tracking, artoolkit, multitexture, texture sharing recording streams of images into movies, better movie reading support, better video in support, more sophisticated pix_buffer handling shared memory objects text: allow unicode characters use vera.ttf as default font instead of the copyrighted arial.ttf allow to override the default font with the environment variable "GEM_DEFAULT_FONT" bugfixes: like always we have removed (and introduced) numerous bugs, so all in all GEM should now run more stable for an incomplete list of fixed bug see the bug-tracker at http://sourceforge.net/projects/pd-gem openGL: generally use openGL-2.0 (if available) vertex/fragment shaders (GLSL and ARB/NV) framebuffers deletion: MarkEX has been removed from GEM and is now available as a separate library; hardware-interfacing objects like [gemorb] and [gemtablet] have been removed ---------------------------- 0.90 ----------------------------- this is the same as 0.888 just a naming issue --------------------------------------------------------------- ---------------------------- 0.888 ---------------------------- this has taken a long time (2 years...) development is now done by several people: chris clepper günter geiger daniel heckenberg james tittle IOhannes m zmölnig <zmoelnig@iem.at> günter has removed himself from the splash-screen, but he still contributes stuff supported platforms: windows (XP,2000,...), linux, and (tadah:) macOS-X(>10.2) irix-support seems to be broken, but i cannot prove it architecture: up till now, the rendering-tree was statically built when rendering was turned on, so you couldn't add objects dynamically and editing was painful. now, Gem utilizes the normal pd-messaging system all the time: you can disable parts of the rendering tree with [spigot], render sub-trees multiple times with [t a a] and put objects into the gem-tree on the fly. documentation: added help for (almost ?) all Gem-objects (excluding openGL-wrappers) new reference-patches are now working out of the box (not the old "abstract" way) added a small pdf-tutorial openGL: GEM features now a full openGL-wrapper (supporting openGL-1.2) you can use any openGL-command like "glNormal3f" by creating a pd-object like [GEMglNormal3f] (note the "GEM"-prefix); this should be very powerful, however most of the objects are not (yet) tested. if you intend to use them and think they don't work, send me a bug report for the objects you need; i will try to fix them gradually. there will be not much help in GEM, since you might consult any openGL-reference text: we now use FTGL instead of GLTT (which is still available at compile time) for freetype-rendering. this is supported on all 3 platforms, looks better (at all sizes!) and allows the new [textextruded] geos: tube, curve3d, rubber, ripple, slideSquares, newWave manips: polygon_smooth for anti-aliasing of single objects [camera] controls: the output of [gemmouse] can now be normalized (by giving the maxVal for x/y as arguments: [gemmouse 1 1] will output coordinates between 0..1, no matter what dimensions the screen has. particles: now the underlying libparticle-engine can be used more directly. velocity-domains (like [part_velcone]) are deprecated and [part_velocity] should be used instead (allowing on-the-fly domain-switching) there are objects that allow to influence single particles (like [part_vertex]) most interesting: with [part_render] and [part_info] you can now use any geo as particles (e.g: .obj-models) not only points/lines as before. texturing: [pix_texture] and [pix_texture2] has merged. so [pix_texture] will texture textures of any size (even non-power-of-2) and it will use hw-support if available (at least on macOS and on linux if the gfx-card supports it (at least nvidia does so)) pixes: lots of new objects (too much to enumerate them here) we now support 3 different colorspaces: RGBA, YUV, Greyscale YUV is new and allows processing of coloured-images with far less memory/CPU than RGBA (factor 2) but without alpha. lots of pix-processing on apple-computers is ALTIVEC-enhanced (faster by numbers!) SIMD-enhancements for PCs (MMX/SSE2) is yet to come... as the new colorspace has been pushed, also a lot of objects has received greyscale-support the TV-class has been deprecated and is now part of pix_* again lot's of color-space converters (most of them not available as objects) the "pix_fx"-stuff is now built into all pix-objects video: on mac-OS the [pix_video] object supports all cameras that are supported by the OS on windows there is now support for DirectShow, which makes new (usb/ieee1394) cameras work most probably on linux there is some prelaminary(!) support for ieee1394 devices. the v4l-support is now multi-threaded which speeds up the whole thing significantly film-formats: windows: AVI; there is also some QUICKTIME-support (needs the quicktime-sdk at compile time and quicktime installed on execution time), but this crashes sometimes (haven't found out when). it should enable "a lot" of file-formats (MPEG, MOV) macOS: quicktime serves your needs linux: support for libavifile, libmpeg3 (or libmpeg1 but libmpeg3 is preferred), libquicktime (or libquicktime4linux; doesn't matter) and ffmpeg. codecs: macOS: everything that is supported by your system should work fine win: all codecs installed on your machine should work (if another program can play a avi-file, Gem should be able to do so too) linux: depends on how you compiled Gem. libmpegX will decode mpegs, libquicktime will (most likely) decode quicktime-files with non-proprietary codecs, libavifile decodes a lot of formats (avi, quicktime, divx, asf,...) and you can utilize windows-codecs (.dll-files; if you have them ;-)) which enables you to play-back proprietary codecs! bug-fixes: probably lots of, but most of them seem to linger around for a while now. --------------------------------------------------------------- ---------------------------- 0.87 ----------------------------- Added much documentation Added [gemkeyboard] and [gemkeyname] for keyboard-interaction in the GEM-window. However, Windows and Linux versions do not give the same results... Added Red/Green stereo Cleaned up the stereo-thing. we can switch between the different stereo-modes (including no-stereo) while rendering You can set the title of the GEM-window with the "title"-message. Up till now only one symbol is allowed. Added "fullscreen" mode Fixed "border" under linux "cursor" is now available on Windoze readded "externals" with additional libraries to close up with the windows version:: Added pix_movie for Linux (mpeg2+quicktime-support) Added pix_film, which is in fact like pix_movie but does not write the pix-buf directly into a texture Fixed the model Added the stupid "teapot" Added a pix_write that let's you capture the current screen into a file (TIFF/JPEG) Added pix_hsv2rgb, pix_rgb2hsv (colour-space converters) Added pix_blob (center of gravity:: colour detection) Added pix_curves, pix_histo Added pix_set, pix_dump Added pix_pix2sig~, pix_sig2pix~ Started a new class "tv" for pix-operations that change over time: like tv_movement (formerly: pix_movement), tv_biquad, tv_rtx; but i am not really happy with this... Started a new pix_fx class for inserting pix-FX. there is not much about it, but you can now bend the image.data pointer to wherever you like (including size-changes, format-changes) it will be bent back in the postrender()-thing Started to import classes from effecTV (by Fukuchi Kentarou): pix_aging, pix_puzzle; most of his FX are real crap, but some are ok and it's easy to import them Made a pix_rgba --------------------------------------------------------------- ---------------------------0.84-5 ----------------------------- Bugfixes for gemwin "cursor" message (cursor [1|0]) Removed "externals" with additional libraries, they are separated now Added a "freq" and "mode" message to Linux video object, you can watch TV now ... It is possible to add the display to the create command for X windows, whole initialization stuff is moved into the create method, so you can look at the patches without having succesfully generated an OpenGl context. Made the pix_video and pix_movie into real base classes of OS specific classes. The OS spezific classes for Windows and SGI have to be fixed .. --------------------------------------------------------------- --------------------------0.84a ----------------------------- text2d: added a message "alias", which toggles between antialiases and standard fonts. Usage "alias 1" or "alias 0" gemwin: additional message cursor, which hides the cursor in GEM windows --------------------------------------------------------------- ---------------------------- 0.84 ----------------------------- Fixed a bug where delete [] was called instead of delete. This could explain a lot of random crashes. Fixed camera message routing. --------------------------------------------------------------- ---------------------------- 0.84 ----------------------------- I long time ago, I changed the behavior for gemhead, so that matrices where automatically restored, etc. However, this broke the camera object. Use the view message to gemwin instead. Fixed a bug in GemMan. If you didn't use "border 0" and you requested a window size with "dimen # #", then the window size was likely to be wrong. This is now fixed. Fixed a bug in the view message to gemwin. There was an offset which should not have occurred. You might need to change your view messages to account for it. Just subtract 4 from any Z values. There are some examples for pix_snap in examples/gemAdvanced/gemPixSnap.pd - Single buffered example examples/gemAdvanced/gemPixSnap2.pd - Double buffered example Keep in mind that pix_snap is a fairly slow operation...I also fixed a nasty memory bug which could easily cause crashes. I added Miller Puckette's pix_video for linux into the code base. If you load a movie in pix_movie with an open message, the object will output the number of frames to the right output. This will not work if you have a "pix_movie homer.avi" for your object since the output message cannot get processed correctly at startup. The disk object has an inlet on the rightmost side for the inner radius...turning the disk into a ring. If the inner radius value is just 0., then the disk is just a circle. Fog can be turned on in gemwin. Look at examples/gemAdvanced/gemFog.pd for examples. The various control messages are documented in the gemwin.pd help patch. These next objects are thanks to hannes - mailto:zmoelnig@iem.mhsg.ac.at --------------------------- Added OpenGL material objects - ambient, ambientRGB, diffuse, diffuseRGB, emission, emissionRGB, shininess, specular, specularRGB They provide much greater control over the color of objects. Look at examples/gemLighting/gem5.materials.pd for examples. Guenter found a bug in the ortho object. It is now fixed. The ortho object has the same general unit size as the normal perspective matrix. Look at examples/gemAdvanced/gemOrtho.pd for how to use the object. --------------------------------------------------------------- ---------------------------- 0.83 ----------------------------- Added another outlet to counter. When the counter reaches the "count to" value, the right outlet will send a bang. The bang happens after the left inlet sends its float. Fixed a dumb bug in pix_2grey. It didn't calculate the number of pixels correctly. Adding some comments to the FAQ that pix_draw is almost always slower than pix_texture on PCs. Basically, graphics accelerators do not accelerate glDrawPixels(). Added rectangle and cylinder. Cleaned up the text objects (text3d, etc). Should display text a bit better and manage memory more intelligently. These next objects are thanks to hannes - mailto:zmoelnig@iem.mhsg.ac.at --------------------------- Added pix_rectangle - creates a rectangle in a pix Added pix_a_2grey - only changes the pixel to grey based on the alpha component. See the help page and the example in manual/gem_pix/gemAlphaGrey.pd --------------------------------------------------------------- ---------------------------- 0.82 ----------------------------- Free-view sterescopic rendering is possible. If you send 'createStereo' message to the gemwin instead of a 'create' message, then your rendering area will be split in two. Send a 'stereoSep float' message to set the stereo seperation. Send a 'stereoFoc float' message to set the focal distance. See the example patch gem_advanced/gemStereo.pd patch for an example. 'color' message was registered twice in gemwin. The second should have been a 'perspec' message, for perspective. This also fixes the error which pd-0.29 gives about GEM now. primTri is a new object. It is a triangle primtive. Unlike the normal triangle object, it has 6 inlets. The first three inlets are for setting the vertex positions. The last three inlets are for setting the color at each vertex. The color can be either RGB or RGBA values. Look at gem_advanced/gemPrimTri.pd for an example. The particle objects are now frame rate independent. If you needed them to run at a certain speed, you can send a multiplier into part_head with the message 'speed float'. Run the fountain at 60fps to see how smooth it is. The particles still default to 20fps, which is GEM's default. You can slow down the particle systems or speed them up by sending a different speed value into the part_head. Thanks to Guenter for making the sgi image loader 64-bit compliant. Received new Gnu makefiles for Linux from Guenter. new particle objects - These all have help files. See gem_particles/gem6.target.pd for how the target objects work. part_damp - apply a damping force to the particles part_targetcolor - Change color of the particles toward the specified color. part_targetsize - Change size of the particles toward the specified size. Added some help files, mainly for the particle objects. Updated the FAQ. --------------------------------------------------------------- ---------------------------- 0.81 ----------------------------- On WinNT, you can remove the window border. Send a 'border 0' message to gemwin to remove it, or a 'border 1' to put it back. The default includes the border. Fixed some bugs when in single buffer mode and in the pix_snap object. A bunch more help documentation is done. This includes reference pages and the html manual pages. The inlets for alternate and counter were backwards. Integrated unix event handling into the code base. Fixed other random bugs. --------------------------------------------------------------- ---------------------------- 0.80 ----------------------------- A real manual has been started! This means that the doc directory will not be as important. The release notes will still be here and few of the other doc files, but hopefully most people will just be able to use the on-line manual. Look at gem/manual/index.html to get started. pix_movie has been added. It automatically does the texture mapping so you don't need to use pix_texture. This also means that you can't process the pix image. This will change in the future, but I wanted to get the object out and have people hammer on it. Also, only certain objects can texture the movie data correctly. They are square, triangle, circle, and cube. Cone and sphere will have a black region if the movie isn't a power of two (most movies are 320x160 or something). This will be fixed in the future. See gem_pix/gemMovie.pd for an example hsv2rgb and rgb2hsv have been added. There is no ambient lighting in the default case. If you want to have ambient lighting, send a message "ambient r g b" to gemwin. On WinNT, if you hit Ctrl + r in the GEM window, then rendering will stop. This does not go through the normal Pd interface, so it can be used if you accidentally create a patch which takes so much processing that you cannot turn it off because the patch UI is unresponsive. Fixed a really bad bug in the text rendering objects. Various other random bugs. --------------------------------------------------------------- ---------------------------- 0.79 ----------------------------- The example patches have been organized a little bit. There is now a collection of directories which are installed with GEM. Eventually, they will be fleshed out a lot more (I hope), but for the time being, at least there is some order to them. The model and multimodel objects accept a "rescale 0" or "rescale 1" message. In previous versions, the model objects would resize your model to fit within the unit cube (all vertices where within -1 to 1). This made it dificult to coordinate diferent model files together, because they would all be resized by diferent factors. Now, if you send a "rescale 0" message into model or multimodel, it will not do resizing for any _SUBSEQUENT_ loading. In other words, if you have already loaded in a model, and you send a "rescale 0", the currently loaded model (or models) will not change. Look at the example patch gem_advanced/gemModelRescale.pd for how this works. The left model chain is much larger and a scaleXYZ object with a value of .1 is needed to even get the model into the viewport. The model and multimodel objects default to "rescale 1" so that it doesn't break any existing patches. The middle and right buttons work in gemtablet now. The outlets are all pretty close together now, so until you can resize objects, it will be difficult to select the correct outlet. Look in examples/gemTablet.pd for all of the outlets. I have upgraded to Visual C++ 6.0. I doubt that the GEM library is backwards compatible for people who are writing their own libraries. Sorry, but the IDE is a little less painful in 6.0. I removed the position inlet from the light object. If you want to move/rotate a world_light/light, then just put a translate or rotate object into the chain. It was broken before, but now there is no reason for the position inlet. light and world_light accept a "debug" message with a value of 1 or 0. Look at the gemLightSphere.pd patch for an example. It was too hard to figure out where the light is, and this turns on a sphere for the light object (since it is a point light), and a cone for the world_light object (since it is a directional light). The world_light is NOT a spot light, even though its icon is a cone. The icons are the color of the light. MarkEx has been merged into GEM. I was tired of maintaining two libraries. Also, people didn't seem to be downloading MarkEx, and there are a lot of good objects in there, IMHO. The camera object is finally useable. It has an inlet for the translation and rotation vectors. Anyone who was using it before is now broken, but the change was very necessary. gemwin can accept a perspective message. This will set up the viewing paramaters for the window. You need to pass in 6 floats with the "perspective" message, for the left, right, bottom, top, front, and back. The defaults are -1., 1., -1., 1., 1., 20. If you send a reset message to gemwin, it will reset the perspective values as well. The big change in this release is a particle system. It is based on code from David McAllister. There are many new object, all of which interact in certain ways. One design issue is that there are far too many controls and variables to be able to expose directly in GEM. People who want to get complete control over all aspects of the particle system are going to need to write their own externals. However, most people should be fine with the particle objects. The new objects are: CREATION -------- part_head - The start of a particle group part_color - Set the range of colors for the new particles part_size - Set the size of new particles part_velsphere - Set the velocity based on a sphere distribution You need 4 args - xvel, yvel, zvel, and radius part_velcone - Set the velocity based on a cone distribution part_source - Generate particles MANIP ----- part_follow - Particles will follow each other like a snake part_gravity - Have the particles accelerate in a direction part_killold - Remove particles past a certain age part_killslow - Remove particles below a certain speed part_orbitpoint - Orbit the particles around a specified point part_draw - Apply the actions and render the particles. Accepts a message "draw line" or "draw point" to change the drawing style. Look in the example files to get some idea how to use the particle objects. Notice that you still need a gemhead starting off the chain, but after that, you just use the part_* objects. Regular GEM manips like rotate, translateXYZ, and scale will affect the particles. In general, you start with part_head, then modify the particle parameters with the creation objects like part_color and part_velocity. Then use part_source to actual generate the particles. Next in the chain, use the manip objects to control the particles behavior. When you actually want to display the particles, use part_draw. Make sure that you remove particles as well. The best method is probably with part_killold. If you don't remove particles, then you will eventually not be able to add any new ones (the default number of particles at once is 1000, set by part_head). You can also slow down the rate of the particle generation with the part_source object. --------------------------------------------------------------- ---------------------------- 0.78 ----------------------------- If you don't want GEM to take control of the tablet if it finds one, set the environment variable GEM_NO_TABLET to the value "1" (no quotes of course). There will be a print out if GEM finds the environment variable. I added a few more setup access function so that people who use "-lib gem" or "-lib GEM" will work correctly. Lighting will now work under single buffer mode, but you have to destroy then create the graphics window to change the mode. This will not work with the GEM_SINGLE_CONTEXT variable. pix_data is a new object. It outputs color information from a pix. The first inlet accepts a bang to trigger it. The second inlet accepts a gem list (probably from pix_image) The third inlet is the x position (between 0 and 1) The fourth inlet is the y position (between 0 and 1) The first outlet is the gem list The second outlet is the color (an RGB list) The third outlet is the gray scale value (a float) See the example patches gemPixDataSimple.pd and gemPixDataComplex.pd for possible use. Fixed a pretty bad bug in the SGI image loading. Basically, unless the image was RGBA, it was going to core dump. Also, the orientation was wrong. --------------------------------------------------------------- ---------------------------- 0.77 ----------------------------- GEM is now under the Gnu Public License. This should not affect any one. I also cleaned up the license information for the AuxLibs. All of the license and usage information can be found in GEM.LICENSE.TERMS GEM has a new home - http://www.danks.org/mark/GEM gemorb - a new object to interface with the SpaceTec SpaceOrb360. It is a 6DoF ball with 6 buttons that connects to your serial port. It is a very cool device, and is relatively cheap ($50 US). If gemorb is able to connect, it will print out a message, or an error if there is a problem. John Stone wrote the library. There is a particle system with a number of new objects. The system uses a library by David McAllister. ps I haven't had time to bring all of the objects online. particle is the only object right now. It just creates a fountain. accumrotate was added - three inlets to control the rotation. Each time a new value is sent in, it increases the rotation. Sending 'reset' to the leftmost inlet sets the rotation matrix to identity (ie, it resets it to no rotation). rotateXYZ was added - three inlets to control the rotation. Order is X rotation, then Y, then Z. The tablet cleanup is a little better now on WinNT. There are still some bugs, like it doesn't return to normal mouse usage after GEM exits. However, the DLL is being released correctly...I just need to reset to the default state somehow. Cone and sphere have changed behavior as of 0.77. The middle inlet is now the size and the right inlet is the number of slices. depth used to be sending '1' would turn on depth testing, but this was conceptually wrong. It should be 1 to turn on the depth object (which would disable depth testing). This is now the current behavior. ortho was added. It changes the viewing from perspective to orthogonal. The size is the size of the window with (0, 0) being the lower left corner. I made this object for creating a background the size of the window, but you can probably find other uses for it. There is a matrix class for those who are writing objects. It is in src/Base/Matrix. --------------------------------------------------------------- ---------------------------- 0.76 ----------------------------- Fixed a bug in spline-path. I wasn't doing the knot logic correctly. Thanks to Patrick Rost for finding this. A bunch of internal changes to get GEM working with Pd 0.22 All instances of A_INT went away and the inlets and outlets are created in the correct "logical" order now. --------------------------------------------------------------- ---------------------------- 0.75 ----------------------------- You can resize the window under WinNT and the viewport will change to reflect the new size. Also, the correct aspect ratio is maintained no matter what the width/height ratio is for the GEM window. The ratio is x:y -> (width/height):1. This is currently only under WinNT. gemmouse and gemtablet are new objects. They currently only work in WinNT. You should be able to create the object in the Irix/Linux versions, but you won't get any output. See gemmouse.pd and gemtablet.pd for examples. gemmouse outputs the current mouse position and button up/down for the GEM window. gemtablet outputs the current pen position, pressure, orientation, and pen up/down, with the GEM window mapped to the tablet. If GEM can connect to your tablet, a message will be printed at startup. If you don't see a message at startup from GEM about connecting to the tablet, then gemtablet will not output any values. You must have the wintab32.dll library installed. Your tablet's installation should do this. Added a bunch of utility functions (spline, bias functions, etc). linear_path and spline_path are new objects. If you give them an array, then they will generate a point from an index. linear_path will linearly interpolate between points. spline_path uses the points as knots for a curve. See gemSplinePath.pd and gemLinearPath.pd for examples. Added __declspec declarations for Windows. This should make it easy for people to use GEM as a dll. --------------------------------------------------------------- ---------------------------- 0.74 ----------------------------- I replaced the images in the example directory with JPGs. They are alot smaller. However, in gemMoveImages.pd, you can see the effect that the compression has. Look at the red dancer. All of the "black" should be alpha masked out, yet there are little bits which get all jaggy. Got gltt-1.8 Looks like it fixes a bunch of bugs. Finally put an alpha test into the alpha object. This means that if the alpha of a pixel == 0., then it won't be put written into the frame buffer. Look at the example file gemMoveImages.pd for an example of this. Notice that the dancer is texture mapped to a sphere, yet you can always see her correctly. You can disable this behavior by sending a 'test 0' to the alpha object. Oh boy, were my texture coordinates off. Unknown to me, my reference image (dancer.tif) was actually upside down. This meant that all of the texture coordinates in the Geos objects were compensating for the rotation. Sorry if this messes anyone up, but it is now correct for all of the geos. I also now load in images in OpenGL format. This means that data[0][0] == lower-left corner. This shouldn't have any effect on anyone unless you are doing position sensitive image processing. Fixed the orientation problem when using pix_draw. imageVert handles gray8 pixes Fixed a problem if pix_multiimage loaded in images that were different formats or sizes. GEM supports search paths! Basically, GEM will look for auxiliary files (images, models, fonts, etc.) from whatever directory the patch is in (unless you use an absolute path name with '/'). --------------------------------------------------------------- ---------------------------- 0.73 ----------------------------- Fixed profiling on Unix Added text2d, text3d, textoutline. The text objects will render a truetype font (I have provided a couple fonts in gem/examples). text2d renders a flat bitmap...no rotation or Z movement. text3d is full polygonal text, so you can translate and rotate. textoutline is also polygonal, it is just a vectored outline. PS text2d has some problems... JPEG and SGI image file formats are supported! Depending on the number of color components, GEM will automatically convert them to grayscale or RGBA (just like TIFF files). pix_video is working slightly on WinNT. There are still some serious problems, so consider this version a complete pre-alpha. I'm releasing a version now to find out if it even works on other systems. I am using a Connectix QuickCam2. Shifted all of the auxilary libraries into a common directory. Considering that I'm currently using 6 outside packages, it is just easier. --------------------------------------------------------------- ---------------------------- 0.72 ----------------------------- Did a bunch of cleaning so that the Linux compile is happier (and easier). This involved getting rid of some warning messages and changing the makefiles slightly. The strange core dump on WinNT went away... All of the code and extra files are under source code control (CVS). You can just ignore the CVS directories. Eventually, I will try to keep them out of the release build. Added profiling. If you send 'profile 1' to gemwin, then normal profiling is turned on (GEM displays the number of milliseconds per frame). If you send 'profile 2', then images will not be cached (ie, the pixes will always be processed). If you send 'profile 0', then profiling is turned off. pix_multiply multiplies the color components of two images together. It doesn't modify the alpha channel. Optimized pix code. Because Miller is removing the INT type, I have slowly been moving it out of the code. If any objects have stopped working, please let me know. I redid the construction macros in CPPExtern to reflect this change. If you have made any new GEM objects, you will probably need to change to the new macro format. Most of the dual input pix objects will process gray8 and RGBA data gracefully. --------------------------------------------------------------- ---------------------------- 0.71 ----------------------------- Guenter got GEM working under Linux! The biggest impact is that I have changed all of the #ifdef __sgi to #ifdef _UNIX_ If specific versions of Un*x need certain things, then they can be #ifdef'ed with __sgi, or LINUX, or whatever. Fixed a bug in polygon and curve. I'm not sure why it ever worked on the SGI... All pix objects accept a 0 or 1 to turn on and off their processing. The 0 or 1 should just be sent to the first inlet. The inlets were backwards for colorRGB. Fixed a bug in turning on and off texture mapping in pix_texture. GemMan::initGem is now called from Gem_setup. There seems to be a problem with Linux creating the dummy static class to initialize GEM. Changes pix_texture so that it deal with OpenGL 1.1, GL_EXT_texture_obj, and base OpenGL 1.0 I think that every OS has the texture_obj extension, but just in case, I also have the OpenGL 1.0 technique of display lists. Removed some spurious print outs. I looked into using GL_BGRA_EXT for images on Windows. It is faster in the software version, but my Intergraph card doesn't support it. It only makes a difference for OpenGL in software...and texture download time isn't the primary problem then. With a 512x512 image using glDrawPixels in software, I got 6 frames/sec with RGBA and 7 frames/sec with BGRA_EXT. Older SGIs like ABGR_EXT, but the newer machines want RGBA. Looks like I'm going to stick with RGBA for a while. You can now load in Gray8 and RGBA images and they will retain their format. Before, everything was slammed into an RGBA image, with A == 255. This means that you can have alpha masks on images, etc. The only pix object which can currently handle a gray8 is pix_mask. All of the other pixes throw errors if they get a gray8. This will slowly be fixed. Added some new functions to GemPixUtil (from a paper by Alvy Ray Smith). They should speed things up. Currently, only pix_composite is using them. The color channels of pixels should be gotten by the const ints that are in GemPixUtil (for instance, chRed, chGreen, etc). Using hard coded offsets like 0 or 2 for red and blue is asking for trouble. gemheads no longer push and pop the entire matrix state when renderGL is called. This should be faster (push/pop is slow on some platforms). Also, all objects are required to "reset" the OpenGL state when they are done, so it shouldn't be neccessary. Strangeness: There is an unreferenced memory exception on WinNT when you quit Pd. However, it only happens if you use pix_image. It doesn't happen while you are using Pd, only when you quit... --------------------------------------------------------------- ---------------------------- 0.70 ----------------------------- All geos can now accept a size argument (they default to 1.0) I cleaned up the texture coordinate mapping. The order was slightly random before. The order is more logical now; it is counterclockwise starting at 0, 0. If you use pix_coordinate any where, you will need to fix the values. Fixed a bug in translateXYZ. The inlets where backwards. You can now move the GEM window under NT. NT doesn't automatically take care of the basic window functions unless you pass the messages through (unlike X Windows). Texture mapping can be turned on and off by sending a 0 or 1 to pix_texture Texture mapping defaults to GL_LINEAR. Send a quality message to pix_texture to change this. A "quality 0" means GL_NEAREST, "quality 1" means GL_LINEAR. --------------------------------------------------------------- ---------------------------- 0.69 ----------------------------- Fixed a bunch of bugs in imageVert. Cleaned up some lingering problems in various objects (the open message to pix_multiimage didn't work as advertised for instance). Setting window color is now dynamic. multimodel now exists. Works just like pix_multiimage, only it reads in Alias/Wavefront files. It also has a caching mechanism. --------------------------------------------------------------- ---------------------------- 0.68 ----------------------------- fixed pix_2grey so it uses real color weights, instead of just averaging the three colors. pix_image now works the same way as pix_multiimage. If you load in an image which another pix_image has already loaded, they will share the image. This means that if you create a bunch of dummy pix_image objects, you can send an open message to pix_images which have a gemhead connected to them and get instantaneous image changes. Found a MAJOR bug in the NT version of pix_texture. Basically, if you used it, the program would core dump. Found another bug in square. It involved texture mapping and texture coordinates (mainly when you don't designate them). Changed the default values for scaleXYZ (to 1, 1, 1) and translateXYZ (to 0, 0, 0) --------------------------------------------------------------- ---------------------------- 0.67 ----------------------------- Forgot to add the arguments for the scale object. This has been fixed. Added translateXYZ, scaleXYZ, and colorRGB. These create three inlets which you can modify, instead of having to mess with vector messages. Fixed a bug in pix_image and pix_multiimage (or more, an unacceptable response to user error). Basically, if you started rendering without an image being loaded (or if an image failed to load, then you were _VERY_ likely to core dump. A check has been added, so this shouldn't be a problem anymore. pix_multiimage HAS CHANGED! It accepts up to four arguments: filename, number : will load the image files from 0 up to AND INCLUDING the number filename, lownum, highnum : will load the image files from the lownum up to AND INCLUDING the highnum filename, lownum, highnum, skiprate : will load the image files from the low num up to AND INCLUDING the highnum, but incrementing the counter by the skiprate, not by one. No matter how many images are loaded, you can change which image is displayed by sending a number. The number must be between 0 and the number of images which were loaded (notice that this number may not be the highnum!) If you try to display an image out of range, you will get an error. pix_multiimage now uses a shared cache. Basically, if you give two pix_multiimage objects the EXACT same values (filename, base number, top number and skip number), then they will use the same collection of images. This will save massive amounts of memory if there is any commonality between pix_multiimages. pix_flip - see help file --------------------------------------------------------------- ---------------------------- 0.66 ----------------------------- Finished the port to NT (mainly had to get images working). Made pix_colormatrix - This is really good for things like saturation, hue rotate, etc. I will eventually include a bunch of matrices to do cool stuff. Check out Paul Haeberli's paper on color matrices at http://www.sgi.com/grafica/index.html I removed pix_color. It was a hold over from earlier days and I don't think that anyone (including myself) is using it any more. I got a title bar onto the graphics window, but you still can't move it around. I am not certain why this is the case, but I'll keep looking. I made general speed ups to most of the pix objects. Mainly, I have been removing GetPixel() and SetPixel() functions (they have a lot of overhead). I will continue to use Get/SetPixel() while I'm developing because they make things easy to deal with, but as objects get finished, I will remove them. Some of the manipulators (color, rotate, and translate) accept arguments. For instance, if you do color 1 0 0, it will automatically set the color to red. The objects try to be intelligent about their arguments. For instance, if color receives three args, it sets RGB, but if it gets 4, it sets RGBA. If rotate or translate get 3 args, then they just set the vector, but if they get 4, then they set both the vector and the value. --------------------------------------------------------------- ---------------------------- 0.65 ----------------------------- GEM works under NT! I got the port working last night. I had to make some major changes to the underlying classes (specifically CPPExtern) because MS VisC++ puts the vtable pointer in the first four bytes...no matter what. This is a different behavior than SGI's compiler (and I think that it requires more work for MS VisC++'s compiler). While it was a pain to change things, it is good in the long run. The C++ standard doesn't say where the vtable is located, so this would have bitten me at some point. --------------------------------------------------------------- ---------------------------- 0.64 ----------------------------- Because MS VisC++ really wants files to end in .cpp (how stupid...), I renamed all of the C++ files. I looked into making all of the pixes be float, instead of unsigned char. This would give increased flexibility because we could use negative numbers, not worry about wrap around on the unsigned char, etc. In running performance tests on an SGI O2, the performance difference is fairly great. If GEM was only an image processing program (ie, PhotoShop), then I would definetely have pixes be floats. However, since GEM is meant for real-time, I will continue to use unsigned chars to represent pixels. For the tech heads...I used to generate the rendering by creating a linked list of the GEM objects. The problem was that objects like separator weren't possible because it wasn't a true DAG. That is now fixed so that tree/leaf graphs are possible. Made render_trigger so you can know exactly when the rendering is occuring. Made pix_multiimage! Just give it a file with a * (like myfiles*.tif) and an integer for a range (the number of images). Made pix_invert, separator --------------------------------------------------------------- ---------------------------- 0.63 ----------------------------- The src directory has been made into a tree. Made pix_add and pix_subtract Added a scale object --------------------------------------------------------------- ---------------------------- 0.62 ----------------------------- A dummy glxContext is created at startup. What this means is that in the constructors of objects, OpenGL calls can be made, display lists can be constructed, etc. Eventually, I would like to have a single window which is always in existance that can change between single and double buffering, but that may be a little while. I put Sam Leffler's tiff library back in. All image files must be in TIFF format again. Basically, I think that Win NT would have trouble making SGI .rgb files, while anyone can make TIFF formats. Currently there is some code bloat because libtiff does more than just read in a TIFF file. The pix_coordinate object allows users to set the S,T texture coordinates for geos. For instance, by giving pix_coordinate 4 S,T pairs, the texture coordinates for a square can be changed on the fly. Not all of the geos can support this ability right now (currently only square, triangle, and polygon, but this will change in the near future). A FAQ has been started, but there really aren't any questions in it yet. As people think of them, please let me know and I'll add them. --------------------------------------------------------------- ---------------------------- 0.61 ----------------------------- Cocoon html help files for developers have been created. GEM now uses an internally generated DAG for rendering. This removes a serious bug where by objects could still try to reference dangling pointers. GEM objects act like the tidle objects do from a users point of view. Even if you break a connection in a GEM chain, the GEM objects will continue to work. This means that it is safe to edit patches while a GEM chain is running. To rebuild the GEM patch, rendering must be turned off and then back on (just like the tilde objects). Using the td library from Evans & Sutherland by Nate Robbins to display Alias/Wavefront files (.obj). It also takes care of image loading, although it is only .rgb. If people complain enough, then I may return to the Sam's libTiff library, but it is so big that the td library is better. The td library can also be compiled on Windows (or else I wouldn't have used it). The new object is called model (although it may change its name some day). There is a new object which maps the color of a pix to the Z of a polygon. It is isn't overly useful right now, but it is a cool demo. It is called imageVert. --------------------------------------------------------------- ---------------------------- 0.60 ----------------------------- Major changes to the internals of GEM. gemwin is now only an access point to the window manager, instead of actually being the window manager. This should make it easier to have multiple graphics windows. While I was getting the O2 video camera to work, I seem to have broken the Indycam object... --------------------------------------------------------------- ---------------------------- 0.50 ----------------------------- Made the port from Max over to Pd. Redesigned the class heirarchy somewhat.