【HTML5初探之绘制图像(上)】看我canvas元素引领下一代web页面

简介:
导航

【初探HTML5之使用新标签布局】用html5布局我的博客页!

【HTML5初探之form标签】解放表单验证、增加文件上传、集成拖放

【HTML5初探之绘制图像(上)】看我canvas元素引领下一代web页面

【HTML5初探之绘制图像(下)】看我canvas元素引领下一代web页面

【HTML5初探之多媒体元素】视频播放HTML5、Flash谁才是王道?

【HTML5初探之本地存储】如果没有数据库。。。

【HTML5初探之离线应用】如何打造零请求、无流量的网站?

【HTML5初探之通信API】跨域门槛不再高、数据推送不是梦

【HTML5初探之Web Workers】网页也能多线程

【HTML5初探之Geolocation API】让我们来回去地理信息

 

前言

最近小弟够活跃了,主要是思想上发生了改变,有了明确的目的性,整个人有干劲多了。

但是,其实小弟写的东西很乱,至少最近这些东西很乱就是了,因为我是边看书边写博客,就当读书笔记似的,希望各位包涵。

HTML5前端初探是一个系列,我会从头到尾学习HTML5与CSS3形成两个系列“HTML5初探”、“CSS3初探”,

然后再做第二次学习,将第一次没有弄懂的全部搞懂,将一些需要扩展的做扩展。

号外:学到这一章,书莫名其妙的变成了彩色的了哟
八卦一下

呵呵,这里小弟八卦一下,小弟一直在关注”失业的程序员“一文的大哥,抛开创业故事、创业经历不说,对于其中学姐、博主、卞工之间的故事非常感兴趣。

学姐绝对是女神般的存在,这种学姐谁不喜欢呢?所以说不好是三角恋哦,但是,当我看到最近的一期卞工相亲,我发现我错了,我真的大错特错!!!

卞工相亲要带上博主,而最后居然很诡异的向博主说出他已心有所属!!!然后在回想之前死心塌地的跟着博主出来创业,再到后面时时刻刻关注博主和学姐的发展,

甚至主动和学姐联系(关心之间关系),我一直认为卞工会不会也是”尊敬“学姐呢?但是新的一期结束后,我的出了结论:绝对不是!!!

其实卞工自始至终爱的都只是一个人......此处省略三千字
  

呵呵,希望博主不要见怪,他的故事非常精彩,又出的慢,小弟等不及这里小小调侃一下,万望海涵。 

初识canvas元素

HTML5新增了一个元素canvas,用于绘图使用,其实它的表现和div比较接近(其实他应该属于inline-block),而提供了许多接口,从而轻易的绘制矩形框、园三角形等

PS:关于HTML5新增元素

经过最近两天的学习,和以前对HTML5的认知,我认为HTML5其实还是HTML4,两者之间没多大的区别,无非是增加了点新东西。<br>我认为HTML5为我们带来的真正意义是:我们可以用javascript做更多的事情了;我们可以用javascript实现更好的产品了。
比如HTML5就解决了我们头疼的跨域问题、实时通信API、与现在的canvas
之所以HTML5叫HTML5,我认为他是划时代的,比如他让我们用网页开发游戏变成可能;比如他让电脑桌面只剩IE不在是传说(过于夸张)
  

绘制矩形框

直入正题,我们来绘制一个矩形框看看,这里提供一个颜色选择器用于方便的选择颜色,PS:现在不用jquery编程感觉真麻烦。。。

 问题:定义样式与定义height与width

 一来就遇到了问题,我这里先来截个图:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <script type="text/javascript">
        function draw() {
            //获取canvas对象
            var canvas =  document.getElementById('canvas');
            if (canvas == null) {
                return false;
            }
            var context = canvas.getContext('2d');
            context.fillStyle = '#99d9ea';
            context.fillRect(0, 0, 300, 200); //填充画布结束
 
            context.strokeStyle = 'red';
            context.fillStyle = 'gray';
            context.lineWidth = 1;
            context.fillRect(10, 10, 100, 100);
            context.strokeRect(10, 10, 100, 100);
 
            context.clearRect(20, 20, 20, 20);
        }
    </script>
