Revision: 49617 http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=49617 Author: genscher Date: 2012-08-06 13:40:29 +0000 (Mon, 06 Aug 2012) Log Message: ----------- Patch [#32246] (Bugfix): UV editor -> "Proportional edit" together with "constrain to bounds" does not work.
Patch reviewed by Campbell Barton. Thanks! Modified Paths: -------------- trunk/blender/source/blender/editors/transform/transform.c trunk/blender/source/blender/editors/transform/transform.h trunk/blender/source/blender/editors/transform/transform_conversions.c Modified: trunk/blender/source/blender/editors/transform/transform.c =================================================================== --- trunk/blender/source/blender/editors/transform/transform.c 2012-08-06 13:37:25 UTC (rev 49616) +++ trunk/blender/source/blender/editors/transform/transform.c 2012-08-06 13:40:29 UTC (rev 49617) @@ -2932,6 +2932,14 @@ for (i = 0, td = t->data; i < t->total; i++, td++) ElementResize(t, td, mat); + + /* In proportional edit it can happen that */ + /* vertices in the radius of the brush end */ + /* outside the clipping area */ + /* XXX HACK - dg */ + if(t->flag & (T_PROP_EDIT | T_PROP_CONNECTED)) { + clipUVData(t); + } } recalcData(t); @@ -3787,9 +3795,18 @@ applyTranslation(t, t->values); /* evil hack - redo translation if clipping needed */ - if (t->flag & T_CLIP_UV && clipUVTransform(t, t->values, 0)) + if (t->flag & T_CLIP_UV && clipUVTransform(t, t->values, 0)) { applyTranslation(t, t->values); + /* In proportional edit it can happen that */ + /* vertices in the radius of the brush end */ + /* outside the clipping area */ + /* XXX HACK - dg */ + if(t->flag & (T_PROP_EDIT | T_PROP_CONNECTED)) { + clipUVData(t); + } + } + recalcData(t); ED_area_headerprint(t->sa, str); Modified: trunk/blender/source/blender/editors/transform/transform.h =================================================================== --- trunk/blender/source/blender/editors/transform/transform.h 2012-08-06 13:37:25 UTC (rev 49616) +++ trunk/blender/source/blender/editors/transform/transform.h 2012-08-06 13:40:29 UTC (rev 49617) @@ -562,6 +562,7 @@ void flushTransUVs(TransInfo *t); void flushTransParticles(TransInfo *t); int clipUVTransform(TransInfo *t, float *vec, int resize); +void clipUVData(TransInfo *t); void flushTransNodes(TransInfo *t); void flushTransSeq(TransInfo *t); void flushTransTracking(TransInfo *t); Modified: trunk/blender/source/blender/editors/transform/transform_conversions.c =================================================================== --- trunk/blender/source/blender/editors/transform/transform_conversions.c 2012-08-06 13:37:25 UTC (rev 49616) +++ trunk/blender/source/blender/editors/transform/transform_conversions.c 2012-08-06 13:40:29 UTC (rev 49617) @@ -2494,6 +2494,26 @@ return (clipx || clipy); } +void clipUVData(TransInfo *t) +{ + TransData *td = NULL; + int a; + float aspx, aspy; + + ED_space_image_get_uv_aspect(t->sa->spacedata.first, &aspx, &aspy); + + for (a = 0, td = t->data; a < t->total; a++, td++) { + if (td->flag & TD_NOACTION) + break; + + if ((td->flag & TD_SKIP) || (!td->loc)) + continue; + + td->loc[0] = MIN2(MAX2(0.0f, td->loc[0]), aspx); + td->loc[1] = MIN2(MAX2(0.0f, td->loc[1]), aspy); + } +} + /* ********************* ANIMATION EDITORS (GENERAL) ************************* */ /* This function tests if a point is on the "mouse" side of the cursor/frame-marking */ _______________________________________________ Bf-blender-cvs mailing list Bf-blender-cvs@blender.org http://lists.blender.org/mailman/listinfo/bf-blender-cvs