Вычислить размер вращающегося прямоугольника из известных координат ограничительной рамки - программирование
Подтвердить что ты не робот

Вычислить размер вращающегося прямоугольника из известных координат ограничительной рамки

Я прочитал http://goo.gl/HKMtO, чтобы узнать, как вычислить координаты ограничительной рамки из повернутого прямоугольника. Но в частном случае, как показано ниже:

http://i.stack.imgur.com/3UNfD.png

Как получить размер вращающегося прямоугольника, если он получил размер ограничительной рамки, corrdinates и степень вращения?

Я пытаюсь написать код в javascript

//assume w=123,h=98,deg=35 and get calculate box size
var deg = 35;
var bw = 156.9661922099485;
var bh = 150.82680201149986;

//calculate w and h
var xMax = bw / 2;
var yMax = bh / 2;
var radian = (deg / 180) * Math.PI;
var cosine = Math.cos(radian);
var sine = Math.sin(radian);
var cx = (xMax * cosine) + (yMax * sine)   / (cosine * cosine + sine * sine);
var cy =  -(-(xMax * sine)  - (yMax * cosine) / (cosine * cosine + sine * sine));
var w = (cx * 2 - bw)*2;
var h = (cy * 2 - bh)*2;

Но... ответ не соответствует w и h

4b9b3361

Ответ 1

enter image description here

Решение

Учитывая размеры ограничивающего прямоугольника bx на by и t, это вращение против часовой стрелки прямоугольника размером x на y:

x = (1/(cos(t)^2-sin(t)^2)) * (  bx * cos(t) - by * sin(t))
y = (1/(cos(t)^2-sin(t)^2)) * (- bx * sin(t) + by * cos(t))

Вывод

Почему это?

Сначала рассмотрим, что длина bx разрезается на две части, a и b, на угол прямоугольника. Используйте тригонометрию, чтобы выразить bx в терминах x, y и theta:

bx = b          + a
bx = x * cos(t) + y * sin(t)            [1]

и аналогично для by:

by = c          + d
by = x * sin(t) + y * cos(t)            [2]

1 и 2 могут быть выражены в матричной форме как:

[ bx ] = [ cos(t)  sin(t) ] * [ x ]     [3]
[ by ]   [ sin(t)  cos(t) ]   [ y ]

Заметим, что матрица является почти матрицей вращения (но не совсем - это знак минуса.)

Слева разделите матрицу с обеих сторон, давая:

[ x ] = inverse ( [ cos(t)  sin(t) ]    * [ bx ]                        [4]
[ y ]             [ sin(t)  cos(t) ] )    [ by ]

Обратная матрица легко оценивается для матрицы 2x2 и расширяется до:

[ x ] = (1/(cos(t)^2-sin(t)^2)) * [ cos(t) -sin(t) ] * [ bx ]           [5]
[ y ]                             [-sin(t)  cos(t) ]   [ by ]

[5] дает две формулы:

x = (1/(cos(t)^2-sin(t)^2)) * (  bx * cos(t) - by * sin(t))             [6]
y = (1/(cos(t)^2-sin(t)^2)) * (- bx * sin(t) + by * cos(t))

Просто как пирог!

Ответ 2

Вам, возможно, понадобится что-то вроде аффинное преобразование, чтобы обнаружить координаты точек. А затем, используя стандартные формулы геометрии, вычислите размер.