.save() 和 .restore()

  • 除了会保存之前的样式,还会保存之前的坐标轴

pen.translate(x, y);

将画布的 坐标轴原点(0, 0) 从画布的左上角,移动到 (x, y)

  • 必须再绘制之前,移动坐标轴
  • 改变 画布坐标轴 之前的绘制,不受影响。

pen.scale(x, y);

x    设置水平方向上缩放倍数

y    设置垂直方向上缩放倍数

  • 参照画布 绘制坐标轴原点(0, 0)

pen.rotate(radian);

radian    弧度    = deg*Math.PI/180

  • 参照画布 的绘制坐标轴原点 (0, 0)        radian 增大 顺时针旋转 坐标轴
  • 本次旋转,会参照此刻坐标轴的角度,累加旋转,

旋转 案例

  • <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8" />
    <title>旋转</title> <style type="text/css">
    body {
    width: 100%;
    color: #000;
    background: #96b377;
    font: 14px Helvetica, Arial, sans-serif;
    } #wrap {
    /*
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    */
    }
    </style>
    </head> <body> <div id="wrap">
    <canvas id="my_canvas" width="600" height="600">
    您的浏览器不支持 canvas,建议更新或者更换浏览器。
    </canvas>
    </div> <!-- javascript 代码 -->
    <script type="text/javascript">
    // 1. 获取画板
    var myCanvas = document.getElementById("my_canvas"); // 给画布一个颜色
    myCanvas.style.backgroundColor = "#eee"; // 2. 获取画笔
    var pen = myCanvas.getContext("2d"); // 3. 一定要在绘制之前 设置好
    pen.fillStyle = 'olive'; // 填充的颜色
    pen.strokeStyle = "blue"; // 笔的颜色
    pen.lineWidth = 4; // 笔宽
    pen.lineCap = "round"; // 圆形结束
    pen.lineJoin = "round"; // 圆角 var radian = 0; var chgScale = 1;
    var val = -0.1;
    window.setInterval(function(){
    chgScale += val;
    if(chgScale < 0 ){
    val = 0.1;
    chgScale = 0+0.1;
    }
    if(chgScale > 2){
    val = -0.1;
    chgScale = 2-0.1;
    } pen.restore();
    // 4.开始绘制
    pen.clearRect(0, 0, myCanvas.width, myCanvas.height);
    pen.beginPath();
    pen.save();
    pen.translate(200, 200);
    pen.scale(chgScale, chgScale);
    pen.rotate(radian*Math.PI/180);
    pen.arc(0, 0, 100, 0, 2*Math.PI);
    pen.rect(0, 0, 100, 100);
    pen.stroke();
    radian += 4.5;
    }, 1000); </script>
    </body>
    </html>

