HTML5 简单画图,切片,变形
本人是在校学生,由于这段时间不知道怎么回事,心情比较无聊没有事干,所以利用这段时间学一下HTML5,发博客的目的是为了以后可以查询,也希望各位大神能够指导像我们这样的菜鸟,告别菜鸟的时段
我学东西时候有一个习惯,就是把已学知识做一个东西出来,这样可以提高兴趣,于是想起XNA 的游戏结构,想通过这个结构用HTML 写一个游戏引擎,本人是菜鸟 不要指望我有多么厉害
首先我们必须掌握HTML5的一些基本知识,:
canvas: 在HTML5中新增的元素,他相当与游戏中的场景或者画布,想这样编程方面的东西 代码 胜过文语
<!DOCTYPE html>
<meta charset="utf-8">
<html>
<head>
<title></title>
<script type="text/javascript" src="NANF.js"></script>
<script type="text/javascript">
$$(function(){
//得到canvas元素
var c=document.getElementById("myCanvas");
//得到画布
var ctx= c.getContext("2d");
//擦除画布
ctx.clearRect(0,0,400,400);
ctx.fillStyle="red";
ctx.fillRect(20,20,75,50);
//这里处理两个矩形谁在上, source-over 原矩形在上
ctx.globalCompositeOperation="source-over";
ctx.fillStyle="blue";
ctx.fillRect(50,50,75,50); ctx.globalCompositeOperation="destination-over";
ctx.fillStyle="yellow";
ctx.fillRect(30,30,75,50); // destination-over 目标矩形在上
ctx.globalCompositeOperation="destination-over"; var img=new Image();
img.src="jian.png";
//画图
ctx.drawImage(img,0,0,200,200); });
</script> </head>
<body onload="">
<canvas id="myCanvas"></canvas>
</body>
</html>
上面的代码有一个地方要搞清楚 ctx.globalCompositeOperation="source-over"; 各个画东西相交处的处理方式,更多地方
参考HTML5 w3c 文档
下面要讲到的是一张图片的切片:
大家有没有注意 动画的基本原理是一系列图片组成的。。而这些图片都在一张图片上,通过切片的方式 ,可以循环画出指定动作的图片,这里就不用代码演示了,说一下函数就行了
ctx.drawImage(image,sourceX,sourceY,sourceWidth,sourceHeigh,dwX,dwY,dwWidth,dwHeigth);
image: 是一个图片对象
sourceX,sourceY,sourceWidth,sourceHeigh,这四个参数在图片上指定一个区域,画的时候就画那个区域
dwX,dwY:这画布上指定 x 轴 和 y 轴
dwWidth , dwHeigth :图片上指定一个区域图片 画在 画布上宽高
最后我们介绍一下图片变形
ctx.translate(x,y) : 这是平移函数
ctx.rotate(Ang) : 按弧度旋转
ctx.scale(x,y) : 按x,y 方向进行缩放
上面这些 函数 学了一下Gui 的人都知道。。。。。我就不过多的解释了,不过下面介绍的函数我会贴出代码来,因为是做游戏的核心。
是否大家玩游戏的时候有没有注意到 (天龙八部,斗战神) 瀑布的水,河里的水 他们的流动好逼真,用上面的一个函数是很难做到的,所以我们要根据顶点来画图。 有没有有人知道游戏的基元是三角型,三角型有三个顶点 正好组成一个面 ,如果不清楚的可以问度娘和谷爸,废话就不多说了
ctx.createPattern(image,"repeat-y"); 为贴图图像创建一个模式 ;更多内容点击这里
代码:
<!DOCTYPE html>
<meta charset="utf-8">
<html>
<head>
<title></title>
<script type="text/javascript" src="NANF.js"></script>
<script type="text/javascript">
$$(function(){
//得到canvas元素
var c=document.getElementById("myCanvas");
//得到画布
var context= c.getContext("2d");
//擦除画布 var image=new Image();
image.src="hello.jpg";
var imgPattern=context.createPattern(image,"repeat-y");
//重置路径
context.beginPath();
//设置绘制句柄
context.fillStyle=imgPattern;
//绘制路线,第一个点
context.moveTo(50,50);
context.lineTo(60,500);
context.lineTo(400,400);
//绘制路径第四个点
context.lineTo(500,50);
context.closePath();
context.fill();
//结束路径
context.closePath();
});
</script> </head>
<body onload="">
<canvas width="1366" height="768" id="myCanvas"></canvas>
</body>
</html>
在绘制路径中可以指定三个点 和 四个顶点 ,对于更多点我试了一次 ,有点不是我想要的结果,我想应该不可以
而下面我要介绍的函数等同于translate,rotate,scale ,他就是:
context.transform(a,b,c,d,e,f) 绘制一个矩形;通过 transform添加一个新的变换矩阵,再次绘制矩形;添加一个新的变换矩阵,然后再次绘制矩形。请注意,每当您调用 transform时,它都会在前一个变换矩阵上构建 ,更多内容点击这里
好了。。。所学的东西总结到这里
HTML5 简单画图,切片,变形的更多相关文章
- jmGraph:一个基于html5的简单画图组件
jmGraph:一个基于html5的简单画图组件 特性: 代码书写简单易理解 面向对象的代码结构 对图形控件化 样式抽离 模块化:入seajs实现模块化开发 兼容性:暂只推荐支持html5的浏览器:i ...
- HTML5 canvas画图
HTML5 canvas画图 HTML5 <canvas> 标签用于绘制图像(通过脚本,通常是 JavaScript).不过,<canvas> 元素本身并没有绘制能力(它仅仅是 ...
- html5 简单音乐播放器
html5 简单音乐播放器 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> < ...
- HTML5简单入门系列(五)
前言 本篇将讲述HTML5的服务器发送事件(server-sent event) Server-Sent 事件 Server-Sent 事件是单向消息传递,指的是网页自动获取来自服务器的更新. 以前的 ...
- html5 Canvas画图3:1px线条模糊问题
点击查看原文地址: html5 Canvas画图3:1px线条模糊问题 本文属于<html5 Canvas画图系列教程> 接上一篇canvas画线条教程 上次我们讲到,canvas有时候会 ...
- html5 canvas 画图移动端出现锯齿毛边的解决方法
使用HTML5的canvas元素画出来的.在移动端手机上测试都发现画图有一点锯齿问题 出现这个问题的原因应该是手机的宽是720像素的, 而这个canvas是按照小于720像素画出来的, 所以在720像 ...
- HTML5 Canvas画图与动画学习59例
HTML5 Canvas画图与动画学习59例 学习HTML5 动画,画图的好资料. HTML5 Canvas画图与动画学习59例
- HTML5 Canvas 画图入门
HTML5 Canvas 画图入门 HTML5 Canvas 画图入门,仅供学习參考 <!DOCTYPE html> <html> <head> <meta ...
- HTML5 Canvas 画图组件 All In One
HTML5 Canvas 画图组件 All In One Canvas SVG Canvas + SVG refs https://www.infoq.cn/article/1BVg9VDSmqyHv ...
随机推荐
- ecshop在nginx下实现负载均衡
ecshop在负载方面的功能是十分弱小的.当你的IP每个小时到达了一万IP.如果在带宽和服务器硬件有限的情况下.你的服务器很快就会崩溃的.网站直接挂掉.为了增强ecshop在负载均衡方面的能力.我们可 ...
- (转载).Net HttpPost的发送和接收示例代码
HttpPost在不同系统进行数据交互的时候经常被使用.它的最大好处在于直接,不像Webservice或者WCF需要wsdl作为一个双方的"中介".在安全性上,往往通过IP限制的方 ...
- jdk .tar.gz 包安装 inAction
方法参考于http://blog.sina.com.cn/s/blog_81631744010137iy.html, 多谢博主分享,此处仅作为个人学习笔记. 首先将*.tar.gz解压 tar -xz ...
- qt5 基础知识
QWidget wQLineEdit edit; edit.show(); //如果没有这句,编辑框edit将会显示在父窗口的左上角edit.setParent(&w); //以w为父窗口并显 ...
- android开发环境重装系统之后的配置
前提: 之前配置好的android开发环境:重装系统:压缩了android目录 配置: 安装java环境 安装; 建立JAVA_HOME变量:JAVAHOME添加到path变量 JAVA_HOME=C ...
- 第 6 章 抽象工厂模式【Abstract Factory Pattern】
以下内容出自:<<24种设计模式介绍与6大设计原则>> 好了,我们继续上一节课,上一节讲到女娲造人,人是造出来了,世界时热闹了,可是低头一看,都 是清一色的类型,缺少关爱.仇恨 ...
- SQL2005 安装时 “性能监视器计数器要求(错误)” 解决方案
转自SQL2005 安装时 "性能监视器计数器要求(错误)" 解决方案 出现此类问题一般都是在非法卸载sql2005出现的 在 "开始" --> &qu ...
- Sectong日志分析
http://tech.uc.cn/?p=2866#comments http://blog.sectong.com/blog/hw_bigdata.html
- Android开源项目发现---ViewPager 、Gallery 篇(持续更新)
1. Android-ViewPagerIndicator 鼎鼎大名,配合ViewPager使用的Indicator,支持各种位置和样式 项目地址:https://github.com/JakeWh ...
- GDI+编程说明及小结
原文地址:http://blog.csdn.net/byxdaz/article/details/5972759 GDI+(Graphics Device Interface Plus图形设备接口加) ...