Konva简单实例

一、简介

       Konva 是一个 基于 Canvas 开发的 2d js 框架库, 它可以轻松的实现桌面应用和移动应用中的图形交互交互效果,可以高效的实现动画, 变换, 节点嵌套, 局部操作, 滤镜, 缓存, 事件等功能, 不仅仅适用于桌面与移动开发, 还有更为广泛的应用。允许在舞台上绘图, 添加事件监听, 移动或缩放某个图形, 独立旋转, 以及高效的动画. 即使应用中含有数千个图形也是可以轻松实现的。

理念:任何图形都存在于舞台中( Konva.Stage ), 这个舞台中又可以包多个用户层( Konva.Layer )。每一个层中都含有两个<canvas> 着色器: 一个前台渲染器, 一个后台渲染器。前台渲染器是可以看见的部分,而后台渲染器是一个隐藏的 canvas。 后台渲染器为了提高效率实现事件监听的工作。

每一个层可以包含形状( Shape ), 形状的组( Group ), 甚至是由组组成的组. 舞台, 层, 组, 以及形状都是虚拟的节点( node ). 类似于 HTML 页面中的 DOM 节点.

官网https://konvajs.org/

二、实例

1、Stage和Layer :创建舞台和层,并将层添加至舞台中。

$(function () {
        var container = $("#container");
        var width = 800;
        var height = 600;

        // 1、创建舞台 Stage
        var stage = new Konva.Stage({
            container:'container', // 设置容器的 id
            width:width, // 宽度
            height:height, // 高度
        });

        // 2、创建层 Layer
        var  layer = new Konva.Layer();
        layer.batchDraw();

        // 3、将层添加至舞台容器中
        stage.add(layer);
        stage.batchDraw();
    });

2、创建文本

        // 创建文本
        var text = new Konva.Text({
            x: 10,
            y: 5,
            text: '使用konvajs实例:',
            fontSize: 14, // 默认值为12
            fontFamily: 'Calibri', // 默认是Arial
            fill: 'green'
        });
        // 添加到层
        layer.add(text);

文本属性:

NameTypeArgumentDescription
fontFamilyString<optional> 字体,默认是Arial
fontSizeNumber<optional>像素。默认值为12
fontStyleString<optional>可以是normal、 bold、talic。默认是normal
fontVariantString<optional>可以是normal 、small-caps。默认是normal
textDecorationString<optional>

可以是line-through、underline 、string。默认是 string.

textString  
alignString<optional>

可以是 left、center、right

verticalAlignString<optional>

可以是top、middle、bottom

paddingNumber<optional> 
lineHeightNumber<optional>默认值为1
wrapString<optional>

可以是word、char、none。默认是 word

ellipsisBoolean<optional>

可以是true、false。 默认是 false

3.1、线

     var curve = new Konva.Line({
            x:10,
            y:20,
            points:[50,20,100,30,200,20,300,30,400,20,500,30,600,20],
            stroke:'red',
            tension:2
        });
        layer.add(curve);

3.1、线:直线

       var straight = new Konva.Line({
            x:10, // x轴的位置
            y:10, // y轴的位置
            points:[10,10,700,10], // 排列:平面阵列的点坐标,定义[x1,y1,x2,y2,x3,y3]。
            stroke:'red', // 颜色
            tension:1 // 数:较高的值将导致更曲线,默认值为0。
        });
        layer.add(straight);

属性介绍:

NameTypeArgumentDescription
pointsArray 

平面阵列的点坐标,例如 [x1, y1, x2, y2, x3, y3]

tensionNumber<optional>

线的弯曲程度,默认为0

closedBoolean<optional>

定义线形是否闭合,创建 polygon 或者 blob

bezierBoolean<optional>

如果没有提供tension,但bezier为true,则使用通过的点将该线绘制为bezier。

 4、矩形

      var rect = new Konva.Rect({
            x:10,
            y:100,
            width: 100, // 宽度
            height: 50, // 高度
            fill: 'red', // 填充颜色
            stroke: 'black', // 描边颜色
            strokeWidth: 1 // 边框的宽度
        });
        layer.add(rect);

