web前端移动端课程之canvas教程系列

简介: web前端移动端课程之canvas教程系列

canvas

canvas介绍
  • canvas是一个客户端浏览器里的画图技术,canvas也是h5的一个新标签,canvas标签就已经提供了一张所谓的画布,那么再通过jscanvas一些操作就可以达到最终画图的效果
canvas的基本使用
  • 主要就是如何通过js操作canvas才是关键所在
<canvas id="canvas" width="800" height="600">对不起,您的浏览器不支持canvas,请升级到最新版本</canvas>
<script>
    //获取canvas的DOM对象  
  var canvas = document.querySelector('#canvas');
    //获取canvas的画图的上下文对象,值为2d表示画2d平面图,值为webgl表示画3d立体模型图
    var ctx = canvas.getContext('2d');
    //填充一个样式,这个样式是给你要操作的形状的样式
    ctx.fillStyle = 'red';
    //填充一个矩形,前两个参数是矩形的位置,后两个参数是矩形的宽高
    ctx.fillRect(50,100,200,200);
</script>
  • canvas画形状提供了三种方法,三个方法参数一样,都是(x,y,width,height)
  • fillRect():填充一个矩形,默认是黑色
  • strokeRect():绘制一个矩形,没有填充,只是一个描边的矩形,默认描边是黑色
  • clearRect():以矩形的形状来清除一个区域
  • 因此可以发现,想画其他形状了,就要通过其他方法来操作了,在canvas里带有stroke的方法都是画描边的形状,而带有fill的方法都是填充的形状,那么对描边形状设置样式就是对属性strokeStyle,对填充形状设置样式就是fillStyle
canvas画线的操作
  • 画线操作分下边几个步骤,都是canvas对象的上下文对象的方法:
  1. moveTo(x,y):将画笔移动到指定坐标,就是开始画的位置
  2. lineTo(x,y):线绘制的结束位置坐标
  3. lineWidth:线宽的设置
  4. stroke():画描边的线
  5. fill():画填充的线,但是线与线之间必须有交点才可以
  6. lineCap:设置线条末端样式,butt是默认值,还有roundsquare两种,这个其实就是设置线帽的样式
  7. lineJoin:设置线条与线条交点处的样式。有miter(默认值)、roundbevel三个值
canvas路径绘制的细节操作
  • canvas在绘制图形时,如果一段图形操作完毕后想要继续绘制其他图形了,则必须开启新路径操作,并且要闭合绘制路径
  • beginPath():将context对象里原来的路径清除掉,但不会对已经画到界面上的路径造成影响。这样就可以终止以前的路径,开启一个新路径进行操作
  • closePath():关闭路径,意思就是从当前的坐标点直接连接到你开始的坐标点,就是moveTo的坐标点,这种属于自动关闭闭合路径操作

摘要:相当于是手动关闭路径了就从moveTo开始,到最后lineTo结束。自动关闭路径就是从moveTo开始,利用closePath来关闭路径。fill填充操作也可以关闭路径,但会填个颜色。

  • 绘制两个三角形(无填充与有填充)
    画布
    盒子移动
canvas绘制弧线操作
  • arc():前两个参数是绘制的坐标位置,第三个参数是弧线的半径,第四个参数是开始时的角度位置,第五个参数是结束时的角度位置。角度位置理解请看下图:
参数: 1 x坐标 2 y坐标 3 半径 4 开始的角度  5 结束的角度  Math.PI/180

案例:canvas时钟

canvas绘制文本:
  • font:绘制的文本字体样式操作
  • textAlign:文本的水平对齐方式
  • textBaseline:文本垂直对齐方式
  • direction:文本内容的显示方向。ltr表示从左往右显示,rtl表示从左往右显示
  • fillText():绘制文本到canvas上,第一个参数是文本内容,第二个和第三个参数表示文本的绘制位置坐标
  • strokeText():
  • measureText():参数就是要输出的文本内容,此方法作用就是返回文本的宽度,也就是测量文本宽度
canvas对图片的绘制操作(重点):
  • drawImage():绘制图片的主要方法,需要先new Image()来创建图片对象,并给对象指定src后,就可以监听imgload事件来判断图片是否加载完成,加载完成后即可使用drawImage方法绘制图片到canvas上了。
ctx.drawImage(img,x,y,w,h)
// 把canvas转成一个当前图片文件的实际的base64格式路径
imgUrl = canvas.toDataURL('image/jpeg');
// 手机端 照片很大 上传 用canvas把图片重新绘制一下 (压缩)
* echarts:  js插件 图表


目录
相关文章
|
3月前
|
并行计算 前端开发 JavaScript
Web Worker:让前端飞起来的隐形引擎
在现代 Web 开发中,前端性能优化是一个至关重要的课题,尤其是对于计算密集型的应用,如图像处理、视频处理、大规模数据分析等任务。单线程的 JavaScript 引擎常常成为性能瓶颈,导致应用变得迟缓。Web Worker,作为一种强大的技术,使得前端能够在后台进行并行计算,从而实现高效的任务处理,不影响主线程的运行和用户的交互体验。
384 108
|
3月前
|
JavaScript 前端开发 Java
前端框架选择之争:jQuery与Vue在现代Web开发中的真实地位-优雅草卓伊凡
前端框架选择之争:jQuery与Vue在现代Web开发中的真实地位-优雅草卓伊凡
426 72
前端框架选择之争:jQuery与Vue在现代Web开发中的真实地位-优雅草卓伊凡
|
5月前
|
移动开发 前端开发 JavaScript
前端web创建命令
本项目使用 Vite 搭建 Vue + TypeScript 开发环境,并基于 HTML5 Boilerplate 提供基础模板,快速启动现代前端开发。
67 2
|
5月前
|
Web App开发 编解码 移动开发
零基础音视频入门:你所不知道的Web前端音视频知识
本文回顾了Web端音视频的发展历程,同时还介绍了视频的编码、帧率、比特率等概念,提到了Canvas作为视频播放的替代方案,以及FFmpeg在音视频处理中的重要作用等知识。
150 1
|
8月前
|
资源调度 JavaScript 前端开发
前端开发必备!Node.js 18.x LTS保姆级安装教程(附国内镜像源配置)
本文详细介绍了Node.js的安装与配置流程,涵盖环境准备、版本选择(推荐LTS版v18.x)、安装步骤(路径设置、组件选择)、环境验证(命令测试、镜像加速)及常见问题解决方法。同时推荐开发工具链,如VS Code、Yarn等,并提供常用全局包安装指南,帮助开发者快速搭建高效稳定的JavaScript开发环境。内容基于官方正版软件,确保合规性与安全性。
6948 24
|
9月前
|
前端开发
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
251 1
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
|
12月前
|
前端开发 JavaScript 搜索推荐
HTML与CSS在Web组件化中的核心作用及前端技术趋势
本文探讨了HTML与CSS在Web组件化中的核心作用及前端技术趋势。从结构定义、语义化到样式封装与布局控制,两者不仅提升了代码复用率和可维护性,还通过响应式设计、动态样式等技术增强了用户体验。面对兼容性、代码复杂度等挑战,文章提出了相应的解决策略,强调了持续创新的重要性,旨在构建高效、灵活的Web应用。
245 6
|
12月前
|
移动开发 前端开发 JavaScript
前端H5使用canvas画爱心以及笑脸
本文介绍了HTML5中的canvas元素及其基本用法,通过JavaScript在canvas上绘制图形。首先简述了canvas的功能,接着详细展示了如何使用`bezierCurveTo`方法绘制爱心和`arc`方法绘制笑脸,并附有示例代码及效果说明。最后总结了canvas在网页图形绘制上的应用潜力。
323 2
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
978 14
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
302 0