Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBrecht Van Lommel <brechtvanlommel@pandora.be>2005-12-01 15:45:17 +0300
committerBrecht Van Lommel <brechtvanlommel@pandora.be>2005-12-01 15:45:17 +0300
commita09fbc080dea64078a6cfb307a720194ee30e6db (patch)
treed1b3d61b00d95522d4496b3b029f6a2da9cc7743 /source/blender/src/unwrapper.c
parent1a59b16b4831987a12906a1821755c4b249287bb (diff)
Small addition to stretch minimize: with pad +/- or the wheel mouse
you can now blend between the original and minimized. Stretch minimizing trades conformality (= perfect squares in checkerboard texture) for a better sampling of the texture (= often not so well shaped checkerboard), so it is useful to let the user find a balance between the two.
Diffstat (limited to 'source/blender/src/unwrapper.c')
-rw-r--r--source/blender/src/unwrapper.c42
1 files changed, 37 insertions, 5 deletions
diff --git a/source/blender/src/unwrapper.c b/source/blender/src/unwrapper.c
index 7b61e8f51f0..b74181cb385 100644
--- a/source/blender/src/unwrapper.c
+++ b/source/blender/src/unwrapper.c
@@ -1457,7 +1457,7 @@ void minimize_stretch_tface_uv(void)
Mesh *me;
ParamHandle *handle;
double lasttime;
- short doit = 1, val;
+ short doit = 1, escape = 0, val, blend = 0;
unsigned short event = 0;
me = get_mesh(OBACT);
@@ -1474,15 +1474,47 @@ void minimize_stretch_tface_uv(void)
while (qtest()) {
event= extern_qread(&val);
- if (val && (event==ESCKEY || event==RETKEY || event==PADENTER))
- doit = 0;
+
+ if (val) {
+ switch (event) {
+ case ESCKEY:
+ escape = 1;
+ case RETKEY:
+ case PADENTER:
+ doit = 0;
+ break;
+ case PADPLUSKEY:
+ case WHEELUPMOUSE:
+ if (blend < 10) {
+ blend++;
+ param_stretch_blend(handle, blend*0.1f);
+ lasttime = 0.0f;
+ }
+ break;
+ case PADMINUS:
+ case WHEELDOWNMOUSE:
+ if (blend > 0) {
+ blend--;
+ param_stretch_blend(handle, blend*0.1f);
+ lasttime = 0.0f;
+ }
+ break;
+ }
+ }
+ else if ((event == LEFTMOUSE) || (event == RIGHTMOUSE)) {
+ escape = (event == RIGHTMOUSE);
+ doit = 0;
+ }
}
if (!doit)
break;
if (PIL_check_seconds_timer() - lasttime > 0.5) {
- headerprint("Enter to finish. Escape to cancel.");
+ char str[100];
+
+ sprintf(str, "Stretch minimize. Blend %.2f.", blend*0.1f);
+ headerprint(str);
lasttime = PIL_check_seconds_timer();
if(G.sima->lock) force_draw_plus(SPACE_VIEW3D, 0);
@@ -1490,7 +1522,7 @@ void minimize_stretch_tface_uv(void)
}
}
- param_stretch_end(handle, event==ESCKEY);
+ param_stretch_end(handle, escape);
param_delete(handle);