5、圆

    var circle = new Konva.Circle({
            x:200,
            y:120,
            radius:35, // 半径
            fill: 'pink', // 填充颜色
            stroke: 'blue' // 边框的宽度
        });
        layer.add(circle);

6、椭圆

     var ellipse = new Konva.Ellipse({
            x:300,
            y:120,
            radius : {
                x : 50, // x轴半径
                y : 30 // y轴半径
            },
            fill: 'red',
            stroke: 'blue'
        });
        layer.add(ellipse);

7、图片

var imgs ="";
var imageObj010 = new Image();
imageObj010.src = imgs; // 图片的路径
var image = new Konva.Image({
      x: 10,
      y: 200,
      image: imageObj010, 
      width: 750,
      height: 10
});
layer.add(image);

注: imageObj010.src是指图片的路径,也可以值图片的base64值。

三、实例代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>konvajs实例</title>
    <style>
        body{margin: 0px;padding: 0px;}
        .container{width: 800px;height: 600px;border: 1px solid #726e6f;margin-left: auto;margin-right: auto;}
    </style>
    <link rel="stylesheet" href="konva/smartMenu.css"/>
    <script type="text/javascript" src="konva/konva.min.js"></script>
    <script type="text/javascript" src="js/jquery.js"></script>
</head>
<body>
    <div id="container" class="container"></div>
</body>
<script>
    $(function () {
        var container = document.getElementById("container");
        var width = 800;
        var height = 600;
        // 1、创建舞台 Stage
        var stage = new Konva.Stage({
            container:'container', // 设置容器的 id
            width:width, // 宽度
            height:height, // 高度
        });
        // 2、创建层 Layer
        var  layer = new Konva.Layer();

        // 2.1、创建文本
        var text = new Konva.Text({
            x: 10,
            y: 5,
            text: '使用konvajs实例:',
            fontSize: 14, // 默认值为12
            fontFamily: 'Calibri', // 默认是Arial
            fill: 'green'
        });
        // 添加到层
        layer.add(text);

        // 2.2、创建一条直线
        var straight = new Konva.Line({
            x:10, // x轴的位置
            y:10, // y轴的位置
            points:[10,10,700,10], // 排列:平面阵列的点坐标,定义[x1,y1,x2,y2,x3,y3]。
            stroke:'red', // 颜色
            tension:1 // 数:较高的值将导致更曲线,默认值为0。
        });
        layer.add(straight);

        // 2.3、创建曲线
        var curve = new Konva.Line({
            x:10,
            y:20,
            points:[50,20,100,30,200,20,300,30,400,20,500,30,600,20],
            stroke:'red',
            tension:2
        });
        layer.add(curve);

        // 2.4、创建矩形
        var rect = new Konva.Rect({
            x:10,
            y:100,
            width: 100, // 宽度
            height: 50, // 高度
            fill: 'red', // 填充颜色
            stroke: 'black', // 描边颜色
            strokeWidth: 1 // 边框的宽度
        });
        layer.add(rect);

        // 2.5、创建圆
        var circle = new Konva.Circle({
            x:200,
            y:120,
            radius:35, // 半径
            fill: 'pink', // 填充颜色
            stroke: 'blue' // 边框的宽度
        });
        layer.add(circle);

        // 2.6、创建椭圆
        var ellipse = new Konva.Ellipse({
            x:300,
            y:120,
            radius : {
                x : 50, // x轴半径
                y : 30 // y轴半径
            },
            fill: 'red',
            stroke: 'blue'
        });
        layer.add(ellipse);

        // 2.7、图片(渐变的图片)
        var imgs ="";
        var imageObj010 = new Image();
        imageObj010.src = imgs; // 图片的路径
        var image = new Konva.Image({
            x: 10,
            y: 200,
            image: imageObj010,
            width: 750, // 宽度
            height: 10 // 高度
        });
        layer.add(image);
        layer.batchDraw();
        // 将层添加至舞台容器中
        stage.add(layer);
        stage.batchDraw();
    });
</script>
</html>

欢迎关注

 

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值