html5 js 实现刮刮卡效果
来源:互联网 发布:java服务器端开发技术 编辑:程序博客网 时间:2024/05/19 12:15
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0;" name="viewport" />
<title></title>
<style type="text/css">
body
{
width: 320px;
min-height: 568px;
overflow: hidden;
margin: 0;
}
#canvas
{
background: url(img/lzl.jpg);
/*奖品图片*/
fixed:center center no-repeat;
background-size: cover;
width: 320px;
min-height: 480px;
overflow: hidden;
position: relative;
}
.before
{
background: none !important;
}
#canvas canvas
{
cursor: url("img/bird.png") 0 0, auto;
/*PC端的手势图片*/
}
</style>
</head>
<body oncontextmenu="return false;" onselectstart="return false;">
<div id="canvas">
</div>
</body>
<script type="text/javascript">
(function () {
window.onload = function () {
/**禁止拖动设置*/
document.ontouchmove = function (e) {
e.preventDefault();
};
/**判断浏览器是否支持canvas**/
try {
document.createElement('canvas').getContext('2d');
} catch (e) {
var addDiv = document.createElement('div');
alert('您的手机不支持刮刮卡效果哦~!');
}
};
function createCanvas(parent, width, height) {
var canvas = {};
canvas.node = document.createElement('canvas');
canvas.context = canvas.node.getContext('2d');
//此处可以自己给标签添加
canvas.node.width = width || 320;
canvas.node.height = height || 480;
//给canvas标签添加Id
canvas.node.id = 'canvasTag';
parent.appendChild(canvas.node);
return canvas;
}
function init(container, width, height, fillColor, type) {
var canvas = createCanvas(container, width, height);
var ctx = canvas.context;
// define a custom fillCircle method
ctx.fillCircle = function (x, y, radius, fillColor) {
this.fillStyle = fillColor;
this.beginPath();
this.moveTo(x, y);
this.arc(x, y, radius, 0, Math.PI * 2, false);
this.fill();
};
ctx.clearTo = function (fillColor) {
ctx.fillStyle = fillColor;
ctx.fillRect(0, 0, width, height);
};
ctx.clearTo(fillColor || "#ddd");
canvas.node.addEventListener(mobile == "PC" ? "mousedown" : "touchstart", function (e) {
canvas.isDrawing = true;
}, false);
canvas.node.addEventListener(mobile == "PC" ? "mouseup" : "touchend", function (e) {
canvas.isDrawing = false;
}, false);
canvas.node.addEventListener(mobile == "PC" ? "mousemove" : "touchmove", function (e) {
if (!canvas.isDrawing) {
return;
}
if (type == 'Android') {
var x = e.changedTouches[0].pageX - this.offsetLeft;
var y = e.changedTouches[0].pageY - this.offsetTop;
} else {
var x = e.pageX - this.offsetLeft;
var y = e.pageY - this.offsetTop;
}
var radius = 20;
var fillColor = '#ff0000';
ctx.globalCompositeOperation = 'destination-out';
ctx.fillCircle(x, y, radius, fillColor);
}, false);
}
var u = navigator.userAgent, mobile = 'PC';
if (u.indexOf('iPhone') > -1) mobile = 'iphone';
if (u.indexOf('Android') > -1 || u.indexOf('Linux') > -1) mobile = 'Android';
var container = document.getElementById('canvas');
init(container, 320, 568, '#00930f', mobile);
})();
</script>
</html>
- html5 js 实现刮刮卡效果
- html5实现刮刮卡效果
- HTML5实现刮刮卡效果
- 使用HTML5实现刮刮卡效果
- 使用HTML5实现刮刮卡效果
- html5 canvas实现刮刮卡效果
- turn.js:超酷的杂志翻页效果HTML5实现
- js和html5实现手机端刮刮卡抽奖效果
- html5 js 实现浏览器全屏效果(F11)
- js+jquery实现html5的后台缓存书签效果
- HTML5 JS实现毛玻璃效果(高斯模糊)
- 【翻译+山寨】html5+css3+js实现翻页翻书效果
- HTML5实现圣诞树效果
- Html5实现拖动效果
- html5实现卡片效果
- html5实现动画效果
- HTML5 实现全屏效果
- chart.js + bootstrap +jquery.js 实现的 html5 图表绘制效果
- 三招帮你选择"合脚"ERP
- html中将不能完全显示的文字用...代替
- JQUERY 解析 XML
- [[[ java ]]] 数组 arrayList.contains(), arrayList.toArray();
- ORA-12519数据库连接间接性中断
- html5 js 实现刮刮卡效果
- Android Project Butter分析 .
- 10.31 动态绑定
- qemu-kvm: Migrate: socket bind failed
- POJ 1673 EXOCENTER OF A TRIANGLE(求三角形的垂心)
- Hadoop之MR的调优性能
- hdu1179——Ollivanders: Makers of Fine Wands since 382 BC.
- OpenGL学习 将不同纹理映射到不同面上
- tab和空格的转换