2D преобразование

Преобразование означает преобразование одной графики в другую с применением правил. У нас могут быть различные типы преобразований, такие как перемещение, масштабирование вверх или вниз, поворот, сдвиг и т. Д. Когда преобразование происходит на 2D-плоскости, это называется 2D-преобразованием.

Преобразования играют важную роль в компьютерной графике для изменения положения графики на экране и изменения их размера или ориентации.

Однородные координаты

Чтобы выполнить последовательность преобразования, такую ​​как перевод с последующим вращением и масштабированием, нам нужно выполнить последовательный процесс -

  • Перевести координаты,
  • Поверните переведенные координаты, а затем
  • Масштабируйте повернутые координаты, чтобы завершить составное преобразование.

Чтобы сократить этот процесс, мы должны использовать матрицу преобразования 3 × 3 вместо матрицы преобразования 2 × 2. Чтобы преобразовать матрицу 2 × 2 в матрицу 3 × 3, мы должны добавить дополнительную фиктивную координату W.

Таким образом, мы можем представить точку тремя числами вместо двух, что называется Homogenous Coordinateсистема. В этой системе мы можем представить все уравнения преобразования в матричном умножении. Любая декартова точка P (X, Y) может быть преобразована в однородные координаты с помощью P '(X h , Y h , h).

Перевод

Перевод перемещает объект в другое место на экране. Вы можете перевести точку в 2D, добавив координату переноса (t x , t y ) к исходной координате (X, Y), чтобы получить новую координату (X ', Y').

Из рисунка выше вы можете написать, что -

X’ = X + tx

Y’ = Y + ty

Пара (t x , t y ) называется вектором трансляции или вектором сдвига. Вышеупомянутые уравнения также могут быть представлены с помощью векторов-столбцов.

