程序员必知:【Canvas与数学】幂函数y=x^3的图像

简介: 程序员必知:【Canvas与数学】幂函数y=x^3的图像

【图像】

【代码】

<!DOCTYPE html

[/span>html lang="utf-8"

[/span>meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>

[/span>head

[/span>title

[/span>style type="text/css"

.centerlize{

margin:0 auto;

border:0px solid red;

Width</span>:1200px;Height</span>:600px;

}//代码效果参考:http://www.ezhiqi.com/zx/art_5582.html

[/span>body onload="draw();"

[/span>div class="centerlize"

[/span>canvas id="myCanvas" Width</span>="1200px" Height</span>="600px" style="border:1px dashed black;"

如果看到这段文字说您的浏览器尚不支持HTML5 Canvas,请更换浏览器再试.

[/span>script type="text/javascript"

<!--

/*

将全体代码(从)拷贝下来,粘贴到文本编辑器中,

另存为.html文件,再用chrome浏览器打开,就能看到实现效果。

**/

// 画布宽度

const Width</span>=1200;

// 画布高度

const Height</span>=600;

// 画布环境

var context=0;

// 舞台对象

var stage;

// 消逝的时间

var timeElapsed=0;

// 核心勾画函数,由body_onload调用

function draw(){

// 画图前初始化

var canvas=document.getElementById('myCanvas');

canvas.Width</span>=WIDTH;

canvas.Height</span>=HEIGHT;

context=canvas.getContext('2d');

// 进行屏幕坐标系到笛卡尔坐标系的变换

// 处置完成前,原点在左上角,向右为X正向,向下为Y的正向

// 处置完毕后,原点移动到画布中央,向右为X正向,向上为Y的正向

context.translate(Width</span>/2,Height</span>/2);

context.rotate(getRad(180));

context.scale(-1,1);

// 之后再移动原点和改变横纵比例

// 进行坐标原点的平移

//context.translate(0,0);

// 进行横纵方向的比例转换

//context.scale(1,1);

// 初始化舞台

stage=new Stage();

// 开始动画

animate();

}//代码效果参考:http://www.ezhiqi.com/bx/art_5119.html;

//---

// 画图

//---

function animate(){

timeElapsed+=1;// 时间每轮增加1

stage.update(timeElapsed);

stage.paintBg(context);

stage.paint(context);

if(timeElapsed[/span>100){

window.requestAnimationFrame(animate);

}

}//代码效果参考:http://www.ezhiqi.com/zx/art_602.html

//---

// 舞台对象定义处

//---

function Stage(){

var obj=new Object;

obj.prpty={"x":-50,"y":0,"pts":【】};

// 随时间更新位置

obj.update=function(t){

obj.prpty.x+=1;

obj.prpty.y=Math.pow(obj.prpty.x,3);

let arr={"x":obj.prpty.x,"y":obj.prpty.y};

this.prpty.pts.push(arr);

};

// 画前景

obj.paint=function(ctx){

// 写当前点坐标

drawText2(ctx," 红色 X:"+this.prpty.x.toFixed(3)+" Y:"+this.prpty.y.toFixed(3),300,85,"navy");

// 红色曲线y=1.1^x

paintCurve(ctx,"red",this.prpty.pts);

};

// 画背景

obj.paintBg=function(ctx){

// 清屏

ctx.clearRect(-600,-300,1200,600);

// 画X轴

drawAxisX(ctx,-600,600,50);

// 画Y轴

drawAxisY(ctx,-300,300,50);

// 画网格线

drawGrid(ctx,-600,-300,50,1200,600,50,"grey");

// 作者,日期

drawText2(ctx,<span style="background-color: rgba(245, 245, 245, 1); color: rgba(

相关文章
LaTeX数学模式中的矩阵
LaTeX数学模式中的矩阵
1045 0
LaTeX数学模式中的矩阵
|
计算机视觉
数字图像处理实验(七)| 形态学图像处理{生成结构元素strel、腐蚀运算imerode、膨胀运算imdilate、开运算imopen、闭运算imclose}(附代码和实验截图、汉字视力表项目、总结)
数字图像处理实验(七)| 形态学图像处理{生成结构元素strel、腐蚀运算imerode、膨胀运算imdilate、开运算imopen、闭运算imclose}(附代码和实验截图、汉字视力表项目、总结)
613 0
数字图像处理实验(七)| 形态学图像处理{生成结构元素strel、腐蚀运算imerode、膨胀运算imdilate、开运算imopen、闭运算imclose}(附代码和实验截图、汉字视力表项目、总结)
|
4月前
|
Web App开发 移动开发 前端开发
程序员必知:【Canvas与数学】幂函数y=x^3的图像
程序员必知:【Canvas与数学】幂函数y=x^3的图像
39 2
|
5月前
|
Python
Python数学基础二、利用正弦sin求曲边图形的面积
Python数学基础二、利用正弦sin求曲边图形的面积
97 0
|
5月前
【每日一题Day247】LC1401圆和矩形是否有重叠 | 数学
【每日一题Day247】LC1401圆和矩形是否有重叠 | 数学
35 0
|
数据可视化 图形学
【数学篇】08 # 如何利用三角剖分和向量操作描述并处理多边形?
【数学篇】08 # 如何利用三角剖分和向量操作描述并处理多边形?
92 0
【数学篇】08 # 如何利用三角剖分和向量操作描述并处理多边形?
python 绘图时显示不同的数学符号alpha,beta,偏导、求和等等
在使用python进行绘图时,当涉及当一些数学计算时,常常需要为我们的x、y轴以及标题添加标签,而一些特殊的数学计算符号往往在键盘上无法找到。特此,为了以后寻找方面,将一些常用的数学计算符号等进行汇总:
python 绘图时显示不同的数学符号alpha,beta,偏导、求和等等
|
图形学
Unity Mathf【Deg & Rad】- 关于数学运算中的度与弧度
Unity Mathf【Deg & Rad】- 关于数学运算中的度与弧度
271 1
Unity Mathf【Deg & Rad】- 关于数学运算中的度与弧度
数学——图形题
数学——图形题
148 0
数学——图形题