失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > HTML5 Canvas实现图片缩放 翻转 颜色渐变的代码示例技巧

HTML5 Canvas实现图片缩放 翻转 颜色渐变的代码示例技巧

时间:2022-02-01 15:00:03

相关推荐

HTML5 Canvas实现图片缩放 翻转 颜色渐变的代码示例技巧

web前端|H5教程

Canvas,HTML5

web前端-H5教程

翻转、移动、平移、放大、缩小

仿安居客好租网房产源码,vscode导出目录结构,ubuntu显示异常,用tomcat发布工程,免费论坛爬虫,php导出html文件,海外官网seo权重评分,视频分享网站模板,空间模板制作教程lzw

XML/HTML Code复制内容到剪贴板

var canvas = document.getElementById(‘canvas’);

if (canvas.getContext) {

var context = canvas.getContext(‘2d’);

// 放大与缩小

context.beginPath();

context.strokeStyle = “#000000”;

context.strokeRect(10,10,150,100);

php music网站源码,75Ubuntu,tomcat关了之后打不开,爬虫以后发展,php 时间差 年,襄阳工程机械seo推广哪个好lzw

// 放大3倍

context.scale(3,3);

context.beginPath();

context.strokeStyle = ‘#cccccc’;

context.strokeRect(10,10,150,100)

工程进度管理源码,vscode编写css文件,Ubuntu设置修复,内置tomcat使用,c#sqlite多表查询,床垫下面有黄色爬虫卵,php的ksort,沧州seo优化排名,全屏背景网站如何做到自适应,网页下载进度条源码,资讯网站模板lzw

// 缩小

context.scale(0.5,0.5);

context.beginPath();

context.strokeStyle = ‘#cccccc’;

context.strokeRect(10,10,150,100)

// 翻转

var img = new Image();

img.src = ‘images/1.jpg’;

img.onload = function(){

context.drawImage(img, 10,10);

context.scale(1, -1);

context.drawImage(img, 0, -500);

}

// 平移

context.beginPath();

context.strokeStyle = ‘#000000’;

context.strokeRect(10,101,150,100);

// x移动 50 y 移动100

context.translate(50,100);

context.beginPath();

context.strokeStyle = ‘#cccccc’;

context.strokeRect(10,10,150,100);

// 旋转

context.beginPath();

context.strokeStyle = ‘#000000’;

context.strokeRect(200,50,100,50);

// 默认旋转是根据0,0中心,使用translate可以按照自己的设置的中心旋转

context.translate(250,75);

context.rotate(45 * Math.PI /180);

context.translate(-250, -75);

context.beginPath();

context.strokeStyle = ‘#cccccc’;

context.strokeRect(200,50,100,50);

// transform 矩阵

context.beginPath();

context.strokeStyle = ‘#000000’;

context.strokeRect(10,10,150,100);

context.transform(3,0,0,3,0,0);

context.beginPath();

context.strokeStyle = ‘#cccccc’;

context.strokeRect(10,10,150,100);

}

渐变、图像组合效果、颜色翻转

XML/HTML Code复制内容到剪贴板

var canvas = document.getElementById(‘canvas’);

if (canvas.getContext) {

var context = canvas.getContext(‘2d’);

// 线性绘制渐变

var grd = context.createLinearGradient(0,0,200,100);

// postion 必须是0.1-1.0之间的竖直,表示渐变中颜色的地点相对地位,color表示颜色

grd.addColorStop(0.1, “#00ff00”);

grd.addColorStop(0.8, “#ff0000”);

context.fillStyle = grd;

context.fillRect(0,0, 200,100);

// 径向渐变

var grd = context.createRadialGradient(100,100,10,100,100,50);

grd.addColorStop(0.1, “#00ff00”);

grd.addColorStop(0.8, ‘#ff0000’);

context.fillStyle = grd;

context.fillRect(0,0,200,200);

// 图像组合效果

context.fillStyle = ‘#00ff00’;

context.fillRect(10,10,50,50);

// 新绘图

//context.globalCompositeOperation = “source-over”;

// 只绘制新内容,删除其他所有内容

context.globalCompositeOperation = ‘copy’;

// 图形重叠的地方,其颜色值相减后决定

context.globalCompositeOperation = ‘darker’;

// 画布上已经有的内容只会载和其他图形重叠的地方保留

context.globalCompositeOperation = ‘destination-atop’;

// 参考 /htmldom/prop_canvasrenderingcontext2d_globalcompositeoperation.asp

context.beginPath();

context.fillStyle = ‘#ff0000’;

context.arc(50,50,30,0, 2 * Math.PI);

context.fill();

// 颜色翻转

var img = new Image();

img.src = ‘images/1.jpg’;

img.onload = function(){

context.drawImage(img, 0,0, 1, 1);

var imgData = context.getImageData(0,0, 1,1);

var pixels = imgData.data;

console.log(pixels);

for(var i = 0, n = pixels.length; i < n; i+=4) { pixels[i] = 255 – pixels[i]; pixels[i+1] = 255 – pixels[i + 1]; pixels[i+2] = 255 – pixels[i + 2];}context.putImageData(imgData, 250, 0); } }

如果觉得《HTML5 Canvas实现图片缩放 翻转 颜色渐变的代码示例技巧》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。