Android中的Fragment控件实现部分页面的切换
创作时间:
作者:
@小白创作中心
Android中的Fragment控件实现部分页面的切换
引用
CSDN
1.
https://m.blog.csdn.net/m0_74289031/article/details/139566887?spm=1001.2014.3001.5501
在Android开发中,Fragment是一种重要的UI组件,可以实现页面的动态切换和复用。本文将通过一个登录页面的例子,详细介绍如何使用Fragment实现页面切换。
在Android中,我们可以写两个页面,LoginActivity页面和RegisterActivity页面,然后把两个页面关联起来就可以实现登录和注册的切换了,但是这样的页面看起来不是很美观,那么,我们如何可以把页面做的更美观一点呢,在此,我们就可以通过Fragment来实现。
我们随便做一个登录页面来作为例子。由于我们注重于fragment的编写,所以我们的页面ui就写的潦草一点。
主页面布局(activity_main.xml)
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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"
tools:context=".MainActivity">
<RelativeLayout
android:id="@+id/rl_tab"
android:layout_width="match_parent"
android:layout_height="200dp"
android:layout_marginStart="15dp"
android:layout_marginTop="36dp"
android:background="#E6E3E3">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="100dp"
android:layout_marginTop="100dp">
<TextView
android:id="@+id/tv_no_pwd"
android:layout_width="200dp"
android:layout_height="100dp"
android:layout_marginLeft="400dp"
android:text="免密登录"
android:textColor="@drawable/selector_tab"
android:textSize="50dp" />
<TextView
android:id="@+id/tv_account"
android:layout_width="200dp"
android:layout_height="100dp"
android:layout_marginLeft="400dp"
android:layout_toRightOf="@id/tv_no_pwd"
android:text="密码登录"
android:textColor="@drawable/selector_tab"
android:textSize="50dp" />
</RelativeLayout>
</RelativeLayout>
<!--FrameLayout-->
<FrameLayout
android:id="@+id/fl_login"
android:layout_centerInParent="true"
android:layout_width="800dp"
android:layout_height="400dp"
android:layout_marginLeft="60dp"
android:layout_marginTop="350dp"
android:layout_marginRight="60dp" />
<Button
android:id="@+id/btnlogin"
android:layout_width="800dp"
android:layout_centerHorizontal="true"
android:layout_height="80dp"
android:layout_marginLeft="60dp"
android:layout_marginTop="800dp"
android:layout_marginRight="60dp"
android:backgroundTint="#44B6DC"
android:gravity="center"
android:text="@string/login"
android:textColor="#ffffff"
android:textSize="30sp" />
</RelativeLayout>
具体的ui设计可以根据自己的要求来写。
主页面逻辑(MainActivity.java)
package njitt.software.test;
import androidx.appcompat.app.AppCompatActivity;
import androidx.cardview.widget.CardView;
import androidx.fragment.app.FragmentManager;
import androidx.fragment.app.FragmentTransaction;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.FrameLayout;
import android.widget.RelativeLayout;
import android.widget.TextView;
import java.util.HashMap;
import njitt.software.test.fragment.LoginFragment;
import njitt.software.test.fragment.NopwdFragment;
public class MainActivity extends AppCompatActivity implements View.OnClickListener{
private HashMap<String, Object> map;
private CheckBox cvCheckLogin;
private TextView registerUserAgreement;
private RelativeLayout rlMain;
private RelativeLayout rlBack;
private CardView cvAccountLogin;
private RelativeLayout rlLogin;
private TextView tvPhoneTakeIn;
private TextView tvRegister;
private TextView tv_no_pwd;
private TextView tv_account;
private FrameLayout flLogin;
private Button btnlogin;
private NopwdFragment nopwdFragment;
private LoginFragment loginFragment;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
tv_no_pwd.performClick();
}
private void initView() {
flLogin = (FrameLayout) findViewById(R.id.fl_login);
rlMain = (RelativeLayout) findViewById(R.id.rl_main);
cvAccountLogin = (CardView) findViewById(R.id.cv_account_login);
rlLogin = (RelativeLayout) findViewById(R.id.rl_login);
flLogin = (FrameLayout) findViewById(R.id.fl_login);
btnlogin = (Button) findViewById(R.id.btnlogin);
flLogin = (FrameLayout) findViewById(R.id.fl_login);
tv_no_pwd = (TextView) findViewById(R.id.tv_no_pwd);
tv_account = (TextView)findViewById(R.id.tv_account);
tv_no_pwd.setOnClickListener(this);
tv_account.setOnClickListener(this);
}
private void setSelected() {
tv_no_pwd.setSelected(false);
tv_account.setSelected(false);
}
@Override
public void onClick(View view) {
FragmentManager fragmentManager = getSupportFragmentManager();
FragmentTransaction transaction = fragmentManager
.beginTransaction();
hideAllFragment(transaction);
switch (view.getId()) {
case R.id.tv_no_pwd:
setSelected();
tv_no_pwd.setSelected(true);
tv_account.setSelected(false);
if (nopwdFragment == null) {
nopwdFragment = new NopwdFragment();
transaction.add(R.id.fl_login, nopwdFragment);
} else {
transaction.show(nopwdFragment);
}
break;
case R.id.tv_account:
setSelected();
tv_account.setSelected(true);
tv_no_pwd.setSelected(false);
if (loginFragment == null) {
loginFragment = new LoginFragment();
transaction.add(R.id.fl_login, loginFragment);
} else {
transaction.show(loginFragment);
}
break;
default:
break;
}
transaction.commit();
}
private void hideAllFragment(FragmentTransaction transaction) {
if (nopwdFragment != null) {
transaction.hide(nopwdFragment);
}
if (loginFragment != null) {
transaction.hide(loginFragment);
}
}
}
这是定义文字的默认选中为false。定义一个fragmentManager管理器。是否隐藏页面。写一个fragment包。在包里写两个fragment页面。
密码登录Fragment布局(fragment_login.xml)
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout 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"
tools:context=".fragment.LoginFragment">
<androidx.cardview.widget.CardView
android:layout_width="680dp"
android:layout_height="90dp"
>
<TextView
android:layout_width="54dp"
android:layout_height="37dp"
android:text="+86"
android:textSize="28dp"
android:layout_marginLeft="40dp"
android:layout_marginTop="27dp" />
<View
android:layout_width="2dp"
android:layout_height="50dp"
android:background="#ECEFF1"
android:layout_marginLeft="134dp"
android:layout_marginTop="20dp" />
<EditText
android:id="@+id/et_account"
android:layout_width="546dp"
android:layout_height="match_parent"
android:layout_marginLeft="174dp"
android:background="@null"
android:hint="请输入手机号码"
android:textSize="28dp"/>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:layout_width="680dp"
android:layout_height="90dp"
android:layout_marginTop="130dp">
<EditText
android:id="@+id/et_password"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginLeft="40dp"
android:background="@null"
android:hint="请输入密码"
android:textSize="28dp"
android:password="true"/>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:id="@+id/cv_check"
android:layout_width="32dp"
android:layout_height="32dp"
android:layout_marginTop="260dp"
>
</androidx.cardview.widget.CardView>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal">
<TextView
android:layout_width="wrap_content"
android:layout_height="37dp"
android:text="我已阅读并同意"
android:layout_marginTop="256dp"
android:layout_marginLeft="48dp"
android:textSize="28dp" />
<TextView
android:id="@+id/tv_user_secret"
android:layout_width="wrap_content"
android:layout_height="37dp"
android:text="《用户隐私政策》"
android:layout_marginTop="256dp"
android:textSize="28dp"
android:textColor="#1598C4"/>
</LinearLayout>
<TextView
android:id="@+id/tv_forget"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="540dp"
android:text="忘记密码?"
android:textColor="#1598C4"
android:textSize="28dp"
android:onClick="to"
android:layout_marginTop="256dp" />
</FrameLayout>
因为我们只写fragment页面,所以我们就不写点击事件了。
免密登录Fragment布局(fragment_nopwd.xml)
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout 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=".fragment.NopwdFragment">
<androidx.cardview.widget.CardView
android:layout_width="680dp"
android:layout_height="90dp"
app:cardCornerRadius="12dp">
<TextView
android:layout_width="54dp"
android:layout_height="37dp"
android:text="+86"
android:textSize="28dp"
android:layout_marginLeft="40dp"
android:layout_marginTop="27dp" />
<View
android:layout_width="2dp"
android:layout_height="50dp"
android:background="#ECEFF1"
android:layout_marginLeft="134dp"
android:layout_marginTop="20dp" />
<EditText
android:id="@+id/et_phone_number"
android:layout_width="546dp"
android:layout_height="match_parent"
android:layout_marginLeft="174dp"
android:background="@null"
android:hint="请输入手机号码"
android:textSize="28dp"/>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:layout_width="680dp"
android:layout_height="90dp"
app:cardCornerRadius="12dp"
android:layout_marginTop="130dp">
<EditText
android:id="@+id/et_verify"
android:layout_width="500dp"
android:layout_height="match_parent"
android:layout_marginLeft="40dp"
android:background="@null"
android:hint="请输入验证码"
android:textSize="28dp"/>
<TextView
android:id="@+id/tv_get_verification_code"
android:layout_width="140dp"
android:layout_height="37dp"
android:layout_marginLeft="500dp"
android:layout_marginTop="26dp"
android:text="获取验证码"
android:textSize="28dp"
android:textColor="#038BB9" />
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:id="@+id/cv_check"
android:layout_width="32dp"
android:layout_height="32dp"
android:layout_marginTop="260dp"
app:cardCornerRadius="8dp"
app:cardBackgroundColor="#1598C4"
>
</androidx.cardview.widget.CardView>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal">
<TextView
android:layout_width="wrap_content"
android:layout_height="37dp"
android:text="我已阅读并同意"
android:layout_marginTop="256dp"
android:layout_marginLeft="48dp"
android:textSize="28dp" />
<TextView
android:id="@+id/tv_user_secret"
android:layout_width="wrap_content"
android:layout_height="37dp"
android:text="《用户隐私政策》"
android:layout_marginTop="256dp"
android:textSize="28dp"
android:textColor="#1598C4"/>
</LinearLayout>
</FrameLayout>
这样,我们就完成了两个fragment页面的ui设计。我们来看一下效果。
这样,我们的fragment切换页面就完成了。
热门推荐
冬季打卡“泼水成冰”,这份安全指南请收好!
“泼水成冰”背后的物理原理揭秘,小心别被烫伤哦!
中东四国经济转型提速:从石油依赖到多元发展
从《甄嬛传》看清朝发饰:8000万钿子背后的宫廷文化
低利率下“固收+”走红:稳健收益兼得的理财新选择
高蛋白纯牛奶选购指南:含量标准与品牌推荐
含乳饮料、植物奶、早餐奶:这些“假牛奶”别给孩子喝
全球AI专家齐聚巴黎,热议技术发展与应用创新
抗衰老从饮食开始:五类食物让肌肤保持年轻态
幼儿园安全计划合集多篇
血脂康胶囊:天然他汀降脂效果显著,安全性优于化学他汀
降脂效果媲他汀,血脂康胶囊30年临床应用安全有效
C51单片机开发--库函数
C++ 的常见应用领域
钻石投资:抗通胀的稀世珍宝还是流动性陷阱?
揭秘魔术背后的科学原理
资深大厨火夫教你炒猪肝:从选购到烹饪的完整指南
家常青红椒炒猪肝:选购、去腥、烹饪全攻略
南京市第一医院专家:黑茶对糖尿病仅有辅助作用
安化黑茶富含茶多糖,科学证实可辅助调节血糖
从主题设定到灯光效果:打造完美活动场地的实用指南
威虎山雪村:2米厚积雪与纯正东北风情的冰雪乐园
30年儿童哮喘患病率增加近10倍,日常每天都在吃的食物会增加风险
华为金牌客户经理培训秘籍:职业化素养与专业技能双管齐下
幼儿园管理升级:从安全到师资的全方位整改
华为客户经理Lucy:用谈判艺术创造商业价值
假睫毛使用全攻略:从选购到保养,这些技巧让你省时又省心
假睫毛重复使用秘籍:清洗步骤全解析
野餐垫清洗秘籍:告别草地尴尬
生地黄:中医里的滋阴高手