globalToLocal的坐标变换

globalToLocal

$(function() {
    init();
});
// globalToLocal
var stage, holder1, holder2,shape;

function init(e) {
    stage = new createjs.Stage('demo1');
    holder1 = new createjs.Container();
    holder1.x = holder1.y = 10;
    holder2 = new createjs.Container();
    holder2.x = holder2.y = 150;
    holder1.addChild(holder2);
    stage.addChild(holder1);
    
    shape = new createjs.Shape();
    shape.graphics.beginFill('red').rect(10,10,30,30);
    shape.x = 10;
    shape.y = 10;
    shape.alpha = 0.1;
    holder2.addChild(shape);
    shape.on('click', shapeClick);
    
    var line = new createjs.Shape();
    line.graphics.beginStroke('black').moveTo(0, 150).lineTo(300, 150).moveTo(150, 0).lineTo(150, 300);
    line.graphics.beginStroke('green').moveTo(0, 180).lineTo(300, 180).moveTo(180, 0).lineTo(180, 300);
    stage.addChild(line);
    
    stage.update();
}
function shapeClick(event) {
    var pt = shape.globalToLocal(stage.mouseX, stage.mouseY);
    console.log('stage.mouseX:'+stage.mouseX+';stage.mouseY:'+stage.mouseY); // 180,180
    console.log('pt.x:'+pt.x+';pt.y:'+pt.y); // 10,10 -- 这是相对于(shape.x,shape.y)的坐标;
    if (stage.mouseInBounds && shape.hitTest(pt.x, pt.y)) {
        shape.alpha = 1;
    }
    stage.update(event);
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值