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切换页面就完成了。
热门推荐
Steam游戏评测 No.29《刺客信条:英灵殿》
提高代码调试效率和准确性的五大方法
晚上洗头真的会导致头痛吗?这些注意事项请收好
WiFi 6技术大揭秘:为何它是无线网络的新宠儿?
买房预算要考虑的六大关键点
合同自愈原则与效力的法律解析
散打综合解析:从传统武术到现代竞技
当代运动与艺术潮流散打和击剑的技术与训练
绿豆粥对减肥有帮助吗
数据库技术深度解析与未来趋势展望
法医重新鉴定的程序及法律依据
期货交易风险管理指南:从止损到心态控制的全方位策略
期货市场分析全攻略:三个维度帮你洞悉市场走势
《中国古代姓氏与避讳起源》:姓氏到底是“姓”还是“氏”?
这样的传统文化活动“next level”了,在上海名寺逛沉浸式诗会
厕所清理就地处置
申请韩国大学的美术专业要准备哪些材料
韩国艺术类大学TOP5院校及专业设置详解
床钢架好还是木架好?如何选择更适合的床架
床钢架好还是木架好?如何选择更适合的床架
平菇用不用开水焯一下
物联网NB水表是什么?什么叫物联网NB水表?
股票短线交易策略详解:从技术分析到交易平台
预防白色衣物泛黄指南:让它们始终洁白如新
福建省消防救援总队消防行业职业技能鉴定站厦门分站接受报名的公告
高位截瘫14年,“轮椅女孩”易懿从未被困在轮椅里
少儿舞蹈演出准备工作
想靠素食减重?掌握5大原则避开4大热量地雷
心肺功能体检项目大揭秘 如何通过检测预防心肺疾病风险
揭秘印度世袭的达利特徒手“掏粪人”:4个学位的硕士生也得继承