整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

JavaScript操作Canvas实现画板实例分析

JavaScript操作Canvas实现画板实例分析

anvas元素用来支持在网页上绘制图形图像

以前在网页中进行交互绘图是很困难的(需要依赖额外的第三方插件),而引入的Canvas特性使得作者可以很容易的在网页上绘制各种图形和图像。

Canvas提供了脚本(JavaScript)应用接口,我们可以使用JS代码来操作画布,添加各种图形以及实现用户交互。这些特性使得HTML5在开发网页游戏和一些复杂的网页动画上变得更加方便。

比如下面这个例子,使用Canvas实现了简单的在线画板功能,你可以直接在网页上绘制线条:

实例可访问:http://www.ikinsoft.com/3ddemo/Canvas.html

效果图如下:

实际上Canvas规范包含两个部分,一个是HTML5新引入的canvas元素,还有更为关键的2D渲染上下文。实际上前者只是一个容器,后者才是真正绘图的地方。它包含绘图和图形操作所需要的全部方法和丰富功能。 强调一下:绘图是在2D渲染上下文中进行的,而不是在canvas元素中进行。可以通过canvas元素访问和显示2D渲染上下文。

canvas元素的语法很简单,除了id和class外,还有两个和容器尺寸相关的属性:宽和高。

<canvas id="myCanvas" height="500" width="500"></canvas>

我们接下来先搞清楚2D渲染上下文的用法。

画布图形实际上是绘制在2D渲染上下文里

canvas元素并非Canvas中最强大的部分,真正的关键部分是2D渲染上下文,这是你真正绘制图形的地方。canvas元素的用途只是作为2D渲染上下文的包装器,它包含绘图和图形操作所需要的全部方法和丰富功能。理解这一点是很重要的,强调一下:绘图是在2D渲染上下文中进行的,而不是在canvas元素中进行。可以通过canvas元素访问和显示2D渲染上下文。

坐标系统

2D渲染上下文是一种基于屏幕的标准绘图平台。与其他的2D平台类似,它采用平面的笛卡儿坐标系统,左上角为原点(0,0)。向右移动时,x坐标值会增加;向下移动时,y坐标值会增加。如果你想把图形绘制到正确的位置上,一定要理解这个坐标系统。

坐标系统的1个单位通常相当于屏幕的1个像素,所以位置(24,30)是向右24像素和向下30像素的位置。有时候坐标系统的1个单位相当于2个像素(例如,在一些高分辨率显示器中),但是一般的经验法则是1个坐标单位等于1个屏幕像素。

访问2D渲染上下文

我们先创建只有一个空白canvas元素的简单HTML网页:

<canvas id="myCanvas" width="200" height="200">

<!-- Insert fallback content here -->

</canvas>

在这个例子中,我们将这个canvas元素赋值给一个变量,然后再通过调用getContext方法将得到的2D渲染上下文赋给另一个变量。 必须强调一点,由于我们使用了jQuery,所以需要调用get方法才能访问DOM中的canvas元素,然后才能够访问Canvas的getContext方法。

有了包含2D渲染上下文的变量之后,就可以开始绘制图形了。在上下文变量声明语句之后添加下面这行代码:

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

完整的JS代码如下:

上述代码将在画布上绘制如下的一个黑色矩形,从坐标(0,0)处开始,长宽均为200px:

这个矩形是黑色的,因为Canvas所绘制元素的默认颜色是黑色。

者:阿山

转发连接:https://segmentfault.com/a/1190000022535264

天给大家分享一个不错的Vue构建Canvas画板Vue-SketchPad。

vue-sketchpad 基于 vue.js+fabric.js 构建的web画板。支持画箭头、虚线、圆形、文字、删除、撤销重做及清除画板等功能。

实现功能

  • 直线
  • 箭头
  • 虚线
  • 输入文字
  • 矩形
  • 标准圆形
  • 椭圆形
  • 等腰三角形
  • 删除、移动、复位
  • 历史记录

安装使用

# 克隆项目
git clone https://github.com/HWcool/vue-sketchpad.git
# 进入项目
cd vue-sketchpad
# 安装依赖
npm install
# 本地开发
npm run div
# 打包
npm run build

fabric.js 就是针对canvas繁琐的API进行的一系列封装操作,而且现在这个库还在维护中。在github上start高达16.7K+

# fabric.js 高级画板
https://www.cnblogs.com/vipstone/p/8716419.html
# 官网
http://fabricjs.com/

# github地址
https://github.com/fabricjs/fabric.js

最后附上项目地址,需要的朋友不可错过。

# 仓库地址
https://github.com/HWcool/vue-sketchpad

ok,就介绍到这里。如果能对大家有所帮助的话,记得多支持一下哈~