我的编程空间,编程开发者的网络收藏夹
学习永远不晚

HTML5怎么实现圆锥

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

HTML5怎么实现圆锥

这篇文章主要介绍“HTML5怎么实现圆锥”,在日常操作中,相信很多人在HTML5怎么实现圆锥问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”HTML5怎么实现圆锥”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

一.简介

圆锥,数学领域术语,有两种定义。

解析几何定义:圆锥面和一个截它的平面(满足交线为圆)组成的空间几何图形叫圆锥。

立体几何定义:以直角三角形的一条直角边所在直线为旋转轴,其余两边旋转形成的面所围成的旋转体叫做圆锥。该直角边叫圆锥的轴 。

未命名

二.圆锥模拟

通过以上两个定义,我可以模拟出圆锥上所有的点:

JavaScript Code复制内容到剪贴板

var pointPositions = [];  

for (var i = -100; i < 200; i += 10) {  

    var xTemp = getRandomNumber(-i, i);  

    var zTemp = Math.sqrt(Math.abs(i * i - xTemp * xTemp));  

    pointPositions.push(new Vector3(xTemp, i, zTemp));  

}  

i 既是h,又是半径r。

这个时候,我们生成的 Z都是大于零的,不过没有关系,我们等下可以通过旋转来补齐所有的点。

三.旋转与投影

JavaScript Code复制内容到剪贴板

//旋转  

    function rotate(angle) {  

        for (var i = 0; i < pointPositions.length; i++) {  

            var tempX = pointPositions[i].x;  

            var tempZ = pointPositions[i].z;  

            pointPositions[i].x = pointPositions[i].x * Math.cos(angle) - pointPositions[i].z * Math.sin(angle);  

            pointPositions[i].z = pointPositions[i].z * Math.cos(angle) + tempX * Math.sin(angle);  

        }  

    }  

    //投影  

    function projection(v) {  

        var v1 = new Vector3();  

        v1.x = v.x * distance / Math.abs(cameraPosition.z - v.z);  

        v1.y = v.y * distance / Math.abs(cameraPosition.z - v.z);  

        v1.z = v.z;  

        return v1;  

    }  

四.动画

JavaScript Code复制内容到剪贴板

var currentAngle = 0;  

    var roundAsync = eval(Jscex.compile("async", function () {  

        while (true) {  

            pointPositionsForShow.length = 0;  

            currentAngle += 0.1;  

            rotate(degToRad(currentAngle));  

            PositionsProjection();  

            for (var i = 0; i < pointPositionsForShow.length; i++) {  

                cxt.fillStyle = randomColor();  

                cxt.beginPath();  

                if (pointPositionsForShow[i].z > 0) cxt.globalAlpha = 1;  

                if (pointPositionsForShow[i].z < 0) cxt.globalAlpha = 0.1;  

                cxt.arc(centreOfCirclePosition.x + pointPositionsForShow[i].x, centreOfCirclePosition.x + pointPositionsForShow[i].y, distance / Math.abs(cameraPosition.z - pointPositionsForShow[i].z), 0, Math.PI * 2, true);  

                cxt.closePath();  

                cxt.fill();  

            }  

            $await(Jscex.Async.sleep(50));  

        }  

    }))  

到此,关于“HTML5怎么实现圆锥”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

HTML5怎么实现圆锥

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

css3怎么实现圆锥渐变conic-gradient

这篇文章主要介绍css3怎么实现圆锥渐变conic-gradient,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!语法:background-image: conic-gradient(from angle at p
2023-06-08

css如何实现圆锥梯度

小编给大家分享一下css如何实现圆锥梯度,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!圆锥梯度有没有想过是否可以只使用 CSS 创建饼图?好消息是,您实际上可以!
2023-06-27

css怎么实现圆角按钮

这篇“css怎么实现圆角按钮”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“css怎么实现圆角按钮”文章吧。1.首先,在页面中
2023-07-04

css怎么实现圆角边框

这篇“css怎么实现圆角边框”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“css怎么实现圆角边框”文章吧。1.首先创建一个h
2023-07-04

css半圆效果怎么实现

这篇“css半圆效果怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“css半圆效果怎么实现”文章吧。1、半圆半圆分为:
2023-07-04

HTML5 Canvas怎么实现圆形进度条并显示数字百分比效果

这篇文章主要介绍HTML5 Canvas怎么实现圆形进度条并显示数字百分比效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!实现效果1.首先创建html代码2023-06-09

编程热搜

目录