本人安卓小白,公司最近项目需要用到不同的类型的用户注册,周末下午写完记录一下。

网上找了一堆没有适合自己的(或者说我没找到),写的比较基础,欢迎大家多多指导。

老规矩,先上效果图

网上在线合成的GIF图,哪位大神有比较好的合成图方法一定告诉我。

先说思路:

1.使用Spinner组件实现下拉列表;

2.监听Spinner的ID实现切换Fragment。

简单的activity_main.xml布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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=".SpinnerMainActivity"> <TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:text="账号注册"
android:textSize="20sp" /> <Spinner
android:id="@+id/spinnr"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:entries="@array/cars"
android:theme="@style/Spinner"> </Spinner> <LinearLayout
android:id="@+id/ll_fragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"> </LinearLayout> </LinearLayout>

Spinner 自定义的字体大小,颜色,在layout下创建的布局:personal_spinner.xml

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="left"
android:padding="5dip"
android:textColor="#000000"
android:textSize="20sp" />

我在这里使用的是Spinner 的静态加载,在valuse下创建arrays.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
<string-array name="cars">
<item>请选择您的账号注册类型</item>
<item>个人VIP用户注册</item>
<item>绿道司机用户注册</item>
</string-array>
</resources>

这里说一下默认加载数据的字体比较下,在valuse下的styles.xml加上自己需要的字体大小和颜色

<resources>

   ......
<style name="Spinner" parent="Widget.AppCompat.Light.DropDownItem.Spinner">
<item name="android:paddingStart">0dp</item>
<item name="android:paddingEnd">0dp</item>
<item name="android:textColor">@color/colorhei</item>
<item name="android:textSize">20sp</item>
</style>
</resources>

因为Spinner默认会自动加载,网上说了一些方法我试了一下,达不到我想要的效果,所以我直接写了3个Fragment,默认加载的第一个Fragment布局就写一个Textview,内容和第一个item一样,就做一个提示的效果,第二个和第三个Fragment布局才写完整的UI

上代码

这是第一个空的fragment布局

<?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="com.lvdaoproject.xialademo.FragmentDriver"> <TextView
android:layout_width="wrap_content"
android:layout_marginLeft="5dp"
android:layout_height="wrap_content"
android:text="请选择您的账号注册类型"
android:textSize="20sp" />
</LinearLayout>

第一个fragment 代码

package com.lvdaoproject.xialademo;

import android.app.Fragment;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup; public class FragmentNull extends Fragment {
public FragmentNull() { } @Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragmeng_null, container, false);
return view;
} @Override
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
} }

第二个第三个fragment就是布局根据自己的需要写了而已,就不一一粘贴了。

下面粘贴MainActivity代码

package com.lvdaoproject.xialademo;

import android.app.FragmentManager;
import android.app.FragmentTransaction;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.view.Window;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.LinearLayout;
import android.widget.Spinner; public class SpinnerMainActivity extends AppCompatActivity implements AdapterView.OnItemSelectedListener { private Spinner spinner;
private ArrayAdapter adapter;
private LinearLayout ll_fragment;
private FragmentDriver fragmentDriver;
private FragmentPersonVip fragmentPersonVip;
private FragmentNull fragmentNull; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
supportRequestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.activity_main); init();
} private void init() {
spinner = findViewById(R.id.spinnr);
ll_fragment = findViewById(R.id.ll_fragment); //设置ArrayAdapter内置的item样式-这里是自定义显示样式
adapter = ArrayAdapter.createFromResource(SpinnerMainActivity.this, R.array.cars, R.layout.personal_spinner); //这里设置的是Spinner的样式
adapter.setDropDownViewResource(android.R.layout.simple_spinner_item); //设置Adapter了
spinner.setAdapter(adapter); //监听Spinner的操作
spinner.setOnItemSelectedListener((AdapterView.OnItemSelectedListener) this);
} @Override
//选取时候的操作
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
if (id == 0) {
setFragmentNull();
}
if (id == 1) {
setmFragmentPersonVip();
}
if (id == 2) { setmFragmentDriver();
}
} @Override
//没被选取时的操作
public void onNothingSelected(AdapterView<?> parent) { } private void setFragmentNull() {
//判断fragmentMan是否为空,无则创建fragment对象
if (fragmentNull == null) {
fragmentNull = new FragmentNull();
}
//创建FragmentManager对象
FragmentManager manager = getFragmentManager();
//创建FragmentTransaction事务对象
FragmentTransaction fragmentTransaction = manager.beginTransaction();
//使用replace(将要替换位置的i的,替换的页面)方法实现页面的替换
fragmentTransaction.replace(R.id.ll_fragment, fragmentNull);
//提交事务
fragmentTransaction.commit();
} private void setmFragmentDriver() {
//判断fragmentMan是否为空,无则创建fragment对象
if (fragmentDriver == null) {
fragmentDriver = new FragmentDriver();
}
//创建FragmentManager对象
FragmentManager manager = getFragmentManager();
//创建FragmentTransaction事务对象
FragmentTransaction fragmentTransaction = manager.beginTransaction();
//使用replace(将要替换位置的i的,替换的页面)方法实现页面的替换
fragmentTransaction.replace(R.id.ll_fragment, fragmentDriver);
//提交事务
fragmentTransaction.commit();
} private void setmFragmentPersonVip() {
//判断fragmentMan是否为空,无则创建fragment对象
if (fragmentPersonVip == null) {
fragmentPersonVip = new FragmentPersonVip();
}
//创建FragmentManager对象
FragmentManager manager = getFragmentManager();
//创建FragmentTransaction事务对象
FragmentTransaction fragmentTransaction = manager.beginTransaction();
//使用replace(将要替换位置的i的,替换的页面)方法实现页面的替换
fragmentTransaction.replace(R.id.ll_fragment, fragmentPersonVip);
//提交事务
fragmentTransaction.commit();
}
}

在这里补充一下,Fragment我本来导的是v4的包,结果

 //使用replace(将要替换位置的i的,替换的页面)方法实现页面的替换
fragmentTransaction.replace(R.id.ll_fragment, fragmentPersonVip);

这一行第二个参数报错,也就是"fragmentPersonVip"这个小子

后来我把Fragment 的包换成import android.app.Fragment;就好了

好了,就写这么多,刚刚开始写博客,写得不好的请大家多多指教,谢谢!

												

Spinner之下拉多选,监听ID后显示不同Frgment页面的更多相关文章

  1. 9、JcomboBox下拉框事件监听

    9.JcomboBox下拉框事件监听 JComboBox()的事件监听类ItemListener.其范例代码如下: import java.awt.*; import java.awt.event.* ...

  2. Django进入监听端口就自动打开指定页面,无需导航栏手动添加(Django六)

    在我们进入监听端口时画面如下:而因为在urls.py中写过如下语句 我们在监听端口后加上/login就会跳转到login.html页面,如下图 那么如何一打开监听端口就可以走动跳转到login.htm ...

  3. js 监听后退事件及跳转页面

    //直接跳转 window.location.href="b.html"; //返回上一级页面 window.history.back(-1); //返回下一级页面 window. ...

  4. React-Native传值方式之 :DeviceEventEmitter添加监听控制并传值到其他页面

    在 native 开发中,我们可以使用广播实现事件的订阅和事件的触发,从而实现不在该页面但是可以调用该页面的方法. 在 React Native 中,我们也可以使用 DeviceEventEmitte ...

  5. vue 弹窗时 监听手机返回键关闭弹窗(页面不跳转)

    [注]:  popstate 事件 a.当活动历史记录条目更改时,将触发popstate事件. b.如果被激活的历史记录条目是通过对history.pushState()的调用创建的,或者受到对his ...

  6. bootstrap 之下拉多选

    效果如图: 一.HTML代码 <label class="col-sm-1 control-label text-right" for="ds_host" ...

  7. Bootstrap 学习笔记8 下拉菜单滚动监听

    代码部分: <nav class="navbar navbar-default"> <a href="#" class="navba ...

  8. element UI 下拉菜单滚动监听(vue指令)

    直接看代码吧,可以直接粘贴此代码到你的编辑器中看效果. <template> <div class="page-component"> <div cl ...

  9. angular6 监听url查询参数变化刷新页面

    快照snapshot取到的参数是组件第一次渲染时候的参数,当我们在页面中需要根据不同的url查询参数显示不同的内容时,快照就不能满足我们的需要了,这时候就要用ActivatedRoute服务的quer ...

随机推荐

  1. 10 年三线小城 IT 开发的感悟

    一贯都是写技术博客,从来没写过感悟类文章,因为文笔不好.今天看到了大飞的一篇文章,<技术人,请不要封闭自己>,真的感触太深了. 一 先说说我自己,我并非科班出身,大学毕业后一直没找到好的工 ...

  2. spring源码 — 四、MVC

    spring mvc是怎么实现的?为什么我们只需要在方法上写一个注解,就可以通过http访问这个接口?下面我们分3部分来解答这两个问题 注意:本文是基于spring4.3.2的 spring mvc整 ...

  3. C#-Xamarin利用ZXing.Net.Mobile进行扫码

    前言 很多人觉得Xamarin的开源少,没法用来开发项目. 但,实际上Xamarin已经有很多开源代码了:只要不是特别特殊的项目,基本上是都可以满足开发. 下面我们来看一下Xamarin中利用开源代码 ...

  4. bat脚本以管理员身份运行时,目录没有定位到当前目录问题的解决方法

    我们时常使用bat脚本去处理一些事情,有事bat中的命令需要以管理员的身份运行,但是运行后文件的目录自动定位到了C:\Windows\system32下,而不再脚本所在的目录下. 这是我的文件目录,W ...

  5. 部署远程jupyter

    1.直接执行 pip3 install jupyter 2.无法执行jupyter notebook后报错 “jupyter:command not found” 3.找到安装的位置,一般都在pyth ...

  6. Vue2.x源码学习笔记-Vue源码调试

    如果我们不用单文件组件开发,一般直接<script src="dist/vue.js">引入开发版vue.js这种情况下debug也是很方便的,只不过vue.js文件代 ...

  7. LOJ #6050. 「雅礼集训 2017 Day11」TRI

    完全不会的数学神题,正解留着以后填坑 将一个口胡的部分分做法,我们考虑计算格点多边形(包括三角形)面积的皮克公式: \[S=a+\frac{1}{2}b-1\text({a为图形内部节点个数,b为边界 ...

  8. [AI开发]将深度学习技术应用到实际项目

    本文介绍如何将基于深度学习的目标检测算法应用到具体的项目开发中,体现深度学习技术在实际生产中的价值,算是AI算法的一个落地实现.本文算法部分可以参见前面几篇博客: [AI开发]Python+Tenso ...

  9. 使用 docker-compose 快速安装Jenkins

    本文分享在 docker 环境中,使用 docker-compose.yml 快速安装 Jenkins,以及使用主机中的 docker 打包推送镜像到阿里云 博客园的第100篇文章达成,2019的第一 ...

  10. 面向对象(__str__和__repr__方法)

    #Author : Kelvin #Date : 2019/1/21 16:19 class App: def __init__(self,name): self.name=name # def __ ...