ViewPager显示多张图片
XML
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:id="@+id/lin"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:clipChildren="false">
<android.support.v4.view.ViewPager
android:id="@+id/vp_id"
android:layout_width="match_parent"
android:layout_height="300dp"
android:clipChildren="false"
android:layout_marginLeft="100dp"
android:layout_marginRight="100dp">
</android.support.v4.view.ViewPager>
</LinearLayout>
Activity
public class MainActivity extends AppCompatActivity {
private ViewPager vpId;
private List<ImageView> data=new ArrayList<>();
private LinearLayout lin;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
vpId = (ViewPager) findViewById(R.id.vp_id);
lin = (LinearLayout) findViewById(R.id.lin);
int[] images = new int[]{R.drawable.t1,R.drawable.t2,R.drawable.t3,R.drawable.t4,R.drawable.t5,R.drawable.t6};
for (int i = 0; i < images.length; i++) {
ImageView imageView = new ImageView(this);
imageView.setImageResource(images[i]);
data.add(imageView);
}
vpId.setAdapter(new PagerAdapter() {
@Override
public int getCount() {
return data.size();
}
@Override
public boolean isViewFromObject(@NonNull View view, @NonNull Object o) {
return view==o;
}
@NonNull
@Override//产生一个新视图
public Object instantiateItem(@NonNull ViewGroup container, int position) {
container.addView(data.get(position));//添加
return data.get(position);//返回添加成功的控件
}
@Override//移除一张图片
public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
container.removeView(data.get(position));//移除
}
});
vpId.setOffscreenPageLimit(3);
vpId.setPageMargin(10);
lin.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
return vpId.dispatchTouchEvent(event);
}
});
}
}
滑动删除
添加依赖
implementation “com.daimajia.swipelayout:library:1.2.0@aar”
implementation ‘com.android.support:recyclerview-v7:28.0.0’
XML
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".Main2Activity">
<android.support.v7.widget.RecyclerView
android:id="@+id/rv_id"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
</LinearLayout>
MainActivity
public class Main2Activity extends AppCompatActivity {
private static final String TAG = "Main2Activity";
private RecyclerView rvId;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main2);
rvId = (RecyclerView) findViewById(R.id.rv_id);
List<String> data=new ArrayList<>();
for (int i = 0; i < 30; i++) {
data.add("哒哒哒"+i);
}
LinearLayoutManager manager = new LinearLayoutManager(this);
rvId.setLayoutManager(manager);
RVAdapter adapter = new RVAdapter(data, this);
rvId.setAdapter(adapter);
}
}
Swip.xml
<?xml version="1.0" encoding="utf-8"?>
<com.daimajia.swipe.SwipeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:padding="10dp"
android:layout_height="match_parent"
android:id="@+id/swip_id">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<Button
android:id="@+id/delete"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@color/colorAccent"
android:text="删除"
android:textColor="#000"/>
</LinearLayout>
<LinearLayout
android:layout_width="800dp"
android:layout_height="wrap_content">
<TextView
android:id="@+id/text_content"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="要显示的文本"
android:textColor="#000"
android:textSize="18sp"/>
</LinearLayout>
</com.daimajia.swipe.SwipeLayout>
适配器
public class RVAdapter extends RecyclerSwipeAdapter<RVAdapter.MyViewHolder> {
private List<String> strings;
private Context mContext;
public RVAdapter(List<String> strings, Context context) {
this.strings = strings;
mContext = context;
}
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
return new MyViewHolder(LayoutInflater.from(mContext).inflate(R.layout.swip_layout,null));
}
@Override
public void onBindViewHolder(MyViewHolder viewHolder, final int position) {
viewHolder.mSwipeLayout.setShowMode(SwipeLayout.ShowMode.LayDown);//设置滑动模式
viewHolder.textView.setText(strings.get(position));
viewHolder.mButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//删除数据
strings.remove(position);
//删除动画
notifyItemRemoved(position);
//刷新适配器
notifyDataSetChanged();
}
});
}
@Override
public int getItemCount() {
return strings.size();
}
@Override
public int getSwipeLayoutResourceId(int position) {
return position;
}
class MyViewHolder extends RecyclerView.ViewHolder{
private SwipeLayout mSwipeLayout;
private Button mButton;
private TextView textView;
public MyViewHolder(@NonNull View itemView) {
super(itemView);
mSwipeLayout=itemView.findViewById(R.id.swip_id);
mButton=itemView.findViewById(R.id.delete);
textView=itemView.findViewById(R.id.text_content);
}
}
}