目的
- 请根据课程内容设计一个app的门户框架,需要实现3-4个tab切换效果;本功能要求需要的技术为:activity、xml、fragment
- 在任一tab页中实现列表效果;本功能的实现需要使用recycleview;
过程
- 分别实现各个界面的UI
- 使用fragment实现各界面跳转
- 使用recycleview实现列表
1. 实现UI
1.1. 实现主界面UI
1.1.1. 设计顶部
- 建立一个textview将其设置为文本居中,字体大小设置为40sp
1.1.1.1. 代码
- top.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/top"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="center"
android:text="@string/wc"
android:textSize="40sp" />
</LinearLayout>
1.1.1.2. 界面
1.1.2. 设置底部按键
- 在linearlayout中创建四个横向的linearlayout,在创建的linearlayout中创建图片和文本
- 将图片放入drawable文件夹中
- 插入图片,设置图片路径,设置字体大小,文字居中,文本内容等
- 将四个linearlayout的宽度比重设置为1,使其均分屏幕宽度
1.1.2.1. 代码
- button.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content"
tools:ignore="DisableBaselineAlignment">
<LinearLayout
android:id="@+id/Lo1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:orientation="vertical"
tools:ignore="UseCompoundDrawables">
<ImageView
android:id="@+id/imageView1"
android:layout_width="match_parent"
android:layout_height="100dp"
android:src="@drawable/a" />
<TextView
android:id="@+id/textView1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:text="@string/lt"
android:textSize="34sp" />
</LinearLayout>
<LinearLayout
android:id="@+id/Lo2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:orientation="vertical"
tools:ignore="UseCompoundDrawables">
<ImageView
android:id="@+id/imageView2"
android:layout_width="match_parent"
android:layout_height="100dp"
android:src="@drawable/a" />
<TextView
android:id="@+id/textView2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:text="@string/txl"
android:textSize="34sp" />
</LinearLayout>
<LinearLayout
android:id="@+id/Lo3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:orientation="vertical"
tools:ignore="UseCompoundDrawables">
<ImageView
android:id="@+id/imageView3"
android:layout_width="match_parent"
android:layout_height="100dp"
android:src="@drawable/a" />
<TextView
android:id="@+id/textView3"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:text="@string/fx"
android:textSize="34sp" />
</LinearLayout>
<LinearLayout
android:id="@+id/Lo4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:orientation="vertical"
tools:ignore="UseCompoundDrawables">
<ImageView
android:id="@+id/imageView4"
android:layout_width="match_parent"
android:layout_height="100dp"
android:src="@drawable/a" />
<TextView
android:id="@+id/textView4"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:text="@string/w"
android:textSize="34sp" />
</LinearLayout>
</LinearLayout>
1.1.2.2. 界面
1.1.3. 合并为主界面
- 使用include导入top和button
1.1.3.1. 代码
- activity_recycle_view.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity"
>
<include layout="@layout/top" />
<FrameLayout
android:id="@+id/content"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
>
</FrameLayout>
<include layout="@layout/button" />
</LinearLayout>
1.1.3.2. 界面
2. 使用fragment实现界面跳转
2.1. 设计跳转界面UI
- 设计四个界面,其中分别显示聊天,通讯录,发现,我
2.1.1. 代码
- layout1.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/textView5"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:text="这是聊天界面"
android:textSize="40sp" />
</LinearLayout>
2.1.2. 界面
2.2.设计点击效果
- 实现 View.OnClickListener 接口
- 为每个 LinearLayout 元素设置点击事件监听器,通过 setOnClickListener(this) 将当前的 MainActivity 实例设置为监听器。
- 实现onClick,执行时显示某一界面
2.2.1. 代码
- MainActivity.java
LinearLayout lo1,lo2,lo3,lo4;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//列表
lo1 = findViewById(R.id.Lo1);
lo2 = findViewById(R.id.Lo2);
lo3 = findViewById(R.id.Lo3);
lo4 = findViewById(R.id.Lo4);
initialfragment();
lo1.setOnClickListener(this); //将当前的 Activity(或 Fragment)实例设置为 lo1 的点击事件监听器
lo2.setOnClickListener(this);
lo3.setOnClickListener(this);
lo4.setOnClickListener(this);
}
@Override
public void onClick(View view) {
if(view.getId()==R.id.Lo1) show(1);
if(view.getId()==R.id.Lo2) show(2);
if(view.getId()==R.id.Lo3) show(3);
if(view.getId()==R.id.Lo4) show(4);
}
2.3. 实现各个界面的切换
- 隐藏所有界面,切到到某一界面时隐藏其他界面,只显示当前界面
- initialfragment初始化,显示四个子界面并隐藏,初始默认显示界面1
- show显示给出的界面
- hide隐藏给出的界面
2.3.1. 代码
- MainActivity.java
private void show(int i) {//显示给出的界面
FragmentTransaction transaction = fm.beginTransaction();
Hide(transaction);
switch (i){
case 1:transaction.show(fragment1);break;
case 2:transaction.show(fragment2);break;
case 3:transaction.show(fragment3);break;
case 4:transaction.show(fragment4);break;
default:break;
}
transaction.commit();
}
public void initialfragment(){//初始化,显示四个子界面并隐藏,初始默认显示界面1
FragmentTransaction ft= fm.beginTransaction() //重启事件
.add(androidx.appcompat.R.id.content,fragment1)
.add(androidx.appcompat.R.id.content,fragment2)
.add(androidx.appcompat.R.id.content,fragment3)
.add(androidx.appcompat.R.id.content,fragment4)
.hide(fragment1)
.hide(fragment2)
.hide(fragment3)
.hide(fragment4)
.show(fragment1);
ft.commit();
}
private void Hide(FragmentTransaction ft) {//将界面隐藏
ft.hide(fragment1)
.hide(fragment2)
.hide(fragment3)
.hide(fragment4);
}
2.4. 将xml转换为view对象
- inflater.inflate用于将 XML 文件中定义的布局转换为对应的 View 对象
- fragment.java
public class Fragment1 extends Fragment{
@Override
public View onCreateView(LayoutInflater inflater,ViewGroup container,Bundle savedInstanceState){
return inflater.inflate(R.layout.layout1,container,false);
}
}
3. 使用recycleview实现列表
3.1. 列表界面
3.1.1. 代码
- activity_recycle_view.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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=".RecycleViewActivity">
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/RecyclerView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.432" />
</androidx.constraintlayout.widget.ConstraintLayout>
3.1.2. 界面
3.2. 列表元素布局
3.1.1. 代码
- item.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/textView8"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:text="Text"
android:textColor="@color/black"
android:textSize="40sp" />
</LinearLayout>
3.1.2. 界面
3.2. 写适配器
- onCreateViewHolder() 方法用于创建并返回一个 Myholder 对象。
- onBindViewHolder() 将数据绑定到 ViewHolder 上。使用list中的每个值给Myholder赋值。
- getItemCount确定 RecyclerView 中的列表项数量。
3.2.1. 代码
- Myadapter.java
public Myadapter(Context context,List list){
context1=context;
list1=list;
}
@NonNull
@Override
public Myholder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view= LayoutInflater.from(context1).inflate(R.layout.item,parent,false);
Myholder holder=new Myholder(view);
return holder;
}
@Override
public void onBindViewHolder(@NonNull Myholder holder, int position) {
holder.textview.setText(list1.get(position));
}
@Override
public int getItemCount() {
return list1.size();
}
public class Myholder extends RecyclerView.ViewHolder {
TextView textview;
public Myholder(@NonNull View itemView) {
super(itemView);
textview=itemView.findViewById(R.id.textView8);
}
}
3.3. 写RecycleViewActivity 类
- 创建一个 RecyclerView 对象,然后通过 for 循环遍历 0 到 8 这 9 个数字,将 “这是第” + i + “行” 添加到数据集合中。
- 创建了一个 Myadapter 对象,通过调用 setAdapter() 方法将该适配器绑定到 RecyclerView 上。
- 变量 context 在适配器中使用,因此需要以成员变量的形式保存在该类中。
3.4. 代码
- RecycleViewActivity.java
public class RecycleViewActivity extends AppCompatActivity {
RecyclerView recycleview;
Myadapter adapter;
Context context;
List<String> list;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_recycle_view);
recycleview=findViewById(R.id.RecyclerView1);
list=new ArrayList<>();
for(int i=0;i<9;i++){
list.add("这是第"+i+"行");
}
context=this;
adapter =new Myadapter(this,list);
recycleview.setAdapter(adapter);
LinearLayoutManager manager=new LinearLayoutManager(this);
manager.setOrientation(RecyclerView.VERTICAL);
recycleview.setLayoutManager(manager);
}
}
3.5. 测试
- 在注册文件AndroidManifest.xml中将初始界面由MainActivity换为RecycleViewActivity.java
3.5.1. 代码
- AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<!-- 注册文件 -->
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<application
android:allowBackup="true"
android:dataExtractionRules="@xml/data_extraction_rules"
android:fullBackupContent="@xml/backup_rules"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.Work"
tools:targetApi="31">
<activity
android:name=".MainActivity"
android:exported="false" />
<activity
android:name=".RecycleViewActivity"
android:exported="true">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
3.5.2. 运行结果
4. 将RecycleViewActivity合并进fragment
- RecycleViewActivity是独立的界面,如果直接使用startActivity使用RecycleViewActivity会导致该界面完全覆盖之前的MainActivity界面,导致底部按钮以及顶部无法显示,需要使用startactivityforresult,但该方法已经被删除了,因此直接将RecycleViewActivity的代码直接合并到fragment中。
- 因为当前类为fragment,因此传值不能传this而是直接传context
4.1. 代码
- fragment2.java
public class Fragment2 extends Fragment {
RecyclerView recycleview;
Myadapter adapter;
Context context;
List<String> list;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view=inflater.inflate(R.layout.activity_recycle_view,container,false);
recycleview=view.findViewById(R.id.RecyclerView1);
context=view.getContext();
list=new ArrayList<>();
for(int i=0;i<9;i++){
list.add("这是第"+i+"行");
}
adapter =new Myadapter(context,list);
recycleview.setAdapter(adapter);
LinearLayoutManager manager=new LinearLayoutManager(context);
manager.setOrientation(RecyclerView.VERTICAL);
recycleview.setLayoutManager(manager);
return view;
}
}
结果