rotate 3D [初识篇]

rotate 3D [初识篇]随着前端技术发展,尤其是html5中canvas和svg的应用,开始让web也可以轻易的渲染出各种绚丽的效果。本篇讨论的是基于rotate(旋转)的3d效果的初识。在canvas的getContext

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

随着前端技术发展,尤其是html5中canvas和svg的应用,开始让web也可以轻易的渲染出各种绚丽的效果。

本篇讨论的是基于rotate(旋转)的3d效果的初识。在canvas的getContext(‘2d’)下利用一些变换来模拟。webGL是后话,本篇暂不讨论。

【简要原理】
由于仍是在2d下模拟,所以所谓的3d最终还是要降到2d的层面来。
在坐标上的表现就是,3d的界面应该是有x,y,z三向坐标,2d的就只有x,y二向。
那么怎么把3d的z向坐标降到和2d的x,y相关联起来,就是关键。

要在2d的界面上展现3d的z方向的层次感,需要一个视井。
相信学过绘画的同学应该很清楚,要画透视或者有层次关系的多个物体时。在最开始建模的时候老师都会教先根据观察角度“打格子”,把物体的大小层次关系大概先模拟出来。
格子打出来其实就是由近及远的“井”字形。

最直观的感觉就是可以想象一张拍很长走廊的照片,照片里的走廊一定是近处宽,随着距离的拉远,走廊宽度一定是渐窄,看起来就像是两条斜线向远处延伸。

于是,在编码过程中,根据这个原理,不难想象到原本的z坐标要表现在2d的x,y坐标上,其影响就是会影响xy坐标的偏移。
同时还有物体大小的变化,透明度(模糊度)的变化,这些应该容易想到。

【demo1】
下面就以一个小球来展现改变z坐标的位置对其2d界面下的x,y位置和大小的影响。

// 创建一个小球    
var ball = createBall(ballR);
//添加到舞台
stage.addChild(ball);
//取得画布中心位置
vpx = canvas.width/2;
vpy = canvas.height/2;

// 取得当前鼠标相对中心偏移距离 xpos, ypos
stage.addEventListener('mousemove', function (x, y) {
xpos
= x - vpx;
ypos
= y - vpy;
});
// 用键盘上下键改变z坐标的位置
document.addEventListener('keydown', function (e) {
if (e.keyCode == 38) zpos += 5;
if (e.keyCode == 40) zpos -=5;
},
false)

// 每帧刷新时的改变
stage.onRefresh = function () {
// 将z坐标扁平化
var scale = focalLength/(focalLength + zpos);
// 将扁平後z坐标对x,y的影响给小球坐标
ball.x = vpx + xpos*scale;
ball.y
= vpy + ypos*scale;
// 对小球大小的影响
ball.width = ballR*2*scale;

document.getElementById(
'scale').innerHTML = scale;
}

stage.start();

代码很简单,都舔了注释。
 

 

【demo2】
可能上面的demo还太简单,不能看出所谓的3d的效果。按照上面的思路,可以给x方向添加一个旋转的效果,结合z方向对其的影响就可以看出一点所谓3d的效果了。

// 获取画布中心        
vpx = canvas.width/2;
vpy = canvas.height/2;

// 根据鼠标位置计算选装角度(速度)
stage.addEventListener('mousemove', function (x, y) {
angleY
= (x - vpx) * .001;
});

// 主旋转函数
function rotateY(ball, angleY) {
// 把角度三角函数化,以便看起来是绕圆旋转
var cosy = Math.cos(angleY),
siny
= Math.sin(angleY),
// 把 z方向影响算进来
x1 = ball.xpos * cosy - ball.zpos * siny,
z1
= ball.zpos * cosy + ball.xpos * siny;
ball.xpos
= x1;
ball.zpos
= z1;

// z坐标扁平化,并赋给小球影响
var scale = focalLength / (focalLength + ball.zpos);
ball.x
= vpx + ball.xpos * scale;
ball.y
= vpy + ball.ypos * scale;
ball.width
= ballR*2*scale;
}

代码实际运行如下:
  

 

恩,本来这篇还想多写点的,但是肚子饿了,木办法,先去填肚子了,明天还要上班….

今天中秋,虽然迟了点,还是祝各位园友佳节快乐吧。

下篇继续…

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/166782.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • webstorm激活码【注册码】

    webstorm激活码【注册码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月20日
    44
  • nginx反向代理和正向代理的区别是什么_nginx负载均衡的三种方式

    nginx反向代理和正向代理的区别是什么_nginx负载均衡的三种方式nginx反向代理和正向代理的区别是什么?下面本篇文章就来给大家介绍一下,希望对你们有所帮助。什么是正向代理?正向代理是一个位于客户端和原始服务器(originserver)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端才能使用正向代理。什么是反向代理?反向代理(ReverseProxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服.

    2025年8月10日
    3
  • 屠龙之技 作者:长铗

    屠龙之技 作者:长铗一  雨水从宽阔的大理石台阶上淌下来,打湿了年轻人制作考究的山羊皮皮鞋。他的身形颀长瘦削,撑一把漆黑的木柄雨伞,侧脸仰望着灰蒙蒙的天空。年轻人推开图书馆那扇锈涩厚重的大门时,一只鸽子飞了出来。他钝重的步子在高耸狭窄的空间里激荡回响。这是一个由教堂改建而成的街区图书馆,在这个时代,聆听圣音的人已经不多了。  年轻人停住了脚步,目光蓦地垂落到教堂内远远的一角。冬日灰冷的阳光从高窗上的彩色玻璃中透下…

    2022年5月20日
    47
  • pycharm安装教程(非常详细)_扶梯安装步骤

    pycharm安装教程(非常详细)_扶梯安装步骤Pycharm安装+Anconda环境配置,需要下载软件的请访问​​​​​​(75条消息)Python软件.zip(pycharm安装包Anconda安装包)-Python文档类资源-CSDN文库(免费下载免费下载免费下载免费下载免费下载免费下载),没有安装Ancondade小伙伴可以访问Anconda安装(超详细)写文章-CSDN博客https://mp.csdn.net/mp_blog/creation/editor/120982868…

    2022年8月26日
    6
  • 行列式运算法则 矩阵的运算及其运算规则:「建议收藏」

    行列式运算法则 矩阵的运算及其运算规则:「建议收藏」1、三角形行列式的值,等于对角线元素的乘积。计算时,一般需要多次运算来把行列式转换为上三角型或下三角型2、交换行列式中的两行(列),行列式变号(交换)3、行列式中某行(列)的公因子,可以提出放到行列式之外。(倍乘)(注:矩阵是全部元素都乘,都提取)4、行列式的某行乘以a,加到另外一行,行列式不变,常用于消去某些元素。(倍加)5、若行列式中,两行(列)完全一样,则行列式为0;可以推论,如果两…

    2025年8月23日
    3
  • ubuntu下安装python3

    ubuntu下安装python3安装步骤ubuntu本身安装的时候已经自带python了,在终端输入python-V查看当前python版本python-V如上图,当前电脑安装的python版本是2.7.12下载最新的python3sudoapt-getinstallpython3如图,我的电脑本身已经装有python3了,如果没安装有,则应该安装最

    2022年6月23日
    47

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号