成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Fabric.js 的簡單介紹和使用 (二)

wangdai / 553人閱讀

摘要:之前我們學(xué)習(xí)了基礎(chǔ)用法現(xiàn)在我們開始一些好玩的我們先回顧設(shè)置一下正方形角度方法這是沒有動畫的都有方法那么正方形會從到有一個動畫過度從左到右進行變動逆時針轉(zhuǎn)度當(dāng)然還支持這些方法圖片可以使用效果一次可以使用多個效果當(dāng)然你也可以自己定義支持顏色

之前我們學(xué)習(xí)了基礎(chǔ)用法 現(xiàn)在我們開始一些好玩的

Animation

我們先回顧設(shè)置一下正方形角度方法

rect.set("angle", 45);

這是沒有動畫的

Fabric object都有animate方法

rect.animate("angle", 45, {
  onChange: canvas.renderAll.bind(canvas)
});

那么正方形會從0到45有一個動畫過度

從左到右進行變動

rect.animate("left", "+=100", { onChange: canvas.renderAll.bind(canvas) });

逆時針轉(zhuǎn)5度

rect.animate("angle", "-=5", { onChange: canvas.renderAll.bind(canvas) });

當(dāng)然animate還支持這些方法

from: Allows to specify starting value of animatable property (if we don"t want 2. current value to be used).

duration: Defaults to 500 (ms). Can be used to change duration of an animation.

onComplete: Callback that"s invoked at the end of the animation.

easing: Easing function.

rect.animate("left", "+=100", {
    onChange: canvas.renderAll.bind(canvas),
    duration: 3000,
    easing: fabric.util.ease.easeOutBounce
});
Image filters

圖片可以使用filter效果

fabric.Image.fromURL("pug.jpg", function(img) {

  // add filter
  img.filters.push(new fabric.Image.filters.Grayscale());

  // apply filters and re-render canvas when done
  img.applyFilters(canvas.renderAll.bind(canvas));

  // add image onto canvas
  canvas.add(img);
});

filter一次可以使用多個效果

當(dāng)然 你也可以自己定義filter

fabric.Image.filters.Redify = fabric.util.createClass({

  type: "Redify",

  applyTo: function(canvasEl) {
    var context = canvasEl.getContext("2d"),
        imageData = context.getImageData(0, 0, canvasEl.width, canvasEl.height),
        data = imageData.data;

    for (var i = 0, len = data.length; i < len; i += 4) {
      data[i + 1] = 0;
      data[i + 2] = 0;
    }

    context.putImageData(imageData, 0, 0);
  }
});

fabric.Image.filters.Redify.fromObject = function(object) {
  return new fabric.Image.filters.Redify(object);
};
Colors

fabric 支持 hex rgb rgba顏色

new fabric.Color("#f55");
new fabric.Color("#123123");
new fabric.Color("356735");
new fabric.Color("rgb(100,0,100)");
new fabric.Color("rgba(10, 20, 30, 0.5)");

并且支持相互轉(zhuǎn)換

new fabric.Color("#f55").toRgb(); // "rgb(255,85,85)"
new fabric.Color("rgb(100,100,100)").toHex(); // "646464"
new fabric.Color("fff").toHex(); // "FFFFFF"

兩種顏色可以疊加 并且你可以使用一些特定效果

var redish = new fabric.Color("#f55");
var greenish = new fabric.Color("#5f5");

redish.overlayWith(greenish).toHex(); // "AAAA55"
redish.toGrayscale().toHex(); // "A1A1A1"
Gradients

可以使用漸變色

var circle = new fabric.Circle({
  left: 100,
  top: 100,
  radius: 50
});

circle.setGradient("fill", {
  x1: 0,
  y1: -circle.height / 2,
  x2: 0,
  y2: circle.height / 2,
  colorStops: {
    0: "#000",
    1: "#fff"
  }
});

首先確定兩個點 在其距離中以百分比定位顏色

circle.setGradient("fill", {
  x1: -circle.width / 2,
  y1: 0,
  x2: circle.width / 2,
  y2: 0,
  colorStops: {
    0: "red",
    0.2: "orange",
    0.4: "yellow",
    0.6: "green",
    0.8: "blue",
    1: "purple"
  }
});
Text

Multiline support. Native text methods unfortunately simply ignore new lines.

Text alignment. Left, center, right. Useful when working with multiline text.

Text background. Background also respects text alignment.

Text decoration. Underline, overline, strike-through.

Line height. Useful when working with multiline text.

如何添加文字

var text = new fabric.Text("hello world", { left: 100, top: 100 });
canvas.add(text);

fontFamily

var comicSansText = new fabric.Text("I"m in Comic Sans", {
  fontFamily: "Comic Sans"
});

fontSize

var text40 = new fabric.Text("I"m at fontSize 40", {
  fontSize: 40
});
var text20 = new fabric.Text("I"m at fontSize 20", {
  fontSize: 20
});

fontWeight

var normalText = new fabric.Text("I"m a normal text", {
  fontWeight: "normal"
});
var boldText = new fabric.Text("I"m at bold text", {
  fontWeight: "bold"
});

