我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JavaScript canvas 实现用代码画画

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JavaScript canvas 实现用代码画画

引言

canvas是HTML的一个绘图标签,与SVG用标签绘图不同,canvas是通过Js代码进行图形绘制,多用于移动端分享海报绘制以及照片裁剪等场景。本文将结合部分canvas API介绍在Vue项目中如何使用canvas进行简单的图形绘制和图片绘制。

第一部分:图形绘制

画画第一步:准备好画布和画笔

<templete>
  <div>
    <canvas id="my-canvas" width="400" height="400">
    //注意:给canvas设置宽高是不用带单位的,以像素为单位
  </div>
</templete>
<script>
export default {
  mounted() {//注意要在DOM元素渲染完后才能操作DOM
    this.draw();
  },
  methods: {
    draw() {
      let canvas = document.getElementById('my-canvas');//获取画布
      let ctx = canvas.getContext('2d');//获取画笔
      //之后的操作都是基于ctx
}
</script>

画画第二步:给画笔调个粗细

ctx.fill();//用粗的毛笔填充
ctx.stroke();//用细的铅笔描边

画画第三步:给画笔沾点颜料

ctx.fillStyle = 'red'
ctx.strokrStyle = 'blue'

画画第四步:描点画图

为了更好理解,把第二三步置前,实际绘制需先描点,最后选择呈现颜色和方式

描点多借助(x,y)坐标实现,而坐标原点是canvas的左顶点,向右和向下方向分别为x轴和y轴的正方向

(1)画一个三角形

先描3个点,然后把点连接起来就完事!

ctx.beginPath();//新建一条绘制路径
ctx.moveTo(10, 10);//起点
ctx.lineTo(60, 10);//向x轴延申10个像素
ctx.lineTo(60, 60);//向y轴延申10个像素
ctx.closePath();//关闭当前路径
ctx.strokeStyle = 'red';//设置画笔颜色
ctx.stroke();//以描边的方式把描点的位置链接起来
//填充方式画三角形
//ctx.fillStyle = 'blue';//设置颜色
//ctx.fill();//以填充的方式把描点的位置链接起来

效果如下图

(2)画一个矩形

如何快速画出一个矩形?先绘制4个点吗?大漏特漏!!!canvas API里直接就有画矩形的方法!一步到位,无需其他操作!

fillRect(x,y,width,height);//填充一个矩形
strokeRect(x,y,width,height);//描边一个矩形
//参数x,y是起点
//例子
ctx.fillRect(10,10,50,50);//填充一个矩形
ctx.strokeRect(70,10,50,50);//描边一个矩形
//默认颜色为黑色,可通过fillStyle/strokeStyle改颜色

(3)画一个圆

arc(x, y, r, startAngle, endAngle, direction)
//x,y为圆心,r为半径,startAngle、endAngle分别代表开始角度和结束角度,direction代表方向,true为顺时针,false为逆时针,不填默认为true
//例子
ctx.arc(100,100,20,0,2*Math.PI);
ctx.stroke();//以描边方式将点连接起来

(4)进阶:画一个笑脸

ctx.beginPath();
ctx.arc(100, 100, 50, 0, 2 * Math.PI, true);
ctx.moveTo(135, 100);//重新设置画笔起点
ctx.arc(100, 100, 35, 0, Math.PI, false);
ctx.moveTo(90, 85);
ctx.arc(85, 85, 5, 0, 2 * Math.PI, true);
ctx.moveTo(120, 85);
ctx.arc(115, 85, 5, 0, 2 * Math.PI, true);
ctx.stroke();

画画第五步:署名

如何在canvas画布上写字呢?

fillText('文本',x,y,maxWidth);//x,y为文本绘制开始位置,maxWidth为最大宽度(可选参数)
strokeText('文本',x,y,maxWidth);
font ='';//设置字体大小和字体样式 
//例子
ctx.font = '32px serif'
ctx.fillText('任嘉伦最帅',10,50)
ctx.strokeText('任国超也帅',10,100)

第二部分:图片绘制

场景一:页面中现有一张图,需要你在canvas画布上绘制出一张一模一样的图

ctx.drawImage(image, x, y,width,height)//image可以是img元素或Image构造函数创建的屏幕外图片对象,x,y为绘制的起始位置
//场景一
<template>
  <div class="wrap-box">
    <div class="canvas-content">
      <canvas id="my-canvas" width="300" height="300"></canvas>
    </div>
    <div class="img-content">
      <img class="lazy" data-src="../../assets/rjl.jpg" alt="" class="my-img">
    </div>
  </div>
</template>
<script>
export default {
  mounted(){
    this.drawPic()
  },
  methods:{
    drawPic(){
      //场景一
      let canvas = document.getElementById("my-canvas");
      let ctx = canvas.getContext('2d');
      let img = document.querySelector('.my-img');
      img.onload=function(){//为确保图片资源加载完毕,需要在onload方法里绘制
        ctx.drawImage(img,0,0,200,300);
      }
    }
  }
}
</script>
<style scoped>
.wrap-box{
  display: flex;
  align-items: center;
  padding:20px 0 0 50px;
}
#my-canvas{
  border: 1px solid orange;
}
.img-content{
  flex: 1;
}
.my-img{
  width: 200px;
  height: 300px;
}
</style>

场景二:图片不存在页面上,通过接口返回或fileReader对象获取到class="lazy" data-src路径参数,如何把class="lazy" data-src指向的图片资源绘制到canvas上?

//场景二关键代码
<script>
export default {
  mounted(){
    this.drawPic()
  },
  methods:{
    drawPic(){
      //场景二
      let img = new Image();//创建一个Image对象
      img.class="lazy" data-src="xxx.png";//假设xxx.png是获取的scr参数
      img.onload = function(){//切记要在onload方法里绘制
        ctx.drawImage(img,150,100,200,300);
      }
    }
  }
}
</script>

以上就是JavaScript canvas 实现用代码画画的详细内容,更多关于JavaScript canvas 画画的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JavaScript canvas 实现用代码画画

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

下载Word文档

猜你喜欢

JavaScript canvas 实现用代码画画

这篇文章主要为大家介绍了JavaScript canvas 实现用代码画画示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

JavaScript利用Canvas实现粒子动画倒计时

粒子动画就是页面上通过发射许多微小粒子来表示不规则模糊物体。本文将利用canvas实现酷炫的粒子动画倒计时,感兴趣的小伙伴可以尝试一下
2022-12-09

java画图代码实现

要使用Java语言进行图形绘制,可以使用Java的图形库,如AWT(Abstract Window Toolkit)或Swing等。以下是一个简单的例子,使用Java Swing绘制一个红色的圆:```javaimport javax.sw
2023-09-23

android实现简单的画画板实例代码

直接看代码,注释都写清楚了代码如下:public class MainActivity extends Activity { private ImageView iv; private Bitmap baseBitmap; private
2022-06-06

JavaScript canvas怎么实现水球加载动画

这篇文章主要讲解了“JavaScript canvas怎么实现水球加载动画”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript canvas怎么实现水球加载动画”吧!效果展示:
2023-06-30

uniapp 如何实现canvas动画

随着移动端应用的不断发展,动画已经成为了现代应用的必备元素。而canvas作为HTML5中提供的一种绘图技术,被广泛应用于实现各种复杂的动画效果。而今,随着uniapp的流行,我们也可以借助uniapp的强大能力,轻松实现canvas动画效果。本文将为大家详细介绍uniapp如何实现canvas动画。一、认识canvascanvas是HTML5新增的特性,它是一种绘图技术,可以
2023-05-22

使用canvas怎么实现2d画布

使用canvas怎么实现2d画布?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一. Canvas是啥< canvas > 是一个可以使用脚本(通常是js)来绘图的HTML元素<
2023-06-09

JavaScript+Canvas实现带跳动效果的粒子动画

这篇文章主要为大家详细介绍了如何通过JavaScript和Canvas实现带跳动效果的粒子动画,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下
2023-03-14

Android动画 实现开关按钮动画(属性动画之平移动画)实例代码

Android动画 实现开关按钮动画(属性动画之平移动画),最近做项目,根据项目需求,有一个这样的功能,实现类似开关的动画效果,经过自己琢磨及上网查找资料,终于解决了,这里就记录下:在Android里面,一些炫酷的动画确实是很吸引人的地方,
2022-06-06

Android逐帧动画实现代码

逐帧动画(Frame-by-frame Animations)顾名思义就是一帧接着一帧的播放图片,就像放电影一样。可以通过xml实现也可以通过java代码实现。逐帧动画适合实现比较简单的动画效果,如果要实现复杂动画不太建议使用逐帧动画。 x
2022-06-06

如何使用canvas实现骨骼动画

这篇文章主要介绍了如何使用canvas实现骨骼动画,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在开始之前,先来了解一下AlloyStick官方介绍说AlloyStick 是
2023-06-09

Android加载Gif动画实现代码

Android加载Gif动画如何实现?相信大家都很好奇,本文就为大家揭晓,内容如下 2022-06-06

编程热搜

目录