$ P = \ frac {[X]} {[Y]} $ p '= $ \ frac {[X']} {[Y ']} $ T = $ \ frac {[t_ {x}]} {[ t_ {y}]} $

Мы можем написать это как -

P’ = P + T

Вращение

Во время вращения мы поворачиваем объект на определенный угол θ (тета) от его начала. Из следующего рисунка видно, что точка P (X, Y) расположена под углом φ от горизонтальной координаты X на расстоянии r от начала координат.

Предположим, вы хотите повернуть его на угол θ. После поворота на новое место вы получите новую точку P '(X', Y ').

Используя стандартную тригонометрию, исходная координата точки P (X, Y) может быть представлена ​​как -

$ X = r \, cos \, \ phi ...... (1) $

$ Y = г \, грех \, \ фи ...... (2) $

Точно так же мы можем представить точку P '(X', Y ') как -

$ {x} '= r \: cos \: \ left (\ phi \: + \: \ theta \ right) = r \: cos \: \ phi \: cos \: \ theta \: - \: r \ : грех \: \ фи \: грех \: \ тета ....... (3) $

$ {y} '= r \: sin \: \ left (\ phi \: + \: \ theta \ right) = r \: cos \: \ phi \: sin \: \ theta \: + \: r \ : грех \: \ фи \: соз \: \ тета ....... (4) $

Подставляя уравнения (1) и (2) в (3) и (4) соответственно, мы получим

$ {x} '= x \: cos \: \ theta - \: y \: sin \: \ theta $

$ {y} '= x \: sin \: \ theta + \: y \: cos \: \ theta $

Представляя вышеуказанное уравнение в матричной форме,

$$ [X 'Y'] = [XY] \ begin {bmatrix} cos \ theta & sin \ theta \\ −sin \ theta & cos \ theta \ end {bmatrix} OR $$

P '= P. р

Где R - матрица вращения

$$ R = \ begin {bmatrix} cos \ theta & sin \ theta \\ −sin \ theta & cos \ theta \ end {bmatrix} $$

Угол поворота может быть положительным и отрицательным.

Для положительного угла поворота мы можем использовать указанную выше матрицу поворота. Однако для поворота на отрицательный угол матрица изменится, как показано ниже -

$$ R = \ begin {bmatrix} cos (- \ theta) & sin (- \ theta) \\ -sin (- \ theta) & cos (- \ theta) \ end {bmatrix} $$

$$ = \ begin {bmatrix} cos \ theta & −sin \ theta \\ sin \ theta & cos \ theta \ end {bmatrix} \ left (\ потому что cos (- \ theta) = cos \ theta \; и \; sin (- \ theta) = −sin \ theta \ right) $$

Масштабирование

Для изменения размера объекта используется преобразование масштабирования. В процессе масштабирования вы либо увеличиваете, либо сжимаете размеры объекта. Масштабирование может быть достигнуто путем умножения исходных координат объекта на коэффициент масштабирования, чтобы получить желаемый результат.

Предположим, что исходные координаты равны (X, Y), коэффициенты масштабирования - (S X , S Y ), а полученные координаты - (X ', Y'). Математически это можно представить, как показано ниже -

X' = X . SX and Y' = Y . SY

Коэффициент масштабирования S X , S Y масштабирует объект по осям X и Y соответственно. Вышеупомянутые уравнения также могут быть представлены в матричной форме, как показано ниже -

$$ \ binom {X '} {Y'} = \ binom {X} {Y} \ begin {bmatrix} S_ {x} & 0 \\ 0 & S_ {y} \ end {bmatrix} $$

ИЛИ

P’ = P . S

Где S - матрица масштабирования. Процесс масштабирования показан на следующем рисунке.

Если мы предоставим значения меньше 1 для коэффициента масштабирования S, то мы можем уменьшить размер объекта. Если мы предоставим значения больше 1, то мы можем увеличить размер объекта.

Отражение

Отражение - это зеркальное отображение исходного объекта. Другими словами, мы можем сказать, что это операция поворота на 180 °. При преобразовании отражения размер объекта не изменяется.

На следующих рисунках показаны отражения относительно осей X и Y и относительно начала координат соответственно.

Сдвиг

Преобразование, изменяющее форму объекта, называется преобразованием сдвига. Есть два сдвиговых преобразованияX-Shear а также Y-Shear. Один сдвигает значения координат X, а другой сдвигает значения координат Y. Однако; в обоих случаях только одна координата меняет свои координаты, а другая сохраняет свои значения. Стрижка также называетсяSkewing.

X-Shear

X-Shear сохраняет координату Y, и в координаты X вносятся изменения, в результате чего вертикальные линии наклоняются вправо или влево, как показано на рисунке ниже.

Матрица преобразования для X-Shear может быть представлена ​​как -

$$ X_ {sh} = \ begin {bmatrix} 1 & shx & 0 \\ 0 & 1 & 0 \\ 0 & 0 & 1 \ end {bmatrix} $$

Y '= Y + Sh y . Икс

X '= X

Y-ножницы

Y-Shear сохраняет координаты X и изменяет координаты Y, в результате чего горизонтальные линии трансформируются в линии с уклоном вверх или вниз, как показано на следующем рисунке.

Y-сдвиг может быть представлен в матрице как -

$$ Y_ {sh} \ begin {bmatrix} 1 & 0 & 0 \\ shy & 1 & 0 \\ 0 & 0 & 1 \ end {bmatrix} $$

Х '= Х + Ш х . Y

Y '= Y

Составное преобразование

Если за преобразованием плоскости T1 следует преобразование второй плоскости T2, то сам результат может быть представлен одним преобразованием T, которое является композицией T1 и T2, взятых в этом порядке. Это записывается как T = T1 ∙ T2.

Составное преобразование может быть достигнуто путем объединения матриц преобразования для получения объединенной матрицы преобразования.

Комбинированная матрица -

[T][X] = [X] [T1] [T2] [T3] [T4] …. [Tn]

Где [Ti] - любая комбинация

  • Translation
  • Scaling
  • Shearing
  • Rotation
  • Reflection

Изменение порядка преобразования приведет к другим результатам, поскольку в общем случае умножение матриц не является накопительным, то есть [A]. [B] ≠ [B]. [A] и порядок умножения. Основная цель составления преобразований - повысить эффективность за счет применения одного составного преобразования к точке, а не применения серии преобразований одно за другим.

Например, чтобы повернуть объект вокруг произвольной точки (X p , Y p ), мы должны выполнить три шага:

  • Переведите точку (X p , Y p ) в начало координат.
  • Поверните его относительно начала координат.
  • Наконец, переместите центр вращения обратно на место.