簡體   English   中英

請幫助? 當元素被拖動拾取時,它是否僅從中間拾取?

[英]Help please? When the element gets picked up by the drag, it only gets picked up from the middle?

例如,我有一個div,當您拿起它開始拖動時,它將捕捉div,因此光標/鼠標位於其中間。

這是代碼。

// DEFINE DEFAULT VARIABLES
var _target=null, _dragx=null, _dragy=null, _rotate=null, _resort=null;
var _dragging=false, _sizing=false, _animate=false;
var _rotating=0, _width=0, _height=0, _left=0, _top=0, _xspeed=0, _yspeed=0;
var _zindex=1000;

jQuery.fn.touch = function(settings) {

    // DEFINE DEFAULT TOUCH SETTINGS
    settings = jQuery.extend({
        animate: true,
        sticky: false,
        dragx: true,
        dragy: true,
        rotate: false,
        resort: true,
        scale: false
    }, settings);

    // BUILD SETTINGS OBJECT
    var opts = [];
    opts = $.extend({}, $.fn.touch.defaults, settings);

    // ADD METHODS TO OBJECT
    this.each(function(){
        this.opts = opts;
        this.ontouchstart = touchstart;
        this.ontouchend = touchend;
        this.ontouchmove = touchmove;
        this.ongesturestart = gesturestart;
        this.ongesturechange = gesturechange;
        this.ongestureend = gestureend;
    });
};
function touchstart(e){
    _target = this.id;
    _dragx = this.opts.dragx;
    _dragy = this.opts.dragy;
    _resort = this.opts.resort;
    _animate = this.opts.animate;
    _xspeed = 0;
    _yspeed = 0;

    $(e.changedTouches).each(function(){

        var curLeft = ($('#'+_target).css("left") == 'auto') ? this.pageX : parseInt($('#'+_target).css("left"));
        var curTop = ($('#'+_target).css("top") == 'auto') ? this.pageY : parseInt($('#'+_target).css("top"));

        if(!_dragging && !_sizing){
            _left = (e.pageX - curLeft);
            _top = (e.pageY - curTop);
            _dragging = [_left,_top];
            if(_resort){
                _zindex = ($('#'+_target).css("z-index") == _zindex) ? _zindex : _zindex+1;
                $('#'+_target).css({ zIndex: _zindex });
            }
        }
    });
};
function touchmove(e){

    if(_dragging && !_sizing && _animate) {

        var _lastleft = (isNaN(parseInt($('#'+_target).css("left")))) ? 0:parseInt($('#'+_target).css("left"));
        var _lasttop = (isNaN(parseInt($('#'+_target).css("top")))) ? 0:parseInt($('#'+_target).css("top"));
    }

    $(e.changedTouches).each(function(){

        e.preventDefault();

        _left = (this.pageX-(parseInt($('#'+_target).css("width"))/2));
        _top = (this.pageY-(parseInt($('#'+_target).css("height"))/2));

        if(_dragging && !_sizing) {

            if(_animate){
                _xspeed = Math.round((_xspeed + Math.round( _left - _lastleft))/1.5);
                _yspeed = Math.round((_yspeed + Math.round( _top - _lasttop))/1.5);
            }

            if(_dragx || _dragy) $('#'+_target).css({ position: "absolute" });
            if(_dragx) $('#'+_target).css({ left: _left+"px" });
            if(_dragy) $('#'+_target).css({ top: _top+"px" });

        }
    });
};
function touchend(e){
    $(e.changedTouches).each(function(){
        if(!e.targetTouches.length){
            _dragging = false;
            if(_animate){
                _left = ($('#'+_target).css("left") == 'auto') ? this.pageX : parseInt($('#'+_target).css("left"));
                _top = ($('#'+_target).css("top") == 'auto') ? this.pageY : parseInt($('#'+_target).css("top"));

                var animx = (_dragx) ? (_left+_xspeed)+"px" : _left+"px";
                var animy = (_dragy) ? (_top+_yspeed)+"px" : _top+"px";

                if(_dragx || _dragy) $('#'+_target).animate({ left: animx, top: animy }, "fast");
            }
        }
    });

    setTimeout(changeBack,5000,_target);
};
function gesturestart(e){
    _sizing = [$('#'+this.id).css("width"), $('#'+this.id).css("height")];
};
function gesturechange(e){
    if(_sizing){
        _width = (this.opts.scale) ? Math.min(parseInt(_sizing[0])*e.scale, 300) : _sizing[0];
        _height = (this.opts.scale) ? Math.min(parseInt(_sizing[1])*e.scale, 300) : _sizing[1];
        _rotate = (this.opts.rotate) ? "rotate(" + ((_rotating + e.rotation) % 360) + "deg)" : "0deg";      
        $('#'+this.id).css({ width: _width+"px", height: _height+"px", webkitTransform: _rotate });
    }
};
function gestureend(e){
    _sizing = false;
    _rotating = (_rotating + e.rotation) % 360;
};

這僅在您開始拖動時發生,而不是在您第一次單擊時發生。

有人告訴我要更改:

_left = (this.pageX-(parseInt($('#'+_target).css("width"))/2));
_top = (this.pageY-(parseInt($('#'+_target).css("height"))/2));

至:

_left = (this.pageX);
_top = (this.pageY);

但這只是使它從頂部上升。
如何使它從鼠標單擊的位置拾取?

編輯:這是為ipad,它無法在計算機上進行測試..但任何幫助都將是巨大的,即時通訊卡住了

我對_top_left變量了解不多,但是也許可以在onclick事件期間將它們設置為鼠標位置。 該頁面包含一些用於選擇鼠標位置的代碼: 使用Javascript進行鼠標跟蹤

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM