一,三维坐标系转化成二维坐标系
1.flash中的二维坐标系
(1)坐标的转换
flash中场景左上角为(0, 0),而在数学中是场景中心为(0, 0),怎样把数学中的坐标系转成flash的呢?假设场景宽度:550,高度400.
x = 550 / 2 + this._x;
y = 400 / 2 - thix._y;
如图1.

图1 坐标转换 图2 角度转换
(2)角度的转换
flash中角度的计算:
hudu = Math.atan2(y, x);(tg(a) = y / x,计算a的值)
flash中a是以弧度表示的 ,我们要把它转换成角度(360度等于2*pai弧度),所以转成角度的公式为:
jiaodu = hudu * 180 / Math.PI(角度 = 弧度 * 180 / 3.14);
if(jiaodu < 0) { jiaodu = jiaodu + 360; }(转换后的角度的范围从-180到180, 数学中的角度从0到360,所以小于0时加上360).
如图2.
2.flash中的三维坐标系
z轴表示一个物体离屏幕的远近,当物体的z轴位置增加时,物体朝远离屏幕的方向运动,当物体的z值减小时,物体朝接近屏幕的方向运动.
如图3.

图3 三维坐标 图4 三维坐标与二维坐标关系
3.三维坐标转换成二维坐标
已知一个点(x, y, z),怎样确定该点屏幕上的位置呢?利用三角形相似的原理,可以得出下列结论:
d / (d + z) = y1 / y,推出:y1 = d * y / (d + z),这公式可在二维平面上来表现空间上的点的位置.
还可进一步简化,提出因子d / (d + z),用ratio(比率)表示,这个公式就变为
ratio = d / (d + z);
y1 = ratio * y;
x1 = ratio * x;
如图4.
二,控制物体的属性(大小,层次,透明度等)
远的物体和近的物体的大小一样,层次可能也不一样,怎么办呢?
1.控制mc的大小
在三维坐标中,当z值增大,也就是远离屏幕时,物体应越小,反之越大.
怎么在flash中表示一个mc的大小呢?还记得上一步的ratio吗?
当z增加时,ratio减少,因为在ratio中,z是作为分母的.反之,当z减少时,ratio增加.所以可用ratio来控制mc的大小.
mc1._xscale = mc._xscale * ratio;
mc1._yscale = mc._yscale * ratio;
2.控制mc的层次
z值最大,物体应在最底层,最小,在最上层,用一个很大的常数减去z值,用此值作为mc的层次.
flash中,设置mc的层次用swapDepths,
mc.swapDepths(1000 - z);
3.控制mc的透明度
远处的物体看上去模糊些,近处的物体清晰些,
在flash中,可用_alpha来控制,
mc._alpha = 100 * ratio;
4.控制mc的角度(旋转)
旋转有三种,x旋转:坐标x不变,y旋转:y不变,z旋转:z不变,我们先来推导z旋转.
从点(x, y, 0)转到(x1, y1, 0),求点(x1, y1, 0)(如图5)
利用数学中的正弦,余弦公式得出
x1 = r * cos(a + b),而cos(a + b) = cosa * cosb - sina * sinb.
推出:x1 = r * (cosa * cosb - sina * sinb)
又因为x = r * cosa, y = r * sina
所以x1 = x * cosb -y * sinb
同样推出:y1 = y * cosb + x * sinb
这就是z旋转的公式.

图3 (x, y, z)旋转坐标转换
给定点:(x,y,z)
绕x轴旋转后的点(x1, y1, z1)
绕y轴旋转后的点(x2, y2, z2)
绕z轴旋转后的点(x3, y3, z3)
x旋转(x不变)
x1 = x
y1 = y * cosb - z * sinb
z1 = z * cosb + y * sinb
y旋转(y不变)
x2 = x * cosb - z1 * sinb
y2 = y1
z2 = z1 * cosb + x * sinb
z旋转(z不变)
x3 = x2 * cosb - y1 * sinb
y3 = y1 * cosb + x2 * sinb
z3 = z2
在flash要实现旋转,先要求x轴的旋转点,再求y轴的旋转点,最后再求出z轴的旋转点.
分享到:
相关推荐
OpenGL三维坐标系绘图程序是计算机图形学领域中的一个经典应用,它利用OpenGL库来创建和展示复杂的3D模型和图像。在这个程序中,我们主要关注的是如何在三维空间中定位和绘制图形,并且如何通过串行端口(COM口)...
在这个场景下,我们将多个二维图像沿着一个共享的坐标轴(如X、Y或Z轴)堆叠,形成一个三维体,这样就可以从不同的角度观察和分析数据。 要实现这一功能,MATLAB提供了多种函数和方法。最常用的一种是使用`slice`...
在这个过程中,需要将三维坐标系转换到二维坐标系中。下面将详细介绍三维坐标变换的过程。 1. 观察坐标系的建立 观察坐标系是三维坐标变换的基础。它是用户坐标系下的一个参考坐标系,定义了观察平面和观察方向。...
本文将详细介绍计算二维坐标到3D坐标的转换方法,包括反畸变模型、光平面参数、相机坐标系等知识点。 一、反畸变模型 反畸变模型是一种常用的计算机视觉技术,用于将二维图像坐标转换为三维世界坐标。反畸变模型的...
绘制透明的三维坐标系需要考虑以下几个步骤: 1. **设置颜色缓冲区和深度缓冲区**:在开始绘制前,我们需要启用深度测试,以确保正确处理多个图元的前后关系。这可以通过调用`glEnable(GL_DEPTH_TEST)`完成。同时,...
三维图形能够模拟现实世界的物体和场景,而三维坐标系则是理解和描述这些图形的基础。本资源提供了一个优秀的三维坐标系和图形的源代码实现,让我们来深入探讨一下相关知识点。 首先,三维坐标系(3D Coordinate ...
- 我挂上来的这个节点是将鼠标指向的二维坐标转换到三维坐标系下,并发布话题可视化到了rviz中,因为我自己的物体识别发布的像素坐标话题是一个自己写的消息文件,这次就不放出来了,需要用的把我这里的鼠标反馈的...
本文介绍的是如何利用MATLAB实现二维坐标系变换的方法。 坐标变换是测绘学、计算机图形学、机器人技术等领域中非常重要的数学工具。在坐标变换中,需要将一个坐标系下的点映射到另一个坐标系中。常见的坐标变换方法...
在计算机图形学中,三维坐标变换和投影变换是至关重要的概念,它们用于将三维空间中的对象转换成二维屏幕上的图像。本项目通过C++编程语言和Microsoft Foundation Classes (MFC)框架来实现这些复杂的数学运算,使...
matlab在一个坐标系内让二维图片堆叠形成三维空间的表示 二维数据或者图片堆叠在三维空间的表示,图片堆叠方便查看 类似origin里面的瀑布图的方法,只是这是在matlab里面实现。 matlab多张图片同时在三维空间中显示...
在旧技术条件下,由于缺少具有精确三维地心坐标的国家大地点,人们往往需要借助二维的国家坐标系来进行坐标转换。然而,随着技术的进步和新国家大地坐标系的启用,现在有了更加精确的三维地心坐标,这为直接在WGS84...
1. **空间直角坐标系**:这是最基础的三维坐标系统,通常由X、Y、Z三个正交轴构成,其中X和Y轴定义了水平面,Z轴指向地球的北极。在计算机图形学和物理学中广泛使用,每个点的位置由三个数值(X, Y, Z)来确定。 2....
空间直角坐标系,即三维空间坐标(X,Y,Z)形式3.投影平面直角坐标系。即二维平面坐标(x,y,h)形式 在工程测量和施工中,我国普遍使用的是1954北京或1980西安的高斯投影平面直角坐标系。 但为满足工程施工精度...
在MATLAB编程环境中,通常我们使用`polar`函数来绘制二维极坐标图,它能够帮助我们理解在极坐标系下的数据分布。然而,对于某些复杂的科学计算或数据分析任务,二维极坐标图可能无法满足需求,这就催生了对三维极...
一个三维坐标系由三个轴组成:X轴、Y轴和Z轴,它们共同定义了一个点在空间中的位置。在地球坐标系统中,通常使用经度、纬度和高度来表示三维坐标。 方位角,也称为方向角,是从一个点到另一个点的方向线与参考轴...
关键在于,它采用了一种优化策略,即最小化投影误差,以求得最接近观测值的三维坐标。 在Python中,EPNP的实现通常会依赖于一些基础库,如OpenCV或numpy。OpenCV提供了许多用于计算基础几何变换的函数,而numpy则...
在计算机视觉和图像处理领域,将世界坐标系转化为像素坐标系是一个重要的步骤,尤其是在进行三维物体的定位、机器人导航或图像映射等应用时。MATLAB作为一种强大的数值计算和可视化工具,提供了丰富的函数和工具箱来...
在描述中提到的“从给定的单个索引中为二维上矩阵下标(对角线上没有元素)”,意味着我们需要将一个单一的线性索引转换成对应的二维上三角坐标系的行和列索引。MATLAB提供了`ind2sub`函数来实现这种转换,但原生的`...