html绘制动态小人,JavaScript+html5 canvas绘制的小人效果

本文实例讲述了JavaScript+html5 canvas绘制的小人效果。分享给大家供大家参考,具体如下:

运行效果截图如下:

80fc87c94ec2e6e24341be4f52763423.png

index.html代码如下:

canvas中的缩放

#canvas {

background:black; margin-top:100px; margin-left:200px;

}

cache = {};

var offsetX = 50,

offsetY = 20;

cache.context = dyl.createContext('canvas');

dyl.rect(dyl.createColor(), 60 + offsetX, 0 + offsetY, 185, 100);

dyl.rect(dyl.createColor(), 100 + offsetX, 100 + offsetY, 100, 50);

dyl.rect(dyl.createColor(), 20 + offsetX, 150 + offsetY, 260, 200);

dyl.rect(dyl.createColor(), 80 + offsetX, 350 + offsetY, 30, 110);

dyl.rect(dyl.createColor(), 190 + offsetX, 350 + offsetY, 30, 110);

dyl.circle(dyl.createColor(), 115 + offsetX, 55, 20);

dyl.circle(dyl.createColor(), 190 + offsetX, 55, 20);

canvas.js代码如下:

(function() {

var dyl = {cache: {}};

dyl.setContext = function(context) {

dyl.cache._context = context;

return context;

}

dyl.getDom = function(id) {

return document.getElementById(id);

}

dyl._getContext = function() {

return dyl.cache._context;

}

dyl.save = function() {

var context = dyl._getContext();

context ? context.save() : void(0);

}

dyl.restore = function() {

var context = dyl._getContext();

context ? context.restore() : void(0);

}

dyl.createContext = function(canvasID) {

var canvas = this.getDom(canvasID);

if(!canvas) {

return null;

}

return dyl.setContext(canvas.getContext("2d"));

}

dyl.createColor = function() {

var color = "rgb(";

color += Math.round(Math.random()*255);

color += ",";

color += Math.round(Math.random()*255);

color += ",";

color += Math.round(Math.random()*255);

color += ")";

return color;

};

dyl.addImg = function(img, x, y) {

var context = dyl._getContext();

if(!img || !context) {

return;

}

if(typeof img === "string") {

var oImg = new Image();

oImg.src = img;

oImg.onload = function() {

context.drawImage(oImg, x, y);

}

return;

}

context.drawImage(img, x, y);

};

dyl.rect = function(color, x, y, width, height) {

var context = dyl._getContext();

if(!context) {

return;

}

context.fillStyle = color;

context.fillRect(x, y, width, height);

};

dyl.circle = function(color, x, y, r) {

var context = dyl._getContext();

context.save();

context.fillStyle = color;

context.beginPath();

context.arc(x, y, r, 0, 2*Math.PI);

context.fill();

context.stroke();

};

dyl.scale = function(x, y) {

var context = dyl._getContext();

if(!context) {

return;

}

x = x ? x : 1;

y = y ? y : 1;

context.scale(x, y);

};

if(!window.dyl) {

window.dyl = dyl;

}

})();

希望本文所述对大家JavaScript程序设计有所帮助。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值