PaperJS无法在mouseDown上创建圆

时间:2019-07-13 23:15:24

标签: javascript shapes paperjs

我正在尝试复制陶工的滚轮效果,用户可以单击该滚轮的一部分,按住鼠标,然后相对于滚轮中心创建一个圆圈。

类似于此人的演示:https://balazsdavid987.github.io/Pottery-Wheel/

但是可以在这里看到对我来说正在发生的事情: http://p2-paperjs-dpayne5-dpayne589733.codeanyapp.com:3000/coloring/

相关代码如下:

var tool = new paper.Tool();


        //array to hold all curves drawn from mousedrags
        var allPaths = [];

        var currPath;
        var rotationPath;

        //wheel center point, @center of canvas
        var wheelCenter = new paper.Point(350,350);

        //create the potters wheel
        var wheel = new paper.Path.Circle({
          center: wheelCenter,
          radius: 300,
          strokeColor: 'black',
          strokeWidth: 5
        });


        //hold down to create a continous curve with respect to wheelCenter
        tool.onMouseDown = function(event) {
          currPath = new paper.Path();
          currPath.strokeColor = cp.history[cp.history.length-1];
          currPath.strokeWidth = 10;

          currPath.add(event.point);

        }


        //creates a curve from the last position to the new position of mouse
        tool.onMouseDrag = function(event) {
          currPath.add(currPath.rotate(4, wheelCenter));

        }


        //add the curve to allPaths, which then gets animated in onFrame
        tool.onMouseUp = function(event) {
          allPaths.push(currPath);
        }


        paper.view.onFrame = function(event) {
          for (var i = 0; i < allPaths.length; i++) {
            allPaths[i].rotate(4, wheelCenter);
          }
          //testPath.rotate(3, wheelCenter);
        }


        paper.view.draw();

我不明白为什么mouseDrag会从鼠标单击的位置绕出一个圆滑的父亲,而我在这上面停留了一段时间。

任何帮助将不胜感激,谢谢!

1 个答案:

答案 0 :(得分:1)

除了使用onMouseDrag方法的技术困难之外,我认为您应该更改解决问题的方法。
事实是,如果您依赖鼠标拖动事件(仅在鼠标移动时触发),则无法通过保持鼠标静止来在滚轮上绘画(如参考演示中所示)。
因此,最好跟踪鼠标位置(通过侦听鼠标移动事件),并在每帧上进行绘制,将最后一个鼠标位置添加到当前路径中(当然,仅在绘制时)。
胜过一千字的sketch展示了如何实现这一目标。

// Create the wheel.
const wheel = new Path.Circle({
    center: view.center,
    radius: 300,
    strokeColor: 'black',
    strokeWidth: 3
});

// Create a group that will contain all the user drawn path.
// This will allow us to more easily rotate them together.
const paths = new Group();

// Init state variables.
let currentPath;
let drawing = false;
let lastMousePosition;

// On mouse down...
function onMouseDown(event) {
    // ...start a new path.
    currentPath = new Path({
        segments: [event.point],
        strokeColor: 'red',
        strokeWidth: 2
    });
    // Add it to the paths group.
    paths.addChild(currentPath);
    // Mark state as drawing.
    drawing = true;
}

// On mouse move...
function onMouseMove(event) {
    // ...keep track of the mouse position, this will be used to add points to
    // the current path on each frame.
    lastMousePosition = event.point;
}

// On mouse up...
function onMouseUp(event) {
    // ...improve performances by simplifying the path.
    currentPath.simplify();
    // Mark state as not drawing.
    drawing = false;
}

// On each frame...
function onFrame(event) {
    // ...rotate paths around the wheel center.
    paths.rotate(4, wheel.position);
    // If we are currently drawing...
    if (drawing) {
        // ...add the last mouse position to the current path.
        currentPath.add(lastMousePosition);
    }
}