Konva的使用

Konva

Konva特點(diǎn)

面向?qū)ο蠓绞?/h4>
  • 一切皆對(duì)象
  • 如何定義對(duì)象 ①Object構(gòu)造函數(shù) ②直接量 {} ③自定義構(gòu)造函數(shù) 再new
  • 構(gòu)造函數(shù) new一個(gè)構(gòu)造函數(shù)就可以得到對(duì)象(實(shí)例)
  • this
  • 原型 prototype / 原型鏈

konva概念

  • 舞臺(tái) stage
  • 層 layer
  • 組 group
  • 圖形

基本操作

  • 創(chuàng)建舞臺(tái)
    new Konva.Stage({
    width:
    height
    })
  • 創(chuàng)建層
    new Konval.Layer({})
    stage.add(layer)
  • 圖形或組添加到 層
  • 圖形添加到組
  • 繪制 layer.draw()

基本圖形

  • Konva.Rect() 矩形
  • Konva.Circle() 圓形
  • Konva.Ellipse() 橢圓
  • Konva.Text() 文字
  • Konva.Image() 圖片
  • Konva.Line() 劃線
  • Konva.star() 星星
  • ....

事件

類似于jquery

動(dòng)畫(huà)

  • tween對(duì)象 指定動(dòng)畫(huà)持續(xù)時(shí)間 指定變化的樣式 tween.play()
  • 簡(jiǎn)寫(xiě) 圖形.to()
  • Animation對(duì)象

動(dòng)畫(huà)緩動(dòng)效果實(shí)例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
    <title>29 緩動(dòng)效果演示</title>
    
    <script src="bower_components/konva/konva.min.js"></script>
    <style>
        body {
          margin: 0;
          padding: 0;
          overflow: hidden;
          background-color: #F0F0F0;
        }
        #buttons {
            position: absolute;
            top: 10px;
            left: 10px;
        }
        #buttons > input {
            padding: 10px;
        }
      </style>
</head>
<body>
  <div id="container"></div>
  <div id="buttons">
      <input type="button" id="play" value="Play">
      <input type="button" id="pause" value="Pause">
      <input type="button" id="reverse" value="Reverse">
  </div>
  <script>
    var width = window.innerWidth;
    var height = 707;
    
    var stage = new Konva.Stage({
      container: 'container',
      width: width,
      height: height
    });

    var layer = new Konva.Layer();

    var easings = [
        {name: 'Linear', color:'blue'},
        {name: 'EaseIn', color:'green'},
        {name: 'EaseOut', color:'green'},
        {name: 'EaseInOut', color:'green'},
        {name: 'BackEaseIn', color:'blue'},
        {name: 'BackEaseOut', color:'blue'},
        {name: 'BackEaseInOut', color:'blue'},
        {name: 'ElasticEaseIn', color:'green'},
        {name: 'ElasticEaseOut', color:'green'},
        {name: 'ElasticEaseInOut', color:'green'},
        {name: 'BounceEaseIn', color:'blue'},
        {name: 'BounceEaseOut', color:'blue'},
        {name: 'BounceEaseInOut', color:'blue'},
        {name: 'StrongEaseIn', color:'green'},
        {name: 'StrongEaseOut', color:'green'},
        {name: 'StrongEaseInOut', color:'green'}
    ];

    var tweens = [];

    for(var n = 0; n < easings.length; n++) {
        var num = n + 1;
        var ease = easings[n];
        var text = new Konva.Text({
            x: 10,
            y: 60 + (n * 400 / easings.length),
            padding: 4,
            text: num + ') ' + ease.name,
            fontSize: 18,
            fontFamily: 'Calibri',
            fill: ease.color
        });

        layer.add(text);

        // the tween has to be created after the node has been added to the layer
        var tween = new Konva.Tween({
            node: text,
            x: 280,
            easing: Konva.Easings[ease.name],
            duration: 2
        });

        // add tween to tweens array
        tweens.push(tween);
    }

    stage.add(layer);

    // play
    document.getElementById('play').addEventListener('click', function() {
        for (var n=0; n<tweens.length; n++) {
            tweens[n].play();
        }
    }, false);

    // pause
    document.getElementById('pause').addEventListener('click', function() {
        for (var n=0; n<tweens.length; n++) {
            tweens[n].pause();
        }
    }, false);

    // reverse
    document.getElementById('reverse').addEventListener('click', function() {
        for (var n=0; n<tweens.length; n++) {
            tweens[n].reverse();
        }
    }, false);
  </script>

