图形编辑器基于Paper.js教程04: Paper.js中的基础知识

背景

了解paper.js的基础知识,在往后的开发过程中会让你如履平地。

基础知识

paper.js 提供了两种编写方式,一种是纯粹的JavaScript编写,还有一种是使用官方提供的PaperScript。

区别就是在于,调用paper下的字对象是否需要加paper,以及向量的加减乘除。

下面看一下两种写法

使用 paperscript

html 复制代码
<script type="text/paperscript" canvas="myCanvas">
	// Create a Paper.js Path to draw a line into it:
	var path = new Path();
	// Give the stroke a color
	path.strokeColor = 'black';
	var start = new Point(100, 100);
	// Move to start and draw a line from there
	path.moveTo(start);
	// Note the plus operator on Point objects.
	// PaperScript does that for us, and much more!
	path.lineTo(start + [ 100, -50 ]);
</script>

使用javascript

html 复制代码
<script>
 	paper.setup('myCanvas');
	// Create a Paper.js Path to draw a line into it:
	var path = new paper.Path();
	// Give the stroke a color
	path.strokeColor = 'black';
	var start = new paper.Point(100, 100);
	// Move to start and draw a line from there
	path.moveTo(start);
	// Note the plus operator on Point objects.
	// PaperScript does that for us, and much more!
	path.lineTo(start + [ 100, -50 ]);
</script>

向量

向量告诉我们的朝哪个方向移动以及移动多远。

向量的加法

向量的减法

向量的乘法,拉长向量的距离

向量的除法,缩小向量的距离

坐标系

坐标系的原点是在左上角, 0,0

画基本的几何元素

js 复制代码
 paper.setup('myCanvas');

    // 圆
    var circle = new paper.Path.Circle({
      center: [80, 50],
      radius: 30,
      fillColor: 'red'
    });

    // 椭圆
    var ellipse = new paper.Path.Ellipse({
      point: [150, 20],
      size: [80, 40],
      fillColor: 'blue'
    });

    // 矩形
    var rectangle = new paper.Path.Rectangle({
      point: [250, 20],
      size: [100, 50],
      fillColor: 'green'
    });

    // 正方形
    var square = new paper.Path.Rectangle({
      point: [370, 20],
      size: [50, 50],
      fillColor: 'yellow'
    });

    // 线段
    var line = new Path({
      segments: [[500, 20], [550, 70]],
      strokeColor: 'black'
    });

    // 弧线
    var arc = new paper.Path.Arc({
      from: [600, 50],
      through: [650, 20],
      to: [700, 50],
      strokeColor: 'orange'
    });

    // 曲线
    var curve = new Path({
      strokeColor: 'purple'
    });
    curve.add(new paper.Point(750, 25));
    curve.add(new paper.Point(800, 75));
    curve.smooth();

    // 多边形
    var polygon = new paper.Path.RegularPolygon({
      center: [900, 50],
      sides: 6,
      radius: 30,
      fillColor: 'pink'
    });

    // 星形
    var star = new paper.Path.Star({
      center: [1050, 50],
      points: 5,
      radius1: 20,
      radius2: 40,
      fillColor: 'brown'
    });

视图的缩放

js 复制代码
// 缩小一半
paper.view.zoom = 0.5
// 扩大2倍
paper.view.zoom = 2

// 放大2倍
paper.view.scale(2)

// 缩小一半
paper.view.scale(0.5)

两者能实现同样的效果,但zoom是依据最原始的缩放比例,scale是依据当前的缩放比例。

如果你先缩放0.5。然后paper.view.scale(1),那么现在还是缩小了一半。

元素的移动,旋转

元素的旋转

js 复制代码
// 旋转
paper.view.onFrame = function(event) {
  star.rotate(3);
}

角度是 顺时针是正角度,逆时针是负角度。

元素的移动

js 复制代码
star.position = star.position.add(new paper.Point(100, 50));

setTimeout(() => {
  star.position = new paper.Point(20, 20);
}, 2000)

// 或者使用translate
star.translate(new paper.Point(20, 20))

特性有哪些

画点的切线,

画法线,

求图形的交集,并集,补集

贝塞尔曲线

svg导入导出

json导入,导出

特性有很多

说一下不擅长的东西,2d渲染,位图的处理有限

动画功能有限,毕竟定位是矢量库。

负责人几乎不再维护啦,

导入svg有一些问题,特别是高精度的,小尺寸的复杂svg

社区不够活跃

相关推荐
VidDown15 天前
VidDown 工具站:免费、本地优先的开发者工具箱
javascript·编辑器·音视频·视频编解码·视频
VidDown15 天前
显卡处理视频技术详解:从硬解码到 NVENC,GPU 如何让视频处理起飞?
javascript·编辑器·音视频·视频编解码·视频
夜猫逐梦15 天前
【UE基础】03.蓝图与编辑器工作流
编辑器·ue·蓝图·ue编辑器
VidDown15 天前
视频帧率技术详解:从 24fps 到 120fps,帧率如何影响你的观看体验?
网络·网络协议·编辑器·音视频·视频编解码·视频
爱就是恒久忍耐15 天前
VSCode里如何比较2个branch
ide·vscode·编辑器
bloglin9999915 天前
vscode中可视化的合并分支,在“合并编辑器中解析”中“与基线进行比较”是什么意思
ide·vscode·编辑器
sali-tec15 天前
C# 基于OpenCv的视觉工作流-章85-包胶不良检测
图像处理·人工智能·opencv·算法·计算机视觉
zyplayer-doc16 天前
企业知识库安全与权限管理完全指南:从加密到审计的六层防护
人工智能·安全·pdf·编辑器·创业创新
古德new16 天前
鸿蒙PC迁移:Photoflare Qt 图片编辑器鸿蒙PC适配全记录
qt·编辑器·harmonyos
春日见16 天前
vscode的AI编程插件推荐:
大数据·ide·vscode·算法·机器学习·编辑器·ai编程