Skip to content

pick

通过坐标点拾取元素(模拟光标拾取元素)。

关键方法

pick ( hitPoint: IPointData, options?: IPickOptions ): IPickResult

通过坐标点(相对世界坐标)拾取元素,支持获取穿透路径,返回拾取到的目标元素和路径。

ts
interface IPickOptions {
  hitRadius?: number // 拾取半径, 默认为0
  through?: boolean // 是否获取穿透路径,默认为false
  findList?: ILeaf[] // 从指定的元素列表中拾取
  exclude?: ILeafList // 排除指定的元素
  ignoreHittable?: boolean // 忽略元素的hittable属性,默认为false
}

interface IPickResult {
  target: ILeaf // 拾取到的目标元素
  path: ILeafList // 拾取路径,一般用于事件冒泡
  throughPath?: ILeafList // 穿透路径,可以找到被目标元素遮挡的底部元素
}

归属

Group

示例

通过 point 拾取元素

ts
import { Leafer, Rect } from 'leafer-ui'

const leafer = new Leafer({ view: window })

const rect1 = new Rect({ id: 'block', fill: '#32cd79' })
const rect2 = new Rect({ fill: '#32cd79' })

leafer.add(rect1)
leafer.add(rect2)

console.log(
    leafer.pick({ x: 10, y: 10 }) // {taget: rect2, path: [rect2, leafer]}
)

Released under the MIT License.