textDecoration

var underlineText = new fabric.Text("I"m an underlined text", {
  textDecoration: "underline"
});
var strokeThroughText = new fabric.Text("I"m a stroke-through text", {
  textDecoration: "line-through"
});
var overlineText = new fabric.Text("I"m an overline text", {
  textDecoration: "overline"
});

shadow

var shadowText1 = new fabric.Text("I"m a text with shadow", {
  shadow: "rgba(0,0,0,0.3) 5px 5px 5px"
});
var shadowText2 = new fabric.Text("And another shadow", {
  shadow: "rgba(0,0,0,0.2) 0 0 5px"
});
var shadowText3 = new fabric.Text("Lorem ipsum dolor sit", {
  shadow: "green -5px -5px 3px"
});

fontStyle

var italicText = new fabric.Text("A very fancy italic text", {
  fontStyle: "italic",
  fontFamily: "Delicious"
});
var anotherItalicText = new fabric.Text("another italic text", {
  fontStyle: "italic",
  fontFamily: "Hoefler Text"
});

stroke & strokeWidth

var textWithStroke = new fabric.Text("Text with a stroke", {
  stroke: "#ff1318",
  strokeWidth: 1
});
var loremIpsumDolor = new fabric.Text("Lorem ipsum dolor", {
  fontFamily: "Impact",
  stroke: "#c3bfbf",
  strokeWidth: 3
});

textAlign

var text = "this is
a multiline
text
aligned right!";
var alignedRightText = new fabric.Text(text, {
  textAlign: "right"
});

lineHeight

var lineHeight3 = new fabric.Text("Lorem ipsum ...", {
  lineHeight: 3
});
var lineHeight1 = new fabric.Text("Lorem ipsum ...", {
  lineHeight: 1
});

textBackgroundColor

var text = "this is
a multiline
text
with
custom lineheight
&background";
var textWithBackground = new fabric.Text(text, {
  textBackgroundColor: "rgb(0,200,0)"
})
Events

怎么可以沒有事件呢

事件以on off使用 canvas 可以捕捉事件

mouseevent
"mouse:down", "mouse:move", and "mouse:up".

renderevent
"after:render".

selectionevent
"before:selection:cleared", "selection:created", "selection:cleared".

objectevent
object ones: "object:modified", "object:selected", "object:moving", "object:scaling", "object:rotating", "object:added", and "object:removed"

var canvas = new fabric.Canvas("...");
canvas.on("mouse:down", function(options) {
  console.log(options.e.clientX, options.e.clientY);
});

同樣這些事件也可以用任何fabric對象監(jiān)聽

var rect = new fabric.Rect({ width: 100, height: 50, fill: "green" });
rect.on("selected", function() {
  console.log("selected a rectangle");
});

var circle = new fabric.Circle({ radius: 75, fill: "blue" });
circle.on("selected", function() {
  console.log("selected a circle");
});

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/79153.html

相關(guān)文章

  • Fabric.js 簡單介紹使用

    摘要:簡介是一個可以簡化程序編寫的庫。為提供所缺少的對象模型交互和一整套其他不可或缺的工具?;趨f(xié)議開源,在上有許多人貢獻代碼。在移動,線,曲線,或弧等命令的幫助下,路徑可以形成令人難以置信的復(fù)雜形狀。同組的路徑路徑組的幫助,開放更多的可能性。 簡介 Fabric.js是一個可以簡化canvas程序編寫的庫。 Fabric.js為canvas提供所缺少的對象模型, svg parser, 交...

    piapia 評論0 收藏0
  • Fabric.js 簡單介紹使用 (三)

    摘要:之前我們學(xué)習(xí)了基礎(chǔ)和高級特性現(xiàn)在介紹更神奇的東西話說這個功能我最喜歡組成群組可以統(tǒng)一修改其中所有組件屬性如何定義現(xiàn)在我們就可以對其中的對象集修改中的元素相對于定位但是由于要確保之前得到卻切位置所以要異步可以動態(tài)添加添加并修改當(dāng)然你可以使用 之前我們學(xué)習(xí)了基礎(chǔ)和高級特性 現(xiàn)在介紹更神奇的東西 Groups 話說這個功能我最喜歡 組成群組可以統(tǒng)一修改其中所有組件屬性 如何定義 var...

    xi4oh4o 評論0 收藏0
  • 我從 fabric.js 中學(xué)到了什么

    摘要:前言熟悉的朋友想必都使用或者聽說過,算是一個元老級的庫了,從第一個版本發(fā)布到現(xiàn)在,已經(jīng)有年時間了。中緩存是默認開啟的,同時也可以設(shè)置為禁用。處理屏屏幕模糊的問題,直接給出處理方法,就不展開說了。 前言 熟悉 canvas 的朋友想必都使用或者聽說過 Fabric.js,F(xiàn)abric 算是一個元老級的 canvas 庫了,從第一個版本發(fā)布到現(xiàn)在,已經(jīng)有 8 年時間了。我近一年時間也在項目...

    oogh 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<