UIView的弹性拖动就像从UITableView的顶部拖动一样

时间:2012-12-21 09:37:42

标签: iphone ios uigesturerecognizer

我试图找出拖动视图的逻辑,然后当拖动到达某个点时使拖动指数减慢。我有点工作,虽然马车和有点hacky。我想知道是否有更好的公式我可以使用而不是newPosition = (-kDeleteViewWidth + (point.x * 0.2));

完整的手势代码如下。

// kDeleteViewWidth is defined as 80.0f
UIPanGestureRecognizer *gesture = (UIPanGestureRecognizer *)sender;
CGPoint point = [gesture translationInView:self];

if ([gesture state] == UIGestureRecognizerStateBegan)
    _initialPosition = _topView.frame.origin;

if ([gesture state] == UIGestureRecognizerStateChanged)
{

    // Hacky Elastic method
    float newPosition = _initialPosition.x + point.x;
    if (point.x < -kDeleteViewWidth)
        newPosition = (-kDeleteViewWidth + (point.x * 0.2));
    [_topView setFrame:CGRectMake(newPosition, 0, self.contentView.frame.size.width, self.contentView.frame.size.height)];
}

3 个答案:

答案 0 :(得分:4)

为了完整起见,继承了我的代码:

- (void)swipeCell:(id)sender
{
    UIPanGestureRecognizer *gesture = (UIPanGestureRecognizer *)sender;
    CGPoint point = [gesture translationInView:self];

    if ([gesture state] == UIGestureRecognizerStateBegan)
    {
        // CGPoint initialPosition
        _initialPosition = _topView.frame.origin;
    }

    if ([gesture state] == UIGestureRecognizerStateChanged)
    {

        // Hacky Elastic method
        float newPosition = _initialPosition.x + point.x;

        // Starting point
        if (_initialPosition.x == 0)
        {
            // Once we get to our pre-defined kDeleteViewWidth, start dividing by 5
            if (_topView.frame.origin.x < -kDeleteViewWidth) {
                float distance = (point.x - -kDeleteViewWidth);
                float newDistance = distance / 5;
                newPosition = (-kDeleteViewWidth + newDistance);
            }

            else if (_topView.frame.origin.x > 0)
            {
                float distance = point.x;
                float newDistance = distance / 5;
                newPosition = newDistance;
            }
        }

        else if (_topView.frame.origin.x < -kDeleteViewWidth)
        {
            float distance = point.x;
            float newDistance = distance / 5;
            newPosition = (-kDeleteViewWidth + newDistance);
        }

        else if (_topView.frame.origin.x > 0)
        {
            float distance = point.x + _initialPosition.x;
            float newDistance = distance / 5;
            newPosition = newDistance;
        }

        [_topView setFrame:CGRectMake(newPosition, 0, self.contentView.frame.size.width, self.contentView.frame.size.height)];
    }

    if ([gesture state] == UIGestureRecognizerStateEnded || [gesture state] == UIGestureRecognizerStateCancelled) {

        // If we have scrolled over a 1/3 of the way to kDeleteViewWidth, move to kDeleteViewWidth
        if (point.x < -(kDeleteViewWidth / 3)) {
            [UIView animateWithDuration:kAnimationDuration animations:^{
                [_topView setFrame:CGRectMake(-kDeleteViewWidth, 0, self.contentView.frame.size.width, self.contentView.frame.size.height)];
            }];
            _isSwiped = YES;
        }

        // Otherwise animation back to 0
        else  {
            [UIView animateWithDuration:kAnimationDuration animations:^{
                [_topView setFrame:CGRectMake(0, 0, self.contentView.frame.size.width, self.contentView.frame.size.height)];
            } completion:^(BOOL finished) {
                [self removeShadow];
            }];
            _isSwiped = NO;
        }
    }
}

答案 1 :(得分:1)

我认为此链接可能对您有所帮助

Elastic dragging with a CALayer

答案 2 :(得分:1)

这是A nice Sample Project可用。

link:https://github.com/crocodella/PullableView

快乐编码!!