仿探探卡片滑动效果

首先导入依赖

compile 'com.github.bumptech.glide:glide:3.6.1'

github定制,主要的是里面的casdswipelayout,然后直接观察一下fanxianfragment里面的实现代码,即可简单实现

Github下载定制

下面是效果,代码太多,就不粘了






  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
探探左右滑动效果一般是通过RecyclerView和CardView实现的。可以使用RecyclerView的LayoutManager来实现左右滑动效果,同时使用CardView来展示个性化的卡片内容。具体实现可以参考以下步骤: 1. 使用RecyclerView作为容器,通过LayoutManager设置布局管理器,实现左右滑动效果。 2. 创建CardView作为RecyclerView的item布局,用于展示个性化的卡片内容。 3. 使用Adapter来管理RecyclerView的数据源,通过Adapter的getView方法将数据绑定到CardView上,同时实现左右滑动效果。 4. 动态添加数据可以通过在Adapter中添加数据,然后调用Adapter的notifyDataSetChanged方法来刷新RecyclerView中的数据。 下面是一些示例代码,可以帮助你更好地理解实现过程: 1. 在布局文件中添加RecyclerView组件: ``` <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 2. 创建CardView作为RecyclerView的item布局,例如定义一个名为card_view.xml的布局文件: ``` <?xml version="1.0" encoding="utf-8"?> <androidx.cardview.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/cardView" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_margin="8dp"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <ImageView android:id="@+id/avatar" android:layout_width="match_parent" android:layout_height="200dp" android:scaleType="centerCrop" /> <TextView android:id="@+id/name" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="8dp" android:textColor="@color/black" android:textSize="16sp" /> <TextView android:id="@+id/age" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="8dp" android:textColor="@color/black" android:textSize="16sp" /> </LinearLayout> </androidx.cardview.widget.CardView> ``` 3. 创建Adapter用于管理RecyclerView的数据源: ``` public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> { private List<User> mData; private Context mContext; public MyAdapter(Context context, List<User> data) { this.mContext = context; this.mData = data; } public void addData(User user) { mData.add(user); notifyDataSetChanged(); } @NonNull @Override public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(mContext).inflate(R.layout.card_view, parent, false); return new ViewHolder(view); } @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { User user = mData.get(position); holder.mAvatar.setImageResource(user.getAvatar()); holder.mName.setText(user.getName()); holder.mAge.setText(user.getAge()); } @Override public int getItemCount() { return mData.size(); } public static class ViewHolder extends RecyclerView.ViewHolder { private ImageView mAvatar; private TextView mName; private TextView mAge; public ViewHolder(View itemView) { super(itemView); mAvatar = itemView.findViewById(R.id.avatar); mName = itemView.findViewById(R.id.name); mAge = itemView.findViewById(R.id.age); } } } ``` 4. 在Activity中初始化RecyclerView以及Adapter: ``` public class MainActivity extends AppCompatActivity { private RecyclerView mRecyclerView; private MyAdapter mAdapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mRecyclerView = findViewById(R.id.recyclerView); mRecyclerView.setLayoutManager(new CardSliderLayoutManager(this)); mAdapter = new MyAdapter(this, new ArrayList<>()); mRecyclerView.setAdapter(mAdapter); initData(); } private void initData() { User user1 = new User(R.drawable.avatar1, "张三", "18岁"); User user2 = new User(R.drawable.avatar2, "李四", "20岁"); User user3 = new User(R.drawable.avatar3, "王五", "22岁"); mAdapter.addData(user1); mAdapter.addData(user2); mAdapter.addData(user3); } } ``` 在上述代码中,我们使用了CardSliderLayoutManager来作为RecyclerView的LayoutManager,它可以实现左右滑动效果。在initData方法中,我们通过调用Adapter的addData方法来动态添加数据。当我们调用addData方法时,会执行Adapter的notifyDataSetChanged方法,这样就可以实现动态添加数据的效果

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值