钟表 案例

  • <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8" />
    <title>DIY Clock</title> <style type="text/css">
    body {
    width: 100%;
    color: #000;
    background: #96b377;
    font: 14px Helvetica, Arial, sans-serif;
    } #wrap {
    padding-left: 160px;
    padding-top: 160px;
    /*
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    */
    }
    </style>
    </head> <body> <div id="wrap">
    <canvas id="my_canvas" width="600" height="600">
    您的浏览器不支持 canvas,建议更新或者更换浏览器。
    </canvas>
    </div> <!-- javascript 代码 -->
    <script type="text/javascript">
    // 1. 获取画板
    var myCanvas = document.getElementById("my_canvas"); // 给画布一个颜色
    myCanvas.style.backgroundColor = "#eee"; // 2. 获取画笔
    var pen = myCanvas.getContext("2d"); // 3. 一定要在绘制之前 设置好
    pen.fillStyle = '#D40000'; // 填充的颜色
    pen.strokeStyle = "#000"; // 笔的颜色
    pen.lineWidth = 4; // 笔宽
    pen.lineCap = "round"; // 圆形结束
    pen.lineJoin = "round"; // 圆角 window.setInterval(diyClock, 1000); // 封装 diy 时钟
    function diyClock(){
    pen.clearRect(0, 0, myCanvas.width, myCanvas.height); pen.save();
    pen.translate(300, 300);
    //将整个画布逆时针旋转90度
    pen.rotate(-90*Math.PI/180); pen.scale(0.5, 0.5); // 表盘 圆盘颜色:#325FA2 圆盘宽度:14 圆盘半径:140
    pen.save();
    pen.strokeStyle = "#325FA2";
    pen.lineWidth = 14;
    pen.beginPath();
    pen.arc(0, 0, 140, 0, 2*Math.PI);
    pen.stroke();
    pen.restore(); // 分刻 宽度为4 长度为3 外层空心圆盘与分刻之间的距离也为20
    pen.save();
    var i = 0;
    for(i=0; i<60; i++){
    if(i%5 != 0){
    pen.beginPath();
    pen.moveTo(0, -120);
    pen.lineTo(0,-117);
    pen.stroke();
    };
    pen.rotate(6*Math.PI/180);
    };
    pen.restore(); // 时刻 宽度为8 长度为20 外层空心圆盘与时刻之间的距离也为20
    pen.save();
    pen.lineWidth = 8;
    for(i=0; i<12; i++){
    pen.beginPath();
    pen.moveTo(0, -120);
    pen.lineTo(0, -100);
    pen.stroke();
    pen.rotate(30*Math.PI/180);
    };
    pen.restore(); var curTime = new Date();
    var seconds = curTime.getSeconds();
    var minutes = curTime.getMinutes()+seconds/60;
    var hours = curTime.getHours()+minutes/60; // 时针 宽度为14 圆心外溢出80 收20
    pen.save();
    pen.rotate(30*hours*Math.PI/180);
    pen.lineWidth = 14;
    pen.beginPath();
    pen.moveTo(-20,0);
    pen.lineTo(80,0);
    pen.stroke();
    pen.restore(); // 分针 宽度为10 圆心外溢出112 收28
    pen.save();
    pen.rotate(6*minutes*Math.PI/180);
    pen.lineWidth = 10;
    pen.beginPath();
    pen.moveTo(-28,0);
    pen.lineTo(112,0);
    pen.stroke();
    pen.restore(); // 秒针 颜色:#D40000 宽度为6 圆心外溢出83 收30
    pen.save();
    pen.rotate(6*seconds*Math.PI/180);
    pen.strokeStyle = "#D40000";
    pen.fillStyle = "#D40000";
    pen.lineWidth = 6; pen.beginPath();
    pen.moveTo(-30, 0);
    pen.lineTo(83, 0);
    pen.stroke(); // 秒针头 96码开外半径为10的空心圆 宽度为6
    pen.beginPath();
    pen.arc(96, 0, 10, 0, 2*Math.PI);
    pen.stroke(); // 表芯半径为10的实心圆
    pen.beginPath();
    pen.arc(0, 0, 10, 0, 2*Math.PI);
    pen.fill();
    pen.restore();
    pen.restore();
    };
    </script>
    </body>
    </html>

HTML5_canvas_pen.translate()_的更多相关文章

  1. VSTO学习笔记(十四)Excel数据透视表与PowerPivot

    原文:VSTO学习笔记(十四)Excel数据透视表与PowerPivot 近期公司内部在做一种通用查询报表,方便人力资源分析.统计数据.由于之前公司系统中有一个类似的查询使用Excel数据透视表完成的 ...

  2. knowledgeroot 配置

    首先下载 KnowledgeRoot 的安装包,就是一个压缩文件,解压缩后放到 WebRoot 下面 在浏览器中打开网站,自动提示进行安装,安装的过程很简单,安装结束后即可以使用. 安装包创建的数据库 ...

  3. knowledgeroot

    knowledgeroot 示例站点 www.globaladmin.cn Knowledgeroot可用于文档管理,知识库管理. 1.基于php开发,支持linux ,windows.2.支持mys ...

  4. -_-#【Canvas】measureText, translate, drawImage

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  5. python基础-基本数据类型总结_整型(int)_字符型(str)_day3

     一.基本数据类型 1.整型(int) ps1:数字 int ,所有的功能,都放在int里a1 = 123a1 = 456 ps2: int 将字符串转换为数字 # -int # 将字符串转换为数字 ...

  6. HTML5_画布_太阳系

    HTML5_画布_太阳系 一.canvas属性和方法的简单介绍①对于不支持canvas标签的浏览器需要显示"不支持canvas"使用IE11浏览器的开发人员工具,仿真:文档模式=8 ...

  7. translate函数说明

    TRANSLATE(expr, from_string, to_string) from_string 与 to_string 以字符为单位,对应字符一一替换. SQL> SELECT TRAN ...

  8. kubernetes 实战6_命令_Share Process Namespace between Containers in a Pod&Translate a Docker Compose File to Kubernetes Resources

    Share Process Namespace between Containers in a Pod how to configure process namespace sharing for a ...

  9. python之模块_随手记录的模块

    目录 1.StringIO模块 2.string模块 3.pprint模块 4.struct模块 5.uuid模块 6.itertools 7.prettytable 1.StringIO (1)使用 ...

随机推荐

  1. centos7防火墙设置

    前言 CentOS7 与之前版本在防火墙配置上不同,防火墙从iptables变成了firewalld Centos7默认安装了firewalld,如果没有安装的话,可以使用yum命令进行安装 yum ...

  2. 深入学习CSS外边距margin(重叠效果,margin传递效果,margin:auto实现块级元素水平垂直居中效果)

    前言 margin是盒模型几个属性中一个非常特殊的属性.简单举几个例子:只有margin不显示当前元素背景,只有margin可以设置为负值,margin和宽高支持auto,以及margin具有非常奇怪 ...

  3. [物理学与PDEs]第5章第6节 弹性静力学方程组的定解问题

    5. 6 弹性静力学方程组的定解问题 5. 6. 1 线性弹性静力学方程组 1.  线性弹性静力学方程组 $$\bee\label{5_6_1_le} -\sum_{j,k,l}a_{ijkl}\cf ...

  4. webpack安装异常

    webpack中文指南:https://zhaoda.net/webpack-handbook/index.html 今天中午,我用   cnpm install   重新下载了一下项目的依赖,爆了一 ...

  5. Java反射定义、获取Class三种方法

    反射机制的定义: 在运行状态时(动态的),对于任意一个类,都能够得到这个类的所有属性和方法.  对于任意一个对象,都能够调用它的任意属性和方法. Class类是反射机制的起源,我们得到Class类对象 ...

  6. 6.linux安装tomcat

    1.下载安装包 https://tomcat.apache.org/download-80.cgi       2.用 WinSCP 将本地的安装包 上传到 linux 服务器中   3.解压安装包( ...

  7. 集合-Collections工具

    1.定义 Collections是集合类的一个工具类,它提供了一系列静态方法用于对容器中的元素进行排序和搜索等一系列操作. 注:Collection是一个集合接口,而Collections是一个有着操 ...

  8. Ubuntu查看端口占用情况

    netstat -apn 其中最后一列是PID,可以通过kill Pid进行结束进程. 更精确的查找: netstat -apn | grep 8080 查询8080端口的进程 如果要查询这个进程的详 ...

  9. 【原创】大数据基础之Spark(1)Spark Submit即Spark任务提交过程

    Spark2.1.1 一 Spark Submit本地解析 1.1 现象 提交命令: spark-submit --master local[10] --driver-memory 30g --cla ...

  10. 《剑指offer》字符串的排列

    本题来自<剑指offer> 反转链表 题目: 思路: C++ Code: Python Code: 总结: