PaperJS,需要使用鼠标按下选择透明栅格下面的项目

时间:2019-01-21 03:56:10

标签: paperjs

我有一个具有多个栅格图像的画布。 我在onMouseDown上使用Tool查找选择了被单击的项目。

我有一个新要求。

假设两个图像相互重叠,并且上面的图像是部分透明的。这使得下部图像可见。但是,当我尝试单击下部图像时,显然我最终选择了上部图像。

尝试失败

我尝试在Raster上使用getPixel(point)函数。我以为如果可以确定所选像素是透明的,则可以忽略该栅格并寻找其他项目。但是我没有使用该功能获得我期望的颜色值(透明或不透明)。

因此,我的第二个想法是我需要将mousedown事件点从全局坐标空间更改为局部栅格坐标空间。仍然没有用。

有没有办法实现我想要的?

代码

tool.onMouseDown = (event) => {    
      project.activeLayer.children.forEach((item) => {

    if (item.contains(event.point)) {
          // check if hit was on a transparent raster pixel
          const pixel = item.getPixel(event.point)
          console.error(pixel.toCSS(true))

         // 2nd attempt
          const pixel = item.getPixel(item.globalToLocal(event.point))
          console.error(pixel.toCSS(true))
        }
    }
}

1 个答案:

答案 0 :(得分:4)

有一种简单的方法可以实现您想要的目标。
您可以依靠project.hitTestAll()方法对所有项目进行命中测试。
然后,如果命中项是栅格,则命中像素颜色信息将包含在hitResult.color中。您只需检查hitResult.color.alpha,即可检查栅格是否在非透明像素上被击中。

这是该解决方案的sketch演示。

const dataUrl = '';
const lowOpacity = 0.3;

// create 2 rasters
new Raster({
    source: dataUrl,
    opacity: lowOpacity,
    onLoad: function() {
        this.position = view.center - 100;
    }
});
new Raster({
    source: dataUrl,
    opacity: lowOpacity,
    onLoad: function() {
        this.position = view.center + 100;
    }
});

// on mouse down
function onMouseDown(event) {
    // unselect previously selected items
    paper.project.selectedItems.forEach(item => {
        item.selected = false;
        item.opacity = lowOpacity;
    });

    // do a hit test on all project items
    const hitResults = project.hitTestAll(event.point);
    // for each hit result
    for (let i = 0; i < hitResults.length; i++) {
        const hitResult = hitResults[i];
        // if item was hit on a non transparent pixel
        if (hitResult && hitResult.color && hitResult.color.alpha > 0) {
            // select item
            hitResult.item.selected = true;
            hitResult.item.opacity = 1;
            // break loop
            break;
        }
    }
}

enter image description here