短视频软件开发,RecyclerView实现拖拽效果

短视频软件开发,RecyclerView实现拖拽效果

RecyclerView适配器监听ItemTouchHelper的回调,自定义RecyclerView适配器代码TestAdapter如下:

 

1
<br>package com.example.myapplication;<br>import android.content.Context;<br>import android.graphics.Color;<br>import android.view.LayoutInflater;<br>import android.view.View;<br>import android.view.ViewGroup;<br>import android.widget.TextView;<br>import androidx.annotation.NonNull;<br>import androidx.recyclerview.widget.RecyclerView;<br>import java.util.Collections;<br>import java.util.List;<br>public class TestAdapter extends RecyclerView.Adapter<TestAdapter.TestViewHolder> implements ItemMoveCallback {<br>    private Context mContext;<br>    private List<String> mTestList;<br>    public TestAdapter(Context mContext, List<String> testList) {<br>        this.mContext = mContext;<br>        this.mTestList = testList;<br>    }<br>    @Override<br>    public TestViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {<br>        return new TestViewHolder(LayoutInflater.from(mContext).inflate(R.layout.item_test, null, false));<br>    }<br>    @Override<br>    public void onBindViewHolder(final TestViewHolder holder, final int position) {<br>        holder.tvTest.setText(mTestList.get(position));<br>    }<br>    @Override<br>    public int getItemCount() {<br>        return mTestList.size();<br>    }<br>    @Override<br>    public void onItemMove(int fromPosition, int toPosition) {<br>        if (fromPosition < toPosition) {<br>            for (int i = fromPosition; i < toPosition; i++) {<br>                Collections.swap(mTestList, i, i + 1);<br>            }<br>        } else {<br>            for (int i = fromPosition; i > toPosition; i--) {<br>                Collections.swap(mTestList, i, i - 1);<br>            }<br>        }<br>        notifyItemMoved(fromPosition, toPosition);<br>    }<br>    static class TestViewHolder extends RecyclerView.ViewHolder implements ItemHolderMoveCallback{<br>        private TextView tvTest;<br>        public TestViewHolder(View itemView) {<br>            super(itemView);<br>            tvTest = (TextView) itemView.findViewById(R.id.tv_test);<br>        }<br>        @Override<br>        public void onItemHolderMoveStart() {<br>            tvTest.setTextSize(40);<br>            itemView.setBackgroundColor(Color.RED);<br>        }<br>        @Override<br>        public void onItemHolderMoveEnd() {<br>            tvTest.setTextSize(32);<br>            itemView.setBackgroundResource(R.color.colorAccent);<br>        }<br>    }<br>}

 

TestAdapter与RecyclerView绑定:

 

1
<br>        mRvTest.setLayoutManager(gridLayoutManager);<br>        mTestList = new ArrayList<>();<br>        for (int i = 0; i < 20; i++) {<br>            mTestList.add("测试文本" + i);<br>        }<br>        mTestAdapter = new TestAdapter(this, mTestList);<br>        mRvTest.setAdapter(mTestAdapter);

 

布局文件中的代码:

 

1
<br>  <androidx.recyclerview.widget.RecyclerView<br>        android:id="@+id/rv_test"<br>        android:layout_width="wrap_content"<br>        android:layout_height="wrap_content" />

 

以上就是短视频软件开发,RecyclerView实现拖拽效果, 更多内容欢迎关注之后的文章

 

posted @   云豹科技-苏凌霄  阅读(82)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示