</body>
</html>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子扬霜,更是在濱河造成了極大的恐慌曙强,老刑警劉巖莉恼,帶你破解...
    沈念sama閱讀 206,602評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件囚枪,死亡現(xiàn)場(chǎng)離奇詭異发笔,居然都是意外死亡缸榛,警方通過(guò)查閱死者的電腦和手機(jī)吝羞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)仔掸,“玉大人脆贵,你說(shuō)我怎么就攤上這事∑鹉海” “怎么了卖氨?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,878評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵会烙,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我筒捺,道長(zhǎng)柏腻,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,306評(píng)論 1 279
  • 正文 為了忘掉前任系吭,我火速辦了婚禮五嫂,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘肯尺。我一直安慰自己沃缘,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評(píng)論 5 373
  • 文/花漫 我一把揭開(kāi)白布则吟。 她就那樣靜靜地躺著槐臀,像睡著了一般。 火紅的嫁衣襯著肌膚如雪氓仲。 梳的紋絲不亂的頭發(fā)上水慨,一...
    開(kāi)封第一講書(shū)人閱讀 49,071評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音敬扛,去河邊找鬼晰洒。 笑死,一個(gè)胖子當(dāng)著我的面吹牛啥箭,可吹牛的內(nèi)容都是我干的谍珊。 我是一名探鬼主播,決...
    沈念sama閱讀 38,382評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼捉蚤,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼抬驴!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起缆巧,我...
    開(kāi)封第一講書(shū)人閱讀 37,006評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤布持,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后陕悬,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體题暖,經(jīng)...
    沈念sama閱讀 43,512評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評(píng)論 2 325
  • 正文 我和宋清朗相戀三年捉超,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了胧卤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,094評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡拼岳,死狀恐怖枝誊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情惜纸,我是刑警寧澤叶撒,帶...
    沈念sama閱讀 33,732評(píng)論 4 323
  • 正文 年R本政府宣布绝骚,位于F島的核電站,受9級(jí)特大地震影響祠够,放射性物質(zhì)發(fā)生泄漏压汪。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評(píng)論 3 307
  • 文/蒙蒙 一古瓤、第九天 我趴在偏房一處隱蔽的房頂上張望止剖。 院中可真熱鬧,春花似錦落君、人聲如沸穿香。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,286評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)扔水。三九已至痛侍,卻和暖如春朝氓,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背主届。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,512評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工赵哲, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人君丁。 一個(gè)月前我還...
    沈念sama閱讀 45,536評(píng)論 2 354
  • 正文 我出身青樓枫夺,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親绘闷。 傳聞我的和親對(duì)象是個(gè)殘疾皇子橡庞,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 一:canvas簡(jiǎn)介 1.1什么是canvas? ①:canvas是HTML5提供的一種新標(biāo)簽 ②:HTML5 ...
    GreenHand1閱讀 4,667評(píng)論 2 32
  • 【四印蔗、Canvas開(kāi)發(fā)庫(kù)封裝】 《4.1封裝常用的繪制函數(shù)》 4.1.1封裝一個(gè)矩形 //思考:我們用到的矩形需要...
    夜幕小草閱讀 4,644評(píng)論 2 5
  • 第三方的canvas庫(kù) konvaJS https://konvajs.github.io/ 通用 echar...
    細(xì)雨銜雪閱讀 3,088評(píng)論 1 2
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,513評(píng)論 25 707
  • 愛(ài)一個(gè)人三年五載也要結(jié)束 抽一支煙兩年三年也要抽完 嗯扒最,戒煙了 還有就是戒了你
    fa朵閱讀 271評(píng)論 0 0