</head>
<body>
    <canvas id="canvas" width=300 height="200" style="border: 1px solid black; width: 300px; height: 200px;">
    </canvas>
    <br />
    <button onclick="draw();">
        绘制矩形</button>
    <input type="color" />
</body>
</html>
  各位情况canvas元素,图一位设置width与height的情况,图二十用style指定的情况:



可以看到,对于canvas来说,还是老老实实定义高宽的好,别去傻乎乎的用样式了,当然这个问题需要实际研究才能得出最终结论。

好了,现在我们再来看看绘制矩形这个方法:

PS:其实,使用该方法这么麻烦,完全可以将该函数封装下下,使用便会简单许多
1、使用getElementById方法获取绘制对象
2、取得上下文getContext('2d'),这都是固定的写法
3、指定填充的颜色fillStyle和绘制的颜色strokeStyle,即里面的颜色和边框的颜色
4、指定线宽linewidth
5、填充/绘制 fillRect/strokeRect 参数为 x,y,width,height
6、若是要使其中一块透明,使用clearRect
至此,绘制矩形框便暂时告一段落。

绘制圆形

现在我们来绘制圆形,这个说起绘制圆形,其实我原来用js好像写过一个,这里也贴出来看看:

我是纯js画的圆


话说,他还是比较圆的说。。。

进入正题

说起画圆、正弦图等肯定会经过一定计算的,所以稍稍复杂点:

① 创建路径

② 创建图形路径

③ 路径创建完成后关闭路径

④ 设定绘制样式调用方法绘制之

我是一个圆


我们来看看绘制圆过程中其它地方都没有问题,但是创建圆路径这块值得考虑:

arc方法参数很多,依次是:
x
y
半径
开始弧度(我们一般喜欢角度,所以要转换)
结束弧度
顺时针或者逆时针true为顺时针<br>其它都好说,主要这个开始角度和结束角度我们来研究下,因为开始我没搞懂,但后来我发现他其实很简单了。。。
就是开始的角度和结束的角度嘛,和我们高中学的知识一样的,只不过单位换算Math.PI/180为一度。。。。<br>反正还是没说清楚,对了,记得我们高中画圆的除了圆规和一个计量三角形角度的半圆直尺了吗,我要说的角度就是那个。。。太坑爹了!<br>好像最右边是0度,垂直是90度,水平是180度,既然如此,我们再来看看
 

正时针逆时针


我们发现正时针与逆时针还是有所不同的,

1  context.arc(180, 180, 50, 90 * Math.PI / 180, 290 * Math.PI / 180, true);
原谅我这里居然思考了半个小时,我甚至搜索了高中的资料。。。。


于是我好像明白了点什么。。。。。。

moveTo与lineTo

现上实验结果:

两次moveto
一次moveto
三次moveto
以上代码几乎一样,但是他产生的结果却不同:


我认为,使用moveto后相当于新开一起点,之前的一笔勾销,
若是只使用lineto的话,他会将几个点连成线,若是可以组成图形便会拥有中间色彩
  

 结语

 这章内容还比较多,我今天大概到极限了,换个时间再将他结束。 

您可以考虑给小钗发个小额微信红包以资鼓励 





