UI: Fix alt-crop not working with X/Y flipped sources
This commit is contained in:
parent
3cb36bbd51
commit
75e43069cc
@ -742,6 +742,16 @@ void OBSBasicPreview::SnapStretchingToScreen(vec3 &tl, vec3 &br)
|
|||||||
br.y += offset.y;
|
br.y += offset.y;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static float maxfunc(float x, float y)
|
||||||
|
{
|
||||||
|
return x > y ? x : y;
|
||||||
|
}
|
||||||
|
|
||||||
|
static float minfunc(float x, float y)
|
||||||
|
{
|
||||||
|
return x < y ? x : y;
|
||||||
|
}
|
||||||
|
|
||||||
void OBSBasicPreview::CropItem(const vec2 &pos)
|
void OBSBasicPreview::CropItem(const vec2 &pos)
|
||||||
{
|
{
|
||||||
obs_bounds_type boundsType = obs_sceneitem_get_bounds_type(stretchItem);
|
obs_bounds_type boundsType = obs_sceneitem_get_bounds_type(stretchItem);
|
||||||
@ -773,31 +783,34 @@ void OBSBasicPreview::CropItem(const vec2 &pos)
|
|||||||
stretchItemSize.x + crop.right * scale.x,
|
stretchItemSize.x + crop.right * scale.x,
|
||||||
stretchItemSize.y + crop.bottom * scale.y);
|
stretchItemSize.y + crop.bottom * scale.y);
|
||||||
|
|
||||||
vec2_max((vec2*)&pos3, (vec2*)&pos3, &max_br);
|
typedef std::function<float (float, float)> minmax_func_t;
|
||||||
vec2_min((vec2*)&pos3, (vec2*)&pos3, &max_tl);
|
|
||||||
|
minmax_func_t min_x = scale.x < 0.0f ? maxfunc : minfunc;
|
||||||
|
minmax_func_t min_y = scale.y < 0.0f ? maxfunc : minfunc;
|
||||||
|
minmax_func_t max_x = scale.x < 0.0f ? minfunc : maxfunc;
|
||||||
|
minmax_func_t max_y = scale.y < 0.0f ? minfunc : maxfunc;
|
||||||
|
|
||||||
|
pos3.x = min_x(pos3.x, max_br.x);
|
||||||
|
pos3.x = max_x(pos3.x, max_tl.x);
|
||||||
|
pos3.y = min_y(pos3.y, max_br.y);
|
||||||
|
pos3.y = max_y(pos3.y, max_tl.y);
|
||||||
|
|
||||||
if (stretchFlags & ITEM_LEFT) {
|
if (stretchFlags & ITEM_LEFT) {
|
||||||
tl.x = pos3.x;
|
|
||||||
|
|
||||||
float maxX = stretchItemSize.x - (2.0 * scale.x);
|
float maxX = stretchItemSize.x - (2.0 * scale.x);
|
||||||
if (tl.x > maxX) pos3.x = tl.x = maxX;
|
pos3.x = tl.x = min_x(pos3.x, maxX);
|
||||||
} else if (stretchFlags & ITEM_RIGHT) {
|
|
||||||
br.x = pos3.x;
|
|
||||||
|
|
||||||
|
} else if (stretchFlags & ITEM_RIGHT) {
|
||||||
float minX = (2.0 * scale.x);
|
float minX = (2.0 * scale.x);
|
||||||
if (br.x < minX) pos3.x = br.x = minX;
|
pos3.x = br.x = max_x(pos3.x, minX);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (stretchFlags & ITEM_TOP) {
|
if (stretchFlags & ITEM_TOP) {
|
||||||
tl.y = pos3.y;
|
|
||||||
|
|
||||||
float maxY = stretchItemSize.y - (2.0 * scale.y);
|
float maxY = stretchItemSize.y - (2.0 * scale.y);
|
||||||
if (tl.y > maxY) pos3.y = tl.y = maxY;
|
pos3.y = tl.y = min_y(pos3.y, maxY);
|
||||||
} else if (stretchFlags & ITEM_BOTTOM) {
|
|
||||||
br.y = pos3.y;
|
|
||||||
|
|
||||||
|
} else if (stretchFlags & ITEM_BOTTOM) {
|
||||||
float minY = (2.0 * scale.y);
|
float minY = (2.0 * scale.y);
|
||||||
if (br.y < minY) pos3.y = br.y = minY;
|
pos3.y = br.y = max_y(pos3.y, minY);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define ALIGN_X (ITEM_LEFT|ITEM_RIGHT)
|
#define ALIGN_X (ITEM_LEFT|ITEM_RIGHT)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user