H5 canvas基础入门到捕鱼达人小游戏实现(3)-canvas运动入门,渐变,文字渲染,阴影

上一篇主要讲解了矩形柱状图,弧形和饼图的绘制,但是离我们的目标还是有点远,不要紧,我们基础api都还没有学习完,今天继续。

本节主要内容
- canvas画板制作
- 块的直线运动
- 粒子运动
- 线性渐变
- 径向渐变
- 文字渲染
- 阴影

canvas画板

canvas画板简单来说就是设置一块画布在上面自由画线,看看效果图
这里写图片描述

document.addEventListener('DOMContentLoaded',function(){
   
    var canvas = document.querySelector("#canvas");
    var context = canvas.getContext("2d");
    var oC = document.querySelector("#clear");
    canvas.onmousedown = function(e){
   
        context.beginPath();
        context.moveTo(e.pageX,e.pageY);
        document.onmousemove = function(e){
   
            context.lineTo(e.pageX,e.pageY);
            context.stroke();
        };
        document.onmouseup = function(){
   
            document.onmousemove=null;
            document.onmouseup=null;
        };
    };
    oC.onclick=function(){
   
        context.clearRect(0,0,canvas.width,canvas.height);
    };
},false);

这个代码还是比较简单的,这里有一点需要讲讲就是清除画板功能。

canvas.clearRect(x,y,w,h);
x,y:画布的位置
w,h:清除的宽高

其实这里有一个非常重要的知识点:整个canvas的动画其实都是依赖clearRect这个api来实现的,其实在上一篇文章中的动态柱状图中其实已经使用过该api。但是这里我还是想举一个简单的例子来看看是如何实现运动的。

块的直线运动

看看效果图:
这里写图片描述

看这图片我们分析下:
1、首先绘制一个方块
2、动态改变块的绘制位置
直接代码实现:

var oC = document.getElementById('c1');
    var gd = oC.getContext('2d');

    gd.beginPath();
    var k=1;
    function
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于Unity3D多平台网络斗地主的设计与实现毕业设计 目录 前言 1 第1章 概述 2 1.1 系统开发背景 2 1.2 设计的目的 3 1.3 设计的意义 3 第2章 开发环境及相关技术介绍 4 2.1 开发环境介绍 4 2.1.1 Unity3D简介 4 2.1.2 Visual Stdio2010和MonoDevelop 5 2.1.3 Xcode简介 5 2.2 C#语言和Javascript脚本 6 2.2.1 C#语言 6 2.2.2 Javascript语言 6 2.3 IOCP框架简介 7 2.3.1 IOCP内部工作队列图 7 2.3.2 程序实现IOCP模型的基本步骤 8 2.3.3 使用IOCP模型和不使用IOCP模型通讯的对比 8 2.4 本章小结 10 第3章 系统需求分析 10 3.1 用户功能需求分析 10 3.2 系统性能要求 10 3.3 可行性分析 10 第4章 总体方案设计 11 4.1 纸牌设计 11 4.1.1 牌型设计 11 4.1.2 出牌类型(游戏规则)设计 12 4.2 C/S模式 12 4.2.1 基于C/S模式的服务器端设计流程图 12 4.2.2 基于C/S模式的客户端设计流程图 12 4.3 游戏逻辑程序结构 13 4.3.1 数据层 13 4.3.2 控制层 13 4.3.3 显示层 14 4.4 游戏设计流程图 14 4.5 数学建模 15 第5章 详细设计与系统实现 16 5.1 斗地主洗牌算法 16 5.2 斗地主之"排序"算法 16 5.3 基于IOCP的Socket通讯 18 5.4 User对象的设计 19 5.4.1 玩家状态设计 19 5.4.2 玩家的属性以及手牌的操作方法 20 5.5 Table对象的设计 21 5.5.1 桌子状态设计 21 5.5.2 Table的属性及方法 21 5.6 粘包问题 23 5.6.1 TCP和UDP的介绍以及区别 23 5.6.2 粘包介绍及处理 23 第6章 发布和测试 25 6.1 服务器端性能检测 25 6.2 打包发布Android应用 27 6.2.1 导出Android设置 27 6.2.2 真机效果图 28 6.3 打包发布IOS应用 29 6.3.1导出IOS设置 29 6.3.2真机效果图 31 6.4 打包发布Web应用 32 6.4.1 关于UnityWebPlayer的SandBox Security(安全沙盒机制) 32 6.4.2 导出Web设置 32 6.4.3 运行结果 33 6.5 打包发布PC/Linux应用 34 6.6 整体测试效果 34 结束语 40 致谢 42 参考文献 43 附录A 网络斗地主的游戏规则 44 附录B 部分程序代码 47 前言 近年来,随着科技和互联网的飞速发展、智能手机的迅速普以及性能的不断提升,游 戏行业也突飞猛进,游戏已经逐渐成为人们公认的第九种艺术。现在各个平台上的游戏 逐渐涌现,从最初的红白机,到PC机再到XBox平台发展到如今的手机移动平台,从端游 到页游再到手游甚至是体感游戏等表现形式也逐渐丰富,当然成功的也数不胜数。比较 大型的游戏有:反恐精英、星际争霸、使命召唤,生化危机等。当然也涌现了诸多经典 的网络小游戏,比如麻将、拖拉机、中国象棋等。此外手机游戏,如愤怒的小鸟、保卫 萝卜、FlappyBird、切水果、捕鱼达人等也赢得许多人的青睐。这些各种各样形式的游 戏给如今生活在网络时代的人们带来了无限的生活乐趣。 斗地主是一款相当经典的游戏,当然前人也做了不少版本,有移动端,pc端甚至是W eb端的。可能他们在设计的过程中只是正对某一平台然后使用特性的开发技术来开发, 这样的话如果想要实现多平台的设计就需要极大的时间成本和劳力成本。而Unity3D引擎 的问世,最大的解决了这一问题,它能够实现一次开发多平台发布的特点,这也是为什 么Unity3D引擎在短暂的时间里能够发展的如此迅速的原因。将斗地主游戏从单机版到网 络化,使得现实中的多个玩家能够在同一个虚拟房间里面进行对局,并且能够实时的聊 天,同时还不会受到平台的限制,你可以选择pc,web或者是移动端,从而能更好的体验 游戏,娱乐生活。 第1章 概述 1.1 系统开发背景 随着Unity3D引擎的横空出世,游戏开发技术也变得越来越成熟,这款引擎也逐渐改 变了整个游戏圈的开发格局,之前火遍了全球的神庙逃亡就是基于Unity引擎开发的一款 比较成功的手游大作,这也更很好的证明了Unity作为一款游戏引擎还是值得开发者的信 赖。Unity相比较之前大家都熟悉的Unreal虚幻引擎,我认为Unity做的更好,它最值得 人称赞的就是它的跨平台性是其他游戏引擎无法匹敌的,Unity能够做到一次

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值