Blender Git Commit Log

Git Commits -> Revision 104ab9b

Revision 104ab9b by Ton Roosendaal (master)
January 8, 2006, 11:41 (GMT)
Orange:

- New UI element: the "Curve Button".

For mapping ranges (like 0 - 1) to another range, the curve button can be
used for proportional falloff, bone influences, painting density, etc.
Most evident use is of course to map RGB color with curves.

To be able to use it, you have to allocate a CurveMapping struct and pass
this on to the button. The CurveMapping API is in the new C file
blenkernel/intern/colortools.c
It's as simple as calling:

curvemap= curvemapping_add(3, 0, 0, 1, 1)

Which will create 3 curves, and sets a default 0-1 range. The current code
only supports up to 4 curves maximum per mapping struct.
The CurveMap button in Blender than handles allmost all editing.
Evaluating a single channel:

float newvalue= curvemapping_evaluateF(curvemap, 0, oldval);

Where the second argument is the channel index, here 0-1-2 are possible.
Or mapping a vector:

curvemapping_evaluate3F(curvemap, newvec, oldvec);

Optimized versions for byte or short mapping is possible too, not done yet.

In butspace.c I've added a template wrapper for buttons around the curve, to
reveil settings or show tools; check this screenie:

http://www.blender.org/bf/curves.jpg

- Buttons R, G, B: select channel
- icons + and -: zoom in, out
- icon 'wrench': menu with tools, like clear curve, set handle type
- icon 'clipping': menu with clip values, and to dis/enable clipping
- icon 'x': delete selection

In the curve button itself, only LMB clicks are handled (like all UI elements
in Blender).

- click on point: select
- shift+click on point: swap select
- click on point + drag: select point (if not selected) and move it
- click outside point + drag: translate view
- CTRL+click: add new point
- hold SHIFT while dragging to snap to grid
(Yes I know... either one of these can be Blender compliant, not both!)
- if you drag a point exactly on top of another, it merges them

Other fixes:

- Icons now draw using "Safe RasterPos", so they align with pixel boundary.
the old code made ints from the raster pos coordinate, which doesn't work
well for zoom in/out situations

- bug in Node editing: buttons could not get freed, causing in memory error
prints at end of a Blender session. That one was a very simple, but nasty
error causing me all evening last night to find!
(Hint; check diff of editnode.c, where uiDoButtons is called)

Last note: this adds 3 new files in our tree, I did scons, but not MSVC!

Commit Details:

Full Hash: 104ab9b103ab30ca87ccb9e739a58863fc29d3bf
SVN Revision: 6342
Parent Commit: 32e21f4
Lines Changed: +2811, -1573

3 Added Paths:

/source/blender/blenkernel/BKE_colortools.h (+50, -0) (View)
/source/blender/blenkernel/intern/colortools.c (+469, -0) (View)
/source/blender/makesdna/DNA_color_types.h (+74, -0) (View)

19 Modified Paths:

/source/blender/blenkernel/BKE_node.h (+2, -0) (Diff)
/source/blender/blenkernel/intern/node.c (+33, -11) (Diff)
/source/blender/blenkernel/intern/node_shaders.c (+61, -1) (Diff)
/source/blender/blenkernel/SConscript (+1, -0) (Diff)
/source/blender/blenloader/intern/readfile.c (+20, -0) (Diff)
/source/blender/blenloader/intern/writefile.c (+19, -2) (Diff)
/source/blender/include/BIF_interface.h (+2, -0) (Diff)
/source/blender/include/BIF_resources.h (+2, -2) (Diff)
/source/blender/include/butspace.h (+3, -0) (Diff)
/source/blender/include/interface.h (+2, -2) (Diff)
/source/blender/makesdna/intern/makesdna.c (+2, -0) (Diff)
/source/blender/src/blenderbuttons.c (+1544, -1544) (Diff)
/source/blender/src/butspace.c (+191, -0) (Diff)
/source/blender/src/buttons_editing.c (+3, -2) (Diff)
/source/blender/src/drawnode.c (+17, -2) (Diff)
/source/blender/src/editnode.c (+22, -5) (Diff)
/source/blender/src/interface.c (+161, -0) (Diff)
/source/blender/src/interface_draw.c (+128, -1) (Diff)
/source/blender/src/interface_icons.c (+5, -1) (Diff)
By: Miika HämäläinenLast update: Nov-07-2014 14:18MiikaHweb | 2003-2021