如何通过单击KonvaJS Image对象创建Bootstrap popover?

时间:2016-06-29 13:38:59

标签: javascript jquery twitter-bootstrap-3 bootstrap-popover konvajs

在我的应用程序中,我广泛使用了KonvaJS,但是我已经到了需要在Bootstrap Popover点击上创建KonvaJS Image的步骤,这可能吗?

请注意,我在这个应用程序中有超过50张图像,我需要为每个图像创建一个弹出窗口。

1 个答案:

答案 0 :(得分:1)

如果你想让PopOver只用于画布图像,那么我建议使用Konva.Label。您可以根据需要设置指针并设置标签的位置。这是我创建的plunkr

<!DOCTYPE html>
<html>

<head>
  <script src="https://cdn.rawgit.com/konvajs/konva/0.15.0/konva.min.js"></script>
  <meta charset="utf-8">
  <title>Konva Label Demo</title>
  <style>
    body {
      margin: 0;
      padding: 0;
      overflow: hidden;
      background-color: #F0F0F0;
    }
  </style>
</head>

<body>
  <div id="container"></div>
  <script>
    var stage = new Konva.Stage({
      container: 'container',
      width: 300,
      height: 300
    });

    var layer = new Konva.Layer();
    // label with left pointer
    var tooltip = new Konva.Label({
      x: 170,
      y: 75,
      opacity: 0.75
    });

    tooltip.add(new Konva.Tag({
      fill: 'black',
      pointerDirection: 'down',
      pointerWidth: 10,
      pointerHeight: 10,
      lineJoin: 'round',
      shadowColor: 'black',
      shadowBlur: 10,
      shadowOffset: 10,
      shadowOpacity: 0.5
    }));

    tooltip.add(new Konva.Text({
      text: 'Yoda has powers...',
      fontFamily: 'Calibri',
      fontSize: 18,
      padding: 5,
      fill: 'white'
    }));


    var image = new Image();
    image.onload = function() {
      var lion = new Konva.Image({
        image: image,
        x: 70,
        y: 75,
        draggable: true
      });
      layer.add(lion);
      // add the labels to layer
      layer.add(tooltip);
      layer.draw();
    };

    image.src = 'http://konvajs.github.io/assets/yoda.jpg';



    // add the layer to the stage
    stage.add(layer);
  </script>

</body>

</html>