仿iOS个人资料页面布局可以上下滑动

/**
 * 可以拖动的ScrollView
 *
 */
public class CustomerScrollView extends ScrollView {

    private static final int size = 2;
    private View inner;
    private float y;
    private Rect normal = new Rect();;

    public CustomerScrollView(Context context) {
        super(context);
    }

    public CustomerScrollView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    @Override
    protected void onFinishInflate() {
        if (getChildCount() > 0) {
            inner = getChildAt(0);
        }
    }

    @SuppressLint("ClickableViewAccessibility")
    @Override
    public boolean onTouchEvent(MotionEvent ev) {
        if (inner == null) {
            return super.onTouchEvent(ev);
        } else {
            commOnTouchEvent(ev);
        }
        return super.onTouchEvent(ev);
    }

    public void commOnTouchEvent(MotionEvent ev) {
        int action = ev.getAction();
        switch (action) {
            case MotionEvent.ACTION_DOWN:
                y = ev.getY();
                break;
            case MotionEvent.ACTION_UP:
                if (isNeedAnimation()) {
                    animation();
                }
                break;
            case MotionEvent.ACTION_MOVE:
                final float preY = y;
                float nowY = ev.getY();
                /**
                 * size=4 表示 拖动的距离为屏幕的高度的1/4
                 */
                int deltaY = (int) (preY - nowY) / size;

                y = nowY;
                if (isNeedMove()) {
                    if (normal.isEmpty()) {
                        normal.set(inner.getLeft(), inner.getTop(), inner.getRight(), inner.getBottom());
                        return;
                    }
                    int yy = inner.getTop() - deltaY;

                    // 移动布局
                    inner.layout(inner.getLeft(), yy, inner.getRight(), inner.getBottom() - deltaY);
                }
                break;
            default:
                break;
        }
    }

    public void animation() {
        TranslateAnimation ta = new TranslateAnimation(0, 0, inner.getTop(), normal.top);
        ta.setDuration(200);
        inner.startAnimation(ta);
        inner.layout(normal.left, normal.top, normal.right, normal.bottom);
        normal.setEmpty();
    }

    public boolean isNeedAnimation() {
        return !normal.isEmpty();
    }

    public boolean isNeedMove() {
        int offset = inner.getMeasuredHeight() - getHeight();
        int scrollY = getScrollY();
        if (scrollY == 0 || scrollY == offset) {
            return true;
        }
        return false;
    }

}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用UICollectionView来实现iOS仿抖音视频上下划动的效果。下面是一个简单的示例代码,演示了如何创建带有视频的UICollectionView,并实现上下滑动的效果。 首先,创建一个UICollectionView,并设置其滚动方向为垂直方向: ```swift let layout = UICollectionViewFlowLayout() layout.scrollDirection = .vertical let collectionView = UICollectionView(frame: CGRect(x: 0, y: 0, width: view.bounds.width, height: view.bounds.height), collectionViewLayout: layout) collectionView.delegate = self collectionView.dataSource = self ``` 接下来,实现UICollectionViewDelegate和UICollectionViewDataSource协议的相关方法: ```swift extension ViewController: UICollectionViewDelegate, UICollectionViewDataSource { func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int { return videos.count } func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell { let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "VideoCell", for: indexPath) as! VideoCell cell.videoURL = videos[indexPath.item] return cell } } class VideoCell: UICollectionViewCell { var videoURL: URL? { didSet { // 加载并显示视频 } } } ``` 在上述代码中,假设你已经有一个包含视频URL的数组videos,并且VideoCell是自定义的UICollectionViewCell子类,用于加载和显示视频。 最后,你可以在ViewController中添加滑动手势识别器,并在滑动手势回调方法中更新collectionView的contentOffset来实现上下滑动: ```swift let swipeGesture = UIPanGestureRecognizer(target: self, action: #selector(handleSwipe(_:))) collectionView.addGestureRecognizer(swipeGesture) @objc func handleSwipe(_ gesture: UIPanGestureRecognizer) { let translation = gesture.translation(in: collectionView) if gesture.state == .changed { collectionView.contentOffset.y = -translation.y } else if gesture.state == .ended { let velocity = gesture.velocity(in: collectionView) if velocity.y > 0 { // 向下滑动,加载下一页视频 } else { // 向上滑动,加载上一页视频 } } } ``` 在handleSwipe方法中,我们通过手势的translation来计算滑动的偏移量,并将其应用到collectionView的contentOffset上。在滑动手势结束时,你可以根据滑动的速度和方向来加载下一页或上一页的视频。 这只是一个简单的示例,你可以根据自己的需求进行进一步的定制和优化。希望对你有所帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值