JavaScript+html5 canvas繪制的小人效果
本文實(shí)例講述了JavaScript+html5 canvas繪制的小人效果。分享給大家供大家參考,具體如下:
運(yùn)行效果截圖如下:
index.html代碼如下:
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-type" content="text/html;charset=UTF-8" /> <title>canvas中的縮放</title> <style type="text/css"> #canvas { background:black; margin-top:100px; margin-left:200px; } </style> </head> <body> <canvas id="canvas" width="500px" height="500px" ></canvas> </body> <script type="text/javascript" src="canvas.js"></script> <script type="text/javascript"> 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); </script> </html>
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; } })();
更多關(guān)于js特效相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jQuery動(dòng)畫(huà)與特效用法總結(jié)》、《jQuery常見(jiàn)經(jīng)典特效匯總》及《JavaScript動(dòng)畫(huà)特效與技巧匯總》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- JS+HTML5 Canvas實(shí)現(xiàn)簡(jiǎn)單的寫(xiě)字板功能示例
- Javascript HTML5 Canvas實(shí)現(xiàn)的一個(gè)畫(huà)板
- html5+javascript制作簡(jiǎn)易畫(huà)板附圖
- javascript結(jié)合html5 canvas實(shí)現(xiàn)(可調(diào)畫(huà)筆顏色/粗細(xì)/橡皮)的涂鴉板
- JS+html5 canvas實(shí)現(xiàn)的簡(jiǎn)單繪制折線圖效果示例
- js+html5實(shí)現(xiàn)canvas繪制圓形圖案的方法
- js+html5實(shí)現(xiàn)canvas繪制鏤空字體文本的方法
- js+html5繪制圖片到canvas的方法
- js HTML5 Canvas繪制轉(zhuǎn)盤(pán)抽獎(jiǎng)
- javascript+HTML5 Canvas繪制轉(zhuǎn)盤(pán)抽獎(jiǎng)
- 原生JS+HTML5實(shí)現(xiàn)的可調(diào)節(jié)寫(xiě)字板功能示例
相關(guān)文章
javascript中json對(duì)象json數(shù)組json字符串互轉(zhuǎn)及取值方法
這篇文章主要介紹了javascript中json對(duì)象json數(shù)組json字符串互轉(zhuǎn)及取值方法,需要的朋友可以參考下2017-04-04Bootstrap學(xué)習(xí)筆記之js組件(4)
這篇文章主要為大家詳細(xì)介紹了Bootstrap學(xué)習(xí)筆記之js組件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-06-06jQuery實(shí)現(xiàn)文字自動(dòng)橫移
本文詳細(xì)介紹了通過(guò)jquery尺寸相關(guān)函數(shù)實(shí)現(xiàn)文字自動(dòng)橫移的方法。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01JavaScript中isPrototypeOf函數(shù)作用和使用實(shí)例
這篇文章主要介紹了JavaScript中isPrototypeOf函數(shù)作用和使用實(shí)例,本文講解了它的作用和使用方法以及使用實(shí)例,需要的朋友可以參考下2015-06-06詳解javascript的變量與標(biāo)識(shí)符
這篇文章主要為大家介紹了javascript的變量與標(biāo)識(shí)符,感興趣的小伙伴們可以參考一下2016-01-01JavaScript實(shí)現(xiàn)控制并發(fā)請(qǐng)求數(shù)量的方法詳解
這篇文章主要為大家詳細(xì)介紹了JavaScript如何實(shí)現(xiàn)控制并發(fā)請(qǐng)求數(shù)量,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02