位置: IT常识 - 正文

【vue3】使用canvas(vue 如何使用)

编辑:rootadmin
【vue3】使用canvas canvas是什么?

推荐整理分享【vue3】使用canvas(vue 如何使用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue中使用canvas,vue3使用教程,vue 如何使用,vue3使用教程,vue中如何使用canvas,vue3怎么用,vue中如何使用canvas,vue3 canvas,内容如对您有帮助,希望把文章链接给更多的朋友!

一个html5支持的新标签,见名知意,canvas就是画板的意思,可以在canvas上画画。css画三角形很简单,但是要画五角星呢,不妨试试canvas。

在html中使用canvas1、canvas是html5中的一个标签。

新建一个html。并在body中加入canvas标签。

<body> <canvas height="600" width="600"></canvas></body>

此时canvas已经显示在画板中,只不过因为和body的颜色一样,所以看不出来。

在head中加入css样式。

<style> canvas { border:1px solid; }</style>

这时我们就可以看到canvas了。

2、获取CanvasRenderingContext2D对象用于绘图。

先给canvas一个id属性,

<canvas id='canvas' height="600" width="600"></canvas>

获取。

<script> const ctx=document.querySelector('#canvas').getContext('2d');</script>

注意,script标签应该在body标签后(至少在canvas标签后),只有在canvas渲染后才能通过JavaScript代码获取到canvas中的CanvasRenderingContext2D对象。

<body> <canvas height="600" width="600"></canvas></body><script> const ctx=document.querySelector('.canvas').getContext('2d');</script>3、使用JavaScript代码进行绘画。<script> const ctx=document.querySelector('#canvas').getContext('2d'); ctx.moveTo(100,100); ctx.lineTo(100,400); ctx.stroke();</script>

该代码绘制了一条直线。

关于CanvasRenderingContext2D对象更多的绘制方法请参考官方文档。至少现在我们知道canvas是如何使用的了。(一定要注意要在渲染完成后才能通过JavaScript代码获取CanvasRenderingContext2D对象)

在vue3中使用canvas1、创建vite+vue3项目并运行。npm init vue@latest

2、创建我们的canvas。【vue3】使用canvas(vue 如何使用)

这是我们的App.vue文件

<script setup></script><template></template><style scoped></style>

创建我们的canvas

<script setup></script><template> <canvas height="600" width="600"></canvas></template><style scoped>canvas { border: 1px solid;}</style>

3、获取CanvasRenderingContext2D对象并绘制直线。

给canvas标签添加一个ref属性

<canvas ref='canvas' height="600" width="600"></canvas>

获取canvas对象

<script setup>import {ref} from 'vue'const canvas = ref();</script>

渲染完成后获取CanvasRenderingContext2D对象

<script setup>import { onMounted, ref } from 'vue'const canvas = ref();onMounted(() => { const ctx = canvas.value.getContext('2d'); })</script>

画一条直线

<script setup>import { onMounted, ref } from 'vue'const canvas = ref();onMounted(() => { const ctx = canvas.value.getContext('2d'); ctx.moveTo(100, 100); ctx.lineTo(100, 400); ctx.stroke(); })</script>

4、模板<script setup>import { onMounted, ref } from 'vue'const canvas = ref();let ctx = ref();const drawLine = () => { ctx.moveTo(100, 100); ctx.lineTo(100, 400); ctx.stroke();}const initContext = () => { ctx = canvas.value.getContext('2d');}onMounted(() => { initContext(); drawLine();})</script><template> <canvas ref='canvas' height="600" width="600"></canvas></template><style scoped>canvas { border: 1px solid;}</style>canvas快速入门绘制折线

一个moveTo配合多个lineTo。可以通过lineWidth设置线宽,还可以设置两个端点和转折处的形状(使用lineCap和lineJoin)

// 使用moveTo,lineTo,lineWidth,lineCap,lineJoinconst drawCurvedLine = () => { ctx.moveTo(100, 100); ctx.lineTo(400, 100); ctx.lineTo(100, 400); ctx.lineTo(400, 400); ctx.lineCap = 'round'; ctx.lineJoin = 'round'; ctx.stroke();}绘制矩形

rect方法以及strokeRect和fillRect。效果等效:strokeRect=rect+stroke,fillRect=rect+stroke。

绘制方式:绘制边框,使用stroke,绘制填充,使用fill。strokeStyle可以设置边框颜色,fillStyle可以设置填充颜色。

// 使用rect,srokeStyle,stroke,fillStyle,fillconst drawStrokeRect = () => { ctx.rect(100, 100, 100, 100); ctx.strokeStyle = 'green'; ctx.stroke();}const drawFillRect = () => { ctx.rect(300, 100, 100, 100); ctx.fillStyle = 'blue'; ctx.fill();}

将绘制一个绿色边框的矩形和蓝色的矩形。然而,当一同调用时,会发现变成了两个一模一样的矩形(绿色边框或者蓝色填充)。

属性作用域:解决上述问题,使用beginPath方法即可。beginPath将后面对于属性的设置隔离开来,以避免覆盖前面的属性。

// 这里还尝试了使用strokeRect和fillRect替代了rect、stroke、fillconst drawStrokeRect = () => { ctx.beginPath(); ctx.strokeStyle='green'; ctx.strokeRect(100,100,100,100);}const drawFillRect = () => { ctx.beginPath(); ctx.fillStyle = 'blue'; ctx.fillRect(300, 100, 100, 100);}绘制弧线

圆圈

ctx.beginPath();ctx.arc(100,75,50,0,2*Math.PI);ctx.stroke();

圆弧

ctx.beginPath();ctx.arc(100,75,50,90/180*Math.PI,2*Math.PI);ctx.stroke();

扇形

ctx.beginPath();ctx.moveTo(100,75);ctx.arc(100,75,50,90/180*Math.PI,2*Math.PI);ctx.closePath();ctx.fill();

圆环

const RINGWIDTH = 10; ctx.beginPath(); ctx.arc(100, 75, 90, 0, 2 * Math.PI); ctx.fill(); ctx.beginPath(); ctx.arc(100, 75, 90-2*RINGWIDTH, 0, 2 * Math.PI); ctx.fillStyle = 'white'; ctx.fill();

补充:

如你所见,绘制扇形时使用了closePath,意思是将所有端点连接起来(一般是将终点和起点连接起来,形成一个闭合图形。只有图形闭合时,fill才能生效)。所有函数的参数不需要单位。(设置字体时,ctx.font=‘40px’,需要带单位,但确实不是函数的参数)需要角度作为参数时,都是以弧度的形式提供。计算公式,弧度=角度*Math.PI/180。90度,记为90*Math.PI/180。更多关于画布的使用,可以查看HTML Canvas 参考手册 (w3school.com.cn)
本文链接地址:https://www.jiuchutong.com/zhishi/298541.html 转载请保留说明!

上一篇:openai.error.AuthenticationError: No API key provided.

下一篇:HTML+CSS+JS 学习笔记(三)———Javascript(中)(html+css+javascript编程入门指南)

  • 微博粉丝推广必须注意四个方面(微博推广给我的粉丝是会提醒他们吗)

    微博粉丝推广必须注意四个方面(微博推广给我的粉丝是会提醒他们吗)

  • 热搜是什么在哪里看(热搜是什么呀)

    热搜是什么在哪里看(热搜是什么呀)

  • 抖音可以看自己的评论吗(抖音可以看自己访问过谁吗)

    抖音可以看自己的评论吗(抖音可以看自己访问过谁吗)

  • 小度是要一直充电吗(小度1s必须一直充电才能使用)

    小度是要一直充电吗(小度1s必须一直充电才能使用)

  • 号封八天怎么立马解封(封号8天后就能用了吗)

    号封八天怎么立马解封(封号8天后就能用了吗)

  • 美颜相机拍视频怎么没有声音(美颜相机拍视频会外泄吗)

    美颜相机拍视频怎么没有声音(美颜相机拍视频会外泄吗)

  • 微信商城和小程序商城有哪些不同(微信商城小程序定制)

    微信商城和小程序商城有哪些不同(微信商城小程序定制)

  • dtlfolder是什么文件夹(fileld是什么意思中文)

    dtlfolder是什么文件夹(fileld是什么意思中文)

  • 荣耀x10安兔兔跑分多少(荣耀10x 安兔兔)

    荣耀x10安兔兔跑分多少(荣耀10x 安兔兔)

  • 抖音有pc版吗(抖音有没有pc版的)

    抖音有pc版吗(抖音有没有pc版的)

  • 聊天记录怎么做成文件(聊天记录怎么做证据材料)

    聊天记录怎么做成文件(聊天记录怎么做证据材料)

  • 朋友圈拉黑是什么状态(朋友圈拉黑是什么心理)

    朋友圈拉黑是什么状态(朋友圈拉黑是什么心理)

  • 雅达电子是苹果原装吗(雅达电子是苹果的吗)

    雅达电子是苹果原装吗(雅达电子是苹果的吗)

  • 小米路由器红灯闪烁(小米路由器红灯亮怎么回事)

    小米路由器红灯闪烁(小米路由器红灯亮怎么回事)

  • 爱奇艺id号怎么查(求爱奇艺账号)

    爱奇艺id号怎么查(求爱奇艺账号)

  • 互删还能查到聊天记录吗(互删还能查到聊天记录吗微信)

    互删还能查到聊天记录吗(互删还能查到聊天记录吗微信)

  • 苹果有锁卡贴是什么意思(苹果锁卡贴是什么)

    苹果有锁卡贴是什么意思(苹果锁卡贴是什么)

  • mde5是什么型号(mde7是什么型号)

    mde5是什么型号(mde7是什么型号)

  • 苹果手机显示网络不可用怎么办(苹果手机显示网络不稳定是什么意思)

    苹果手机显示网络不可用怎么办(苹果手机显示网络不稳定是什么意思)

  • 苹果手机支持移动卡吗(苹果手机支持移动视频彩铃吗)

    苹果手机支持移动卡吗(苹果手机支持移动视频彩铃吗)

  • 七天网络怎么登录授权(7天网络怎样登录)

    七天网络怎么登录授权(7天网络怎样登录)

  • 微信小浮窗怎么设置(微信小浮窗怎么弄掉)

    微信小浮窗怎么设置(微信小浮窗怎么弄掉)

  • oppor15x功能介绍(oppor15有什么功能怎么用)

    oppor15x功能介绍(oppor15有什么功能怎么用)

  • vue 模拟 chatgpt 聊天效果:js 实现逐字显示、延时函数模拟对话(vue 模拟遥控按钮)

    vue 模拟 chatgpt 聊天效果:js 实现逐字显示、延时函数模拟对话(vue 模拟遥控按钮)

  • nvm管理node版本(nvm for window)

    nvm管理node版本(nvm for window)

  • Openpcdet训练自己的数据集(opencv怎么训练)

    Openpcdet训练自己的数据集(opencv怎么训练)

  • 投资性房地产采用成本模式计量
  • 个体工商户月销售额超10万怎么报税
  • 纳税期限届满
  • 足浴按摩开票明细一栏写什么
  • 小规模纳税人开专票需要交税吗
  • 个人借款给公司利息收入要交税吗
  • 自然人独资企业是什么意思
  • 企业所得税清算报备表清算结束日
  • 会计工作的基本认识
  • 私募基金超募如何购买
  • 供货商对账单跨月返利怎么做账?
  • 闲置土地归谁管理
  • 公司冲账发票做不够该如何处理合适?
  • 自行开发的软件如何确认为无形资产
  • 卫生巾的税率
  • 转账支票可不可以挂失止付
  • 招待费怎么处理
  • 商业汇票记什么会计科目?
  • 加油卡预付卡销户怎么办
  • 开票系统问题
  • 公司员工餐费会计分录
  • 我的初级备考经历怎么写
  • 技术服务费属于什么大类
  • 年底有留抵税额需要结转吗
  • 超市预付卡发票怎么开
  • 服务业核定征收税率表
  • 法人垫付现金的原始凭证
  • 两地取得工资个税怎么交
  • 存货盘亏进项税额转出会计分录怎么做
  • 怎样升级智慧中小学版本软件
  • 旅游费用账务处理
  • 个体工商户需要年审吗
  • 采购合同付款违约条款怎么签
  • 应收账款可不可以作为质押合同的标的
  • 居民企业应纳税额
  • 应付票据和应收票据的关系
  • 自然人股东是
  • vue组件引入外部js
  • 出差住宿费会计分录怎么做
  • 2、传统的目标设定过程目的重在________
  • 2023年会出什么车
  • 发票章没有盖好
  • 甲公司向其控股60%的子公司捐赠货币资金3000万元
  • 注册资金到位时间填多少年最好
  • 财报层次和认定层次
  • sql server数据库正在恢复
  • 百旺连接服务器失败,是否使用离线文件进行更新
  • 年末需暂估已发生的费用吗
  • 经营户个人所得税
  • 季度所得税申报怎么弥补以前年度亏损
  • 短期借款的账务处理例题
  • 应付票据转应付账款有附件吗
  • 印花税计入相关资产成本吗
  • 收取的承包费交什么税
  • 外购固定资产的会计处理
  • 没进项发票开销项发票可以吗?
  • 已认证发票退回说明模板
  • 企业征地款会计分录
  • 会计中的一级科员是什么
  • 业务招待费可以结转下年抵扣吗
  • 建筑工程购买的搬运设备升降平台分录
  • 管理费用怎么结转到本年利润未分配利润里了
  • 企业如何做账可以不交企业所得税
  • 违反会计法规定的行为有哪些
  • 企业初建
  • 如何修改windows注册表
  • winxp系统介绍
  • 微软反盗xp黑屏怎么办
  • win8怎么卸载应用程序
  • linux删错文件
  • opengl3d
  • android 欢迎页
  • linux写时复制
  • 能用python做什么
  • javascript教程
  • jquery实现全选全不选
  • 广东税务查询系统
  • 山东税务社保费用缴纳
  • 教育培训机构都交哪些税
  • 跨境电商出口商品结构
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设