本文转自叶小钗博客园博客,原文链接http://www.cnblogs.com/yexiaochai/archive/2013/04/17/3027220.html如需转载请自行联系原作者
相关文章
|
传感器 弹性计算 安全
从0开始的mqtt服务器
本篇文章将会介绍如何利用阿里云搭建一个属于自己的mqtt服务器
从0开始的mqtt服务器
|
数据可视化 数据挖掘 Java
提升代码质量与效率的利器——SonarQube静态代码分析工具从数据到洞察:探索Python数据分析与科学计算库
在现代软件开发中,保证代码质量是至关重要的。本文将介绍SonarQube静态代码分析工具的概念及其实践应用。通过使用SonarQube,开发团队可以及时发现和修复代码中的问题,提高代码质量,从而加速开发过程并减少后期维护成本。 在当今信息爆炸的时代,数据分析和科学计算成为了决策和创新的核心。本文将介绍Python中强大的数据分析与科学计算库,包括NumPy、Pandas和Matplotlib,帮助读者快速掌握这些工具的基本用法和应用场景。无论是数据处理、可视化还是统计分析,Python提供了丰富的功能和灵活性,使得数据分析变得更加简便高效。
|
人工智能 数据安全/隐私保护 计算机视觉
GitHub爆款神器 | IOPaint:21.7k star 开源AI图像修复项目,竟能秒删水印、拓展画幅!
IOPaint 是一款由 Sanster 团队开发的开源图像处理工具,集成多种 SOTA AI 模型,支持图像擦除、对象替换、文本绘制和图像外扩等功能。它操作简便,一键安装,适用于 Windows、macOS、Linux 和 Apple Silicon 系统,适合摄影爱好者、电商从业者及内容创作者使用,大幅提升图像处理效率。
2311 0
|
人工智能 运维 Cloud Native
开源聚合平台 Websoft9:开源创新已成为中小企业数字化转型、数据驱动企业的基础
Websoft9作为全球领先的开源聚合平台,助力中小企业通过开源软件实现数字化转型。其AI驱动的开源操作系统破解技术鸿沟,提供智能选型、云原生部署和智能运维三大引擎,降低企业成本并提升效率。某跨境电商案例显示,Websoft9帮助其实现建站、数据分析、智能客服及ERP升级等全面优化。平台将企业IT投入降至$99/月起,应用上线周期缩短至72小时,系统可用性达99.95% SLA保障。
364 2
开源聚合平台 Websoft9:开源创新已成为中小企业数字化转型、数据驱动企业的基础
|
机器学习/深度学习 人工智能 自然语言处理
数字化转型需要的技术:生成式AI时代的全栈能力图谱
本文探讨生成式AI推动下的数字化转型技术需求转变,从技术本质、实施路径、伦理规制三方面解构核心要素。技术本质从工具理性进化到能力体系,需建立模型思维、多模态交互和自主进化能力。实施路径分为认知重构、实验验证与迭代优化三个阶段。同时,文章介绍生成式人工智能认证(GAI认证)的战略价值,强调其在能力基准建立、技术合作及创新生态接入中的作用。最后,文章分析组织能力进化与未来技术前沿,如认知智能、具身智能和群体智能的演进方向,为企业提供全面的技术赋能与战略转型指导。
|
JavaScript Linux iOS开发
|
存储 人工智能 Kubernetes
MiniMax云上AI数据湖最佳实践
本简介介绍MiniMax云上AI数据湖的最佳实践。MiniMax成立于2021年,专注于通用人工智能领域,提供ToB和C端产品。面对每日3万亿token、2000万张图片及7万小时语音数据的处理需求,MiniMax基于阿里云构建了稳定灵活的基础设施,采用多云策略实现全球化部署。通过引入Kubernetes、Ray等技术,优化了多模态数据处理效率,并利用对象存储与数据湖技术降低成本。此外,与阿里云合作开发边缘缓存方案,提升跨地域数据传输效率。主讲人:阿里云弹性计算技术专家高庆端。
952 10
|
传感器 算法 安全
CAN 帧中 CRC 场的作用
CAN帧中的CRC场用于检测数据传输错误,通过计算发送数据的校验码并在接收端进行验证,确保数据的完整性和准确性。
WK
|
索引 Python
Python占位符
在Python中,字符串格式化常用占位符插入变量值。主要方法有:1) 百分号 (%) 格式化,使用 %s、%d 等;2) str.format() 方法,使用 {} 和索引/关键字参数;3) F-strings,从Python 3.6开始,前缀 f 或 F,更简洁;4) Template 字符串,使用 $ 符号;5) format_map() 方法,使用字典参数。每种方法各有优缺点,适用于不同场景。
WK
964 3
|
网络协议 API 开发者
Python中的会话管理:requests.Session深度解析
Python中的会话管理:requests.Session深度解析

热门文章

最新文章