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切换页面就完成了。
热门推荐
家庭版烤羊腿~武吃方法
安全科普 | 遇到“雾先生”和“冰女士”,冬季行车该怎么应对?
冬季行车安全指南:如何应对"团雾"和"暗冰"两大隐形杀手
上海金茂大厦:上海的地标性建筑
二战胜利,各国要求日本赔偿540亿美元,为何实际支付不足零头?
摩托车过户需要什么手续和费用,房产过户流程
房屋征收不合理怎么办?一文详解维权途径和常见误区
房屋被征收怎么办?谈判要点、维权指南与财务处理全攻略
安卡血管炎的综合治疗方法
平行四边形的概念 是不是轴对称图形
宝宝几个月会坐这些事项需注意
紫菜含碘量有多少?医生专业解读
测骨龄需要多少钱
股票收益证明获取方法?
大学生和研究生如何培养创新思维
木管乐器都有哪些 十类木管乐器排行榜
研究确认华龙洞人是东亚地区向智人演化的最早古人类
植物补光灯 VS 普通灯:你知道哪一个更适合植物生长吗?
加班费仲裁需要什么证据
机械键盘连击故障,这么解决
体态矫正与身高增长的关系是什么
购车合同是否算做有效承诺?
AI云端部署与本地部署的优势对比
李子坝观景平台背后 还有这些设计美学
血糖高能吃咸鸭蛋吗
每天记录“三件好事”,提升幸福感!抑郁症患者不妨一试
“京”字的意思和解释,“京”字的成语和组词
【轻松学经穴】人体十四经之:认识大肠经
喝茶水影响钙吸收与补钙吗
喝鲜奶茶会形成草酸钙,导致肾结石?营养师来解答