iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >如何使用HTML5 Canvas实现图片缩放、颜色渐变效果
  • 159
分享到

如何使用HTML5 Canvas实现图片缩放、颜色渐变效果

2024-04-02 19:04:59 159人浏览 安东尼
摘要

这篇文章主要为大家展示了“如何使用HTML5 canvas实现图片缩放、颜色渐变效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用html5 Canva

这篇文章主要为大家展示了“如何使用HTML5 canvas实现图片缩放、颜色渐变效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用html5 Canvas实现图片缩放、颜色渐变效果”这篇文章吧。

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

var canvas = document.getElementById('canvas');   

if (canvas.getContext) {   

    var context = canvas.getContext('2d');   

    // 放大与缩小   

    context.beginPath();   

    context.strokeStyle = "#000000";   

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

    // 放大3倍   

    context.scale(3,3);   

    context.beginPath();   

    context.strokeStyle = '#cccccc';   

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

    // 缩小   

    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';   

     // 参考 Http://www.w3school.com.cn/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实现图片缩放、颜色渐变效果”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网JavaScript频道!

--结束END--

本文标题: 如何使用HTML5 Canvas实现图片缩放、颜色渐变效果

本文链接: https://www.lsjlt.com/news/91704.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何使用HTML5 Canvas实现图片缩放、颜色渐变效果
    这篇文章主要为大家展示了“如何使用HTML5 Canvas实现图片缩放、颜色渐变效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用HTML5 Canva...
    99+
    2024-04-02
  • HTML5中Canvas实现图片缩放、翻转、颜色渐变的示例分析
    这篇文章将为大家详细讲解有关HTML5中Canvas实现图片缩放、翻转、颜色渐变的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。翻转、移动、平移、放大、缩小XML/HTML Code复制内容到剪贴...
    99+
    2023-06-09
  • html5如何实现Photoshop渐变色效果
    小编给大家分享一下html5如何实现Photoshop渐变色效果,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! 代码如下: <!DOCTYPE html><head&...
    99+
    2024-04-02
  • 使用CSS3怎么实现颜色渐变效果
    本篇文章给大家分享的是有关使用CSS3怎么实现颜色渐变效果,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。<h2 class="site__title&...
    99+
    2023-06-08
  • HTML5 Canvas如何实现图片缩放比例
    小编给大家分享一下HTML5 Canvas如何实现图片缩放比例,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! drawImage方法的又一变种是增加了两个用于控制图像在canvas中缩放...
    99+
    2024-04-02
  • 如何使用Canvas画四渐变色播放按钮效果
    这篇文章给大家分享的是有关如何使用Canvas画四渐变色播放按钮效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 <canvas></canvas>是...
    99+
    2024-04-02
  • jQuery如何实现字体颜色渐变效果
    这篇文章给大家分享的是有关jQuery如何实现字体颜色渐变效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体如下:jQuery不允许css属性值为非数字的属性进行动画处理,比...
    99+
    2024-04-02
  • 怎么用javascript和HTML5 Canvas画渐变色播放按钮效果
    这篇文章主要介绍“怎么用javascript和HTML5 Canvas画渐变色播放按钮效果”,在日常操作中,相信很多人在怎么用javascript和HTML5 Canvas画渐变色播放按钮效果问题上存在疑惑...
    99+
    2024-04-02
  • 如何使用css3给图片实现渐变效果
    小编给大家分享一下如何使用css3给图片实现渐变效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!浏览器支持情况IEFFChro...
    99+
    2024-04-02
  • 如何使用CSS实现图片的缩放效果
    如何使用CSS实现图片的缩放效果在网页设计中,图片的缩放效果是常见的需求之一。通过CSS的相关属性和技巧,我们可以轻松地实现图片的缩放效果。下面,将为大家详细介绍如何使用CSS来实现图片的缩放效果,并给出具体的代码示例。使用transfor...
    99+
    2023-11-21
    图片缩放 CSS缩放 CSS图片效果
  • css如何实现背景颜色线性渐变和径向渐变效果
    这篇文章主要介绍了css如何实现背景颜色线性渐变和径向渐变效果的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇css如何实现背景颜色线性渐变和径向渐变效果文章都会有所收获,下面我们一起来看看吧。一、线性渐变(li...
    99+
    2023-07-05
  • Kotlin使用TransitionDrawable实现颜色渐变效果流程讲解
    目录1 导入需要渐变的图片2 activity_main.xml3 MainActivity.kt1 导入需要渐变的图片 如果需要实现图片之间的渐变效果,我们需要两张照片,这样才能实...
    99+
    2023-02-16
    Kotlin TransitionDrawable实现颜色渐变 Kotlin颜色渐变效果 Kotlin TransitionDrawable颜色渐变
  • 如何使用HTML颜色代码创建渐变效果?
    渐变效果是一种将多种颜色平滑过渡的技术,在网页设计中广泛应用。使用 HTML 颜色代码可以轻松创建渐变效果,无需使用任何额外的工具或技能。 要使用 HTML 颜色代码创建渐变效果,需要使用 CSS 的 linear-gradient()...
    99+
    2024-02-14
    HTML颜色代码 渐变效果 网页设计 CSS
  • 怎么使用HTML5 Canvas API控制图片的缩放变换
    这篇文章给大家分享的是有关怎么使用HTML5 Canvas API控制图片的缩放变换的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。缩放变换scale(sx,sy)传入两个参数,分...
    99+
    2024-04-02
  • 使用CSS3如何实现字体颜色渐变
    这篇文章主要为大家展示了使用CSS3如何实现字体颜色渐变,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“使用CSS3如何实现字体颜色渐变”这篇文章吧。在使用Animation.css的时候发现它的官...
    99+
    2023-06-08
  • 如何使用HTML5 Canvas为图片填充颜色和纹理
    这篇文章将为大家详细讲解有关如何使用HTML5 Canvas为图片填充颜色和纹理,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。填充颜色艺术离不开色彩,今天咱...
    99+
    2024-04-02
  • 如何使用css实现多个颜色渐变
    这篇“如何使用css实现多个颜色渐变”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“如何使用css实现多个颜色渐变”,小编整理了以下知识点,请大家跟着小编的步伐...
    99+
    2024-04-02
  • tkinter如何使用js的canvas实现渐变色
    这篇文章主要讲解了“tkinter如何使用js的canvas实现渐变色”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“tkinter如何使用js的canvas实现渐变色”吧!1. 使用rgb表...
    99+
    2023-06-21
  • 如何使用CSS制作渐变背景颜色的效果
    如何使用CSS制作渐变背景颜色的效果背景色渐变效果能够为网页增添美观和吸引力。在CSS中,我们可以使用渐变背景色来实现这一效果。本文将介绍如何使用CSS来制作渐变背景色的效果,并提供具体的代码示例。一、线性渐变(Linear gradien...
    99+
    2023-10-25
    CSS 渐变背景 制作效果
  • 如何使用html5 canvas实现图片玻璃碎片特效
    小编给大家分享一下如何使用html5 canvas实现图片玻璃碎片特效,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作