canvas教程

在学习canvas中实现图片的浮雕效果时遇到的一点问题

字号+ 作者:H5之家 来源:H5之家 2015-09-29 18:01 我要评论( )

本帖最后由 u010513756 于 2015-08-30 20:46:43 编辑 问题我用问号标注出来了,先谢谢大家了 html部分 !DOCTYPEhtml html head metacharset="utf-8" title/title styletype="text/css" #canvas{ border:thinblacksolid; } /style /head body canvasid="canva

本帖最后由 u010513756 于 2015-08-30 20:46:43 编辑

问题我用问号标注出来了,先谢谢大家了
html部分
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<style type="text/css">
#canvas {
border: thin black solid;
}
</style>
</head>
<body>
<canvas id="canvas" width="800" height="600"></canvas>
<input type="button" name="show" id="show" value="浮雕效果" onclick="show()" />
</body>
javascript部分
var canvas = document.getElementById("canvas");
var context = canvas.getContext("2d");
var image = new Image();
image.src = "testImage.jpg";
context.drawImage(image, 0, 0);


function show() {
var imagedata, data, length, width;

imagedata = context.getImageData(0, 0, canvas.width, canvas.height);
data = imagedata.data;
width = imagedata.width;
length = data.length;

for(var i = 0; i < length; i++) {
//判断是否处在最后一行
if(i <= length - width * 4) {
//跳过Alpha属性
if((i+1) % 4 !== 0) {
//判断是否在每行的最后一个像素,不清楚为什么要添加这个判断
if((i+4) % (width*4) == 0) {
data[i] = data[i-4];
data[i+1] = data[i-3];
data[i+2] = data[i-2];
data[i+3] = data[i-1];
i += 4; //?这里也不清楚,加没加好像也一样
} else {
//?请问这里为什么要这样写
data[i] = 255/2 + 2*data[i] - data[i+4] - data[i+width*4];
//在网上还有一种说法叫做
//基于当前像素的前一个像素RGB值与它的后一个像素的RGB值之差再加上128
//与本例中的又有什么区别呢?
}
}
} else {
//最后一行的情况
//跳过Alpha属性
if((i+1) % 4 !== 0) {
//当前像素等于他的上一行像素?为什么要这样写
data[i] = data[i-width*4];
}
}
}
context.putImageData(imagedata, 0, 0);
};

分享到:

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • html5canvas核心技术图形、动画与游戏开发源码

    html5canvas核心技术图形、动画与游戏开发源码

    2017-05-02 17:42

  • 打印html5中Canvas的方法

    打印html5中Canvas的方法

    2017-05-01 15:03

  • HTML5+Canvas调用手机拍照功能实现图片上传(下)

    HTML5+Canvas调用手机拍照功能实现图片上传(下)

    2017-04-30 17:00

  • 学习慕课网canvas倒计时实例笔记

    学习慕课网canvas倒计时实例笔记

    2017-04-30 14:01

网友点评