安卓简易开发笔记条例
一、ScrollView的使用和布局
- 首先编写ReadAdapter类,可直接复制进行使用,来自小小小白冷博主的文章-b站材料2–Adapter源文件
package com.example.myapplication2.Adapter;
import android.annotation.SuppressLint;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;
//这里的 myapplication2 在你进行复制后需要修改为你的项目名字
import com.example.myapplication2.R;
public class ReadAdapter extends RecyclerView.Adapter <RecyclerView.ViewHolder>{
@NonNull
private Context mContext;
private OnItemClickListener mListener;
//private List<String> list;
public ReadAdapter(Context context , OnItemClickListener listener){
this.mContext = context;
this.mListener = listener;
}
@Override
public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
//viewType可以通过这个,展示不同的item
return new LinearViewHolder(LayoutInflater.from(mContext).inflate(R.layout.courseitem, parent, false));
//这里需要传入每个item长什么样的布局,需要去layout中去画我们的布局
}
@Override
//通过getItemViewType的返回值来选择具体的item显示
public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, @SuppressLint("RecyclerView")final int position) {
((LinearViewHolder)holder).textView.setText("图片选择");
//如果是直接用viewholder的话,是不能用test view的
//将点击事件放到外面
holder.itemView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//Toast.makeText(mContext,"click..."+position,Toast.LENGTH_SHORT).show();
mListener.onClick(position);
}
});
}
//去控制viewType的方法,根据位置的奇偶性来区分
@Override
public int getItemViewType(int position) {
if(position % 2 == 0){
return 0;//偶数
}else{
return 1;
}
}
@Override
public int getItemCount() {
return 10;
}
class LinearViewHolder extends RecyclerView.ViewHolder{
private TextView textView;
public LinearViewHolder(View itemView){
super(itemView);
textView = itemView.findViewById(R.id.finish_title);
}
}
//接口
public interface OnItemClickListener{
void onClick(int pos);
}
}
- 在界面布局中,ScrollView下添加线性布局,在线性布局中引用RecyclerView
<ScrollView 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"
android:orientation="vertical"
tools:context=".ReadActivity">
<LinearLayout
android:id="@+id/ll_read"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="15dp"
android:orientation="vertical">
<TextView
android:id="@+id/ll_read_finish"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:text="已完成课程"
android:layout_gravity="center"
/>
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/rv_finished"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="20dp"
/>
</LinearLayout>
</ScrollView>
- 新建布局文件 course-item 作为 ScrollView的内容,course-item的布局可以自己定义,之后会通过ReadAdapter中的代码加载进ScrollView中
即:
@Override
public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
//viewType可以通过这个,展示不同的item
return new LinearViewHolder(LayoutInflater.from(mContext).inflate(R.layout.courseitem, parent, false));
//这里需要传入每个item长什么样的布局,需要去layout中去画我们的布局
}
- 编写相关java类
//先声明控件
private RecyclerView rcfinished;
//在写相关事件
rcfinished=findViewById(R.id.rv_finished);
rcfinished.setLayoutManager(new LinearLayoutManager(ReadActivity.this));
rcfinished.setAdapter(new ReadAdapter(ReadActivity.this, new ReadAdapter.OnItemClickListener() {
@Override
public void onClick(int pos) {
Toast.makeText(ReadActivity.this,"click..."+pos,Toast.LENGTH_LONG).show();
}
}));