拖动物体的时候,防止鼠标按下的时候对象突然跳动一下

拖动物体的时候,防止鼠标按下的时候对象突然跳动一下

$(function() {
    init();
});
// mouse interaction drag
// 拖动物体的时候,防止鼠标按下的时候对象突然跳动一下;

var stage, output;
var diff={}; // 偏移量;

function init(e) {
    stage = new createjs.Stage('demo1');
    
    stage.mouseMoveOutside = true;
    
    var circle = new createjs.Shape();
    circle.graphics.beginFill('red').drawCircle(0,0,50);
    
    var label = new createjs.Text('drag me','bold 14px Arial','#ffffff');
    label.textAlign = 'center';
    label.y = -7;
    
    var dragger = new createjs.Container();
    dragger.x = dragger.y = 100;
    dragger.addChild(circle, label);
    stage.addChild(dragger);
    
    dragger.on('pressmove',function(evt){
        evt.currentTarget.x = evt.stageX-diff.x;
        evt.currentTarget.y = evt.stageY-diff.y;
        
        stage.update();
    });
    
    dragger.on('mousedown',function(evt){
        // plan1
//        diff = dragger.globalToLocal( evt.stageX,evt.stageY);
//        console.log(diff);
        // plan2
        diff.x = evt.stageX-evt.currentTarget.x;
        diff.y = evt.stageY-evt.currentTarget.y;
        console.log(diff);
    });
    
    stage.update();
}

其实,可以设置这样的属性:offset.x, offset.y

$(function() {
    init();
});
// DragAndDrop

var canvas, stage;

var mouseTarget;
var dragStarted;
var offset;
var update = true;

function init(e) {
    
    canvas = document.getElementById('demo1');
    
    stage = new createjs.Stage(canvas);
    
    createjs.Touch.enable(stage);
    
    stage.enableMouseOver(10);
    stage.mouseMoveOutside = true;
    
    var image = new Image();
    image.src = "assets/daisy.png";
    image.onload = handleImageLoad;
}

function stop(e) {
    createjs.Ticker.removeEventListener("tick",tick);
}

function handleImageLoad(event) {
    var image = event.target;
    var bitmap;
    var container = new createjs.Container();
    stage.addChild(container);
    
    for(var i=0;i<100;i++){
        bitmap = new createjs.Bitmap(image);
        container.addChild(bitmap);
        bitmap.x = canvas.width*Math.random()|0;
        bitmap.y = canvas.height*Math.random()|0;
        bitmap.rotation = 360 * Math.random()|0;
        bitmap.regX = bitmap.image.width/2|0; // regX干什么用的? 
        bitmap.regY = bitmap.image.height/2|0;
        bitmap.scaleX = bitmap.scaleY = bitmap.scale = Math.random()*0.4+0.6;
        bitmap.name = "bmp_"+i;
        bitmap.cursor = "pointer";
        
        bitmap.on("mousedown",function(evt){
            this.parent.addChild(this);
            this.offset = {x:this.x-evt.stageX,y:this.y-evt.stageY};
        });
        
        bitmap.on("pressmove",function(evt){
            this.x = evt.stageX + this.offset.x; // this.offset.x 干什么用的?是为了防止图片中心突然跳动到鼠标位置的;
            this.y = evt.stageY + this.offset.y;
            
            update = true;
        });
        
        bitmap.on("rollover",function(evt){
            this.scaleX = this.scaleY = this.scale*1.2;
            update = true;
        });
        
        bitmap.on("rollout",function(evt){
            this.scaleX = this.scaleY = this.scale;
            update = true;
        });
    }
    
    createjs.Ticker.addEventListener("tick",tick);
    
}

function tick(event) {
    if(update){
        update = false;
        stage.update(event);
    }
}

 

转载于:https://www.cnblogs.com/stono/p/5653099.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值