这是更改对象角度的过程。旋转可以是顺时针或逆时针。对于旋转, 我们必须指定旋转角度和旋转点。旋转点也称为枢轴点。打印关于旋转哪个对象的信息。
旋转类型
- 逆时针方向
- 逆时针方向
枢轴点的负值(旋转角度)使对象沿顺时针方向旋转。
旋转对象时, 对象的每个点都旋转相同的角度。
直线:直线由端点以相同角度旋转, 并在新端点之间重画线。
多边形:通过使用相同的旋转角度移动每个顶点来旋转多边形。
曲线:通过重新放置所有点并在新位置绘制曲线来旋转曲线。
圆:可以通过中心位置指定角度获得。
椭圆:可以通过将椭圆的长轴和短轴旋转所需角度??来获得其旋转。
data:image/s3,"s3://crabby-images/c671b/c671b689d602fbf9ecd9f09e0e193cce9d83f176" alt="计算机图形旋转操作详细步骤"
文章图片
data:image/s3,"s3://crabby-images/b40eb/b40eb680a2e2a5c286fce2f5524460fdf46832fc" alt="计算机图形旋转操作详细步骤"
文章图片
旋转矩阵为顺时针方向。
data:image/s3,"s3://crabby-images/92f77/92f7779151b65ac7b70416778fe5c6df97d5f49f" alt="计算机图形旋转操作详细步骤"
文章图片
旋转矩阵是逆时??针方向。
data:image/s3,"s3://crabby-images/d65e4/d65e4a52632c4d4fa63420959e793fd13eec68ce" alt="计算机图形旋转操作详细步骤"
文章图片
均匀坐标旋转矩阵(顺时针)
data:image/s3,"s3://crabby-images/9e476/9e476febf7a37d3bee2bbb5c335cc1f78a8f9a76" alt="计算机图形旋转操作详细步骤"
文章图片
齐次坐标旋转矩阵(逆时针)
data:image/s3,"s3://crabby-images/18056/1805691f3183b2a73c0bba34517dfb27cc25ded0" alt="计算机图形旋转操作详细步骤"
文章图片
围绕任意点旋转:如果要旋转对象或围绕任意点旋转点, 首先, 我们将要围绕其旋转的点转换为原点。然后围绕原点旋转点或对象, 最后, 再次将其平移到原始位置。我们绕任意点旋转。
示例:要旋转点(x, y)
(xc yc)是绕逆时针方向旋转的点
步骤1:将点(xc yc)转换为原点
data:image/s3,"s3://crabby-images/f613d/f613d37ae1932a3a2a97c55a192b356eba406a64" alt="计算机图形旋转操作详细步骤"
文章图片
步骤2:围绕原点旋转(x, y)
data:image/s3,"s3://crabby-images/3ab2d/3ab2d39ff10d35f77bd194a137ae397506ec2657" alt="计算机图形旋转操作详细步骤"
文章图片
步骤3:将旋转中心平移回原始位置
data:image/s3,"s3://crabby-images/e84ad/e84ad70436408c351aa50d017e939566f742573e" alt="计算机图形旋转操作详细步骤"
文章图片
data:image/s3,"s3://crabby-images/a2dd1/a2dd1e8d7a51fef764b928568c5748ba65a5d670" alt="计算机图形旋转操作详细步骤"
文章图片
示例1:证明围绕原点的2D旋转是可交换的, 即R1 R2 = R2 R1。
解决方案:R1和R2是旋转矩阵
data:image/s3,"s3://crabby-images/45ac9/45ac9c58d3f90ecd9dd3e62d1e85cbde84c88e45" alt="计算机图形旋转操作详细步骤"
文章图片
示例2:绕着原点旋转线CD, 使其端点为(3, 4)和(12, 15), 沿逆时针方向旋转45°。
解决方案:点C(3, 4)
data:image/s3,"s3://crabby-images/a0e57/a0e57680e87d83659c223eb5506bba6acbe35a53" alt="计算机图形旋转操作详细步骤"
文章图片
data:image/s3,"s3://crabby-images/58693/586939e9226aff35db18ff1220206a41f9cf3a04" alt="计算机图形旋转操作详细步骤"
文章图片
data:image/s3,"s3://crabby-images/e13a4/e13a4a5c2ef1f80f9a508d7828671a1e04535cdb" alt="计算机图形旋转操作详细步骤"
文章图片
例3:绕线AB绕其原点沿顺时针方向旋转AB, 端点为A(2, 5)和B(6, 12)。
解决方案:沿顺时针方向旋转。矩阵是
data:image/s3,"s3://crabby-images/f79f0/f79f0b8ce199d703b4209c982c215845c7489eb3" alt="计算机图形旋转操作详细步骤"
文章图片
步骤1:旋转点A(2, 5)。取角30°
data:image/s3,"s3://crabby-images/f35af/f35af166bfbd7c959497f149a7c8b56fa611bd6f" alt="计算机图形旋转操作详细步骤"
文章图片
步骤2:旋转B点(6, 12)
data:image/s3,"s3://crabby-images/443eb/443ebd7b1dc110d5a0e55fd70d7cdaddd2cc71e6" alt="计算机图形旋转操作详细步骤"
文章图片
data:image/s3,"s3://crabby-images/c2288/c2288d555844addbf3ab163ab864c9364f76bf16" alt="计算机图形旋转操作详细步骤"
文章图片
旋转线的程序:
#include<
stdio.h>
#include<
graphics.h>
#include<
math.h>
int main(){ intgd=0, gm, x1, y1, x2, y2;
double s, c, angle;
initgraph(&
gd, &
gm, "C:\\TC\\BGI");
setcolor(RED);
printf("Enter coordinates of line: ");
scanf("%d%d%d%d", &
x1, &
y1, &
x2, &
y2);
cleardevice();
setbkcolor(WHITE);
line(x1, y1, x2, y2);
getch();
setbkcolor(BLACK);
printf("Enter rotation angle: ");
scanf("%lf", &
angle);
setbkcolor(WHITE);
c = cos(angle *3.14/180);
s = sin(angle *3.14/180);
x1 = floor(x1 * c + y1 * s);
y1 = floor(-x1 * s + y1 * c);
x2 = floor(x2 * c + y2 * s);
y2 = floor(-x2 * s + y2 * c);
cleardevice();
line(x1, y1 , x2, y2);
getch();
closegraph();
return 0;
}
输出:
【计算机图形旋转操作详细步骤】旋转前
data:image/s3,"s3://crabby-images/188b1/188b119fb6b355d59544b154e6fd0a4a2bd7b5fe" alt="计算机图形旋转操作详细步骤"
文章图片
data:image/s3,"s3://crabby-images/99f1a/99f1abfd23526e958bc5fd26817729920eeeda73" alt="计算机图形旋转操作详细步骤"
文章图片
data:image/s3,"s3://crabby-images/3f9ec/3f9ec236bd165eef4c47b3a8519059f161abc002" alt="计算机图形旋转操作详细步骤"
文章图片
旋转后
data:image/s3,"s3://crabby-images/193ab/193ab0ab8d4f1ad774387c4e4756ca2e6248cbb8" alt="计算机图形旋转操作详细步骤"
文章图片
程序旋转三角形:
#include<
stdio.h>
#include<
graphics.h>
#include<
math.h>
main(){ intgd=0, gm, x1, y1, x2, y2, x3, y3;
double s, c, angle;
initgraph(&
gd, &
gm, "C:\\TURBOC3\\BGI");
setcolor(RED);
printf("Enter coordinates of triangle: ");
scanf("%d%d%d%d%d%d", &
x1, &
y1, &
x2, &
y2, &
x3, &
y3);
setbkcolor(WHITE);
cleardevice();
line(x1, y1, x2, y2);
line(x2, y2, x3, y3);
line(x3, y3, x1, y1);
getch();
setbkcolor(BLACK);
printf("Enter rotation angle: ");
scanf("%lf", &
angle);
setbkcolor(WHITE);
c = cos(angle *M_PI/180);
s = sin(angle *M_PI/180);
x1 = floor(x1 * c + y1 * s);
y1 = floor(-x1 * s + y1 * c);
x2 = floor(x2 * c + y2 * s);
y2 = floor(-x2 * s + y2 * c);
x3 = floor(x3 * c + y3 * s);
y3 = floor(-x3 * s + y3 * c);
cleardevice();
line(x1, y1 , x2, y2);
line(x2, y2, x3, y3);
line(x3, y3, x1, y1);
getch();
closegraph();
return 0;
}
输出:
旋转前
data:image/s3,"s3://crabby-images/7d58c/7d58cfa1431097b43fb16b4d46bf93399217db98" alt="计算机图形旋转操作详细步骤"
文章图片
data:image/s3,"s3://crabby-images/c378a/c378a6a33fe9ee79a6c65c0b07ac13cbde953577" alt="计算机图形旋转操作详细步骤"
文章图片
data:image/s3,"s3://crabby-images/f6c90/f6c90692ff719e6c1b19b4277dc1334687385387" alt="计算机图形旋转操作详细步骤"
文章图片
旋转后
data:image/s3,"s3://crabby-images/fd650/fd6502aa23890a5358eb947f5b17cd52ac241d1c" alt="计算机图形旋转操作详细步骤"
文章图片
推荐阅读
- 计算机图形(反射操作)
- 计算机图形(缩放比例)
- 计算机图形翻译
- 计算机图形转型介绍
- 计算机扫描线多边形填充算法
- 计算机图形(洪水填充算法)
- 计算机图形(填充区域基元)
- 计算机图形(中点椭圆算法)
- 计算机图形(三角法)