您的位置:首页 > 其它

globalToLocal的坐标变换

2016-07-07 14:25 288 查看
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);
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: