Spinner之下拉多选,监听ID后显示不同Frgment页面
本人安卓小白,公司最近项目需要用到不同的类型的用户注册,周末下午写完记录一下。
网上找了一堆没有适合自己的(或者说我没找到),写的比较基础,欢迎大家多多指导。
老规矩,先上效果图

网上在线合成的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页面的更多相关文章
- 9、JcomboBox下拉框事件监听
9.JcomboBox下拉框事件监听 JComboBox()的事件监听类ItemListener.其范例代码如下: import java.awt.*; import java.awt.event.* ...
- Django进入监听端口就自动打开指定页面,无需导航栏手动添加(Django六)
在我们进入监听端口时画面如下:而因为在urls.py中写过如下语句 我们在监听端口后加上/login就会跳转到login.html页面,如下图 那么如何一打开监听端口就可以走动跳转到login.htm ...
- js 监听后退事件及跳转页面
//直接跳转 window.location.href="b.html"; //返回上一级页面 window.history.back(-1); //返回下一级页面 window. ...
- React-Native传值方式之 :DeviceEventEmitter添加监听控制并传值到其他页面
在 native 开发中,我们可以使用广播实现事件的订阅和事件的触发,从而实现不在该页面但是可以调用该页面的方法. 在 React Native 中,我们也可以使用 DeviceEventEmitte ...
- vue 弹窗时 监听手机返回键关闭弹窗(页面不跳转)
[注]: popstate 事件 a.当活动历史记录条目更改时,将触发popstate事件. b.如果被激活的历史记录条目是通过对history.pushState()的调用创建的,或者受到对his ...
- bootstrap 之下拉多选
效果如图: 一.HTML代码 <label class="col-sm-1 control-label text-right" for="ds_host" ...
- Bootstrap 学习笔记8 下拉菜单滚动监听
代码部分: <nav class="navbar navbar-default"> <a href="#" class="navba ...
- element UI 下拉菜单滚动监听(vue指令)
直接看代码吧,可以直接粘贴此代码到你的编辑器中看效果. <template> <div class="page-component"> <div cl ...
- angular6 监听url查询参数变化刷新页面
快照snapshot取到的参数是组件第一次渲染时候的参数,当我们在页面中需要根据不同的url查询参数显示不同的内容时,快照就不能满足我们的需要了,这时候就要用ActivatedRoute服务的quer ...
随机推荐
- ORM 开发环境之利器:MVC 中间件 FreeSql.AdminLTE
前言 这是一篇纯技术干货的分享文章,FreeSql 已经基本完成 .NETCore 最方便的 ORM 使命,我们正在筹备生态的建立,比如 ABP 中如何使用 FreeSql 的实现,需要各种各样的扩展 ...
- C语言超级搞笑的代码,冷笑话我们程序员也会讲的啊!
百年修得足下点击本文 欢迎来到"C语言基础"专题,今天我们放松一天,不学习知识,来看下大千世界的千奇百怪的C语言代码,你见过那些? 1.关于随机数这回事 这个随机数有点意思哦. 2 ...
- Android 切换横竖屏
一个项目一般会自己先定义项目是横屏还是竖屏但是也有可以横屏和竖屏之间切换的activty. 切换横竖屏的方法: //判断当前屏幕方向if(getRequestedOrientation() == Ac ...
- python+selenium 自动化测试实战
一.前言: 之前的文章说过, 要写一篇自动化实战的文章, 这段时间比较忙再加回家过11一直没有更新博客,今天整理一下实战项目的代码共大家学习.(注:项目是针对我们公司内部系统的测试,只能内部网络访问, ...
- 「技巧」如何将Sketch改为深色模式
之前Sketch只能根据mac系统的外观设置变更皮肤.在更新了版本54之后,可以脱离操作系统,在自己的偏好设置中更改外观了. 准备 Sketch 54 更多工具:whose.design 第一步:打开 ...
- 对 Undefined 与 Null 的一些理解
Undefined 和 Null 是 Javascript 中两种特殊的原始数据类型(Primary Type),它们都只有一个值,分别对应 undefined 和 null ,这两种不同类型的值,既 ...
- ReactiveSwift源码解析(二) Bag容器的代码实现
今天博客我接着上篇博客的内容来,上篇博客我们详细的看了ReactiveSwift中的Observer已经Event的代码实现.接下来我们来看一下ReactiveSwift中的结构体Bag的实现.Bag ...
- echarts切换tab时,第一个图表显示,第二个图表不显示的解决办法
首先这种情况,我在网上看到了好多人问,确实也有正解,但是只是说出了其错误出现的原因,并没有给出解决方法. 我也是深受其害,所以呢,在这里记录一下,分享给还在困扰着的你们,迅速找出解决办法. 首先,我先 ...
- String字符串创建与存储机制
Java内存可以粗略的区分为堆内存(Heap)和栈内存(Stack),堆中存放的是对象实例,而栈中存放的则是方法调用过程中的局部变量或引用等. 在Java语言中,字符串的生命与初始化有如下两种方式: ...
- echarts中提示框的样式调整
第一种方法:利用tooltip 里面的配置项 默认就会有写显示 第二种方法:利用formattet回调函数 返回我们想要显示的信息 formatter : function (params) { va ...