ViewPage+Fragment的使用例子
2013年9月6日Fragment学习
Fragment这个东西,我到现在才接触到,之前没有用到过,关于Fragment这个东西在官方文档已经介绍了非常清楚了,我还特地转载了官方API的中文翻译,在这我就不浪费口舌了。简单来说,Fragment就是为满足大屏幕的而诞生的,手机屏幕小而平板屏幕就大了,屏幕一大就会产生更多的交互,这是很容易想到的,那么单纯的Activity就不能满足我们的需求了。
今天这个例子是自己做的一个小Demo,简单使用了Fragment,是跟ViewPage结合一起使用的。我想实现的效果是,左右滑动可以从一个Fragment到另一个Fragment的过渡。
看看效果图:
可以看到,两个fragment都可有控件的点击事件,如果是两个Activity我不知道怎么实现,可能会稍微麻烦一点。
简单的ViewPage布局:
/2013.09.05_ViewPage_Fragment_Demo/res/layout/activity_main.xml
- <?xml version="1.0" encoding="utf-8"?>
- <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="match_parent"
- android:layout_height="match_parent" >
- <android.support.v4.view.ViewPager
- android:id="@+id/viewpager"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:flipInterval="30"
- android:persistentDrawingCache="animation" />
- </RelativeLayout>
/2013.09.05_ViewPage_Fragment_Demo/res/layout/viewpager1.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:background="@drawable/guide_1" >
- <Button
- android:id="@+id/btn"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_alignParentBottom="true"
- android:layout_centerHorizontal="true"
- android:layout_marginBottom="54dp"
- android:background="@drawable/butten"
- />
- </RelativeLayout>
/2013.09.05_ViewPage_Fragment_Demo/res/layout/viewpager2.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:background="@drawable/guide_2" >
- <Button
- android:id="@+id/btn"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_alignParentBottom="true"
- android:layout_centerHorizontal="true"
- android:layout_marginBottom="54dp"
- android:background="@drawable/butten" />
- </RelativeLayout>
再来一个适配器:
/2013.09.05_ViewPage_Fragment_Demo/src/com/wwj/vf/adapter/FragAdapter.java
- package com.wwj.vf.adapter;
- import java.util.List;
- import android.support.v4.app.Fragment;
- import android.support.v4.app.FragmentManager;
- import android.support.v4.app.FragmentPagerAdapter;
- /**
- * FragmentPager适配器
- * @author wwj
- *
- */
- public class FragAdapter extends FragmentPagerAdapter{
- private List<Fragment> fragments;
- public FragAdapter(FragmentManager fm) {
- super(fm);
- }
- public FragAdapter(FragmentManager fm, List<Fragment> fragments) {
- super(fm);
- this.fragments = fragments;
- }
- @Override
- public Fragment getItem(int position) {
- return fragments.get(position);
- }
- @Override
- public int getCount() {
- return fragments.size();
- }
- }
两个自定义的Fragment
这里很简单,一张背景+一个按钮
/2013.09.05_ViewPage_Fragment_Demo/src/com/wwj/vf/ui/MyFragment1.java
- package com.wwj.vf.ui;
- import com.wwj.vf.R;
- import android.os.Bundle;
- import android.support.v4.app.Fragment;
- import android.view.LayoutInflater;
- import android.view.View;
- import android.view.View.OnClickListener;
- import android.view.ViewGroup;
- import android.widget.Button;
- import android.widget.Toast;
- /**
- * 第一个Fragment
- *
- * @author wwj
- *
- */
- public class MyFragment1 extends Fragment {
- private Button btn;
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- }
- @Override
- public View onCreateView(LayoutInflater inflater, ViewGroup container,
- Bundle savedInstanceState) {
- View view = inflater.inflate(R.layout.viewpager1, container, false);
- btn = (Button) view.findViewById(R.id.btn);
- btn.setOnClickListener(new OnClickListener() {
- @Override
- public void onClick(View v) {
- Toast.makeText(getActivity(), "你点我啦,好坏!!!", Toast.LENGTH_LONG).show();
- }
- });
- return view;
- }
- @Override
- public void onActivityCreated(Bundle savedInstanceState) {
- super.onActivityCreated(savedInstanceState);
- }
- @Override
- public void onPause() {
- super.onPause();
- }
- }
/2013.09.05_ViewPage_Fragment_Demo/src/com/wwj/vf/ui/MyFragment2.java
- package com.wwj.vf.ui;
- import android.os.Bundle;
- import android.support.v4.app.Fragment;
- import android.view.LayoutInflater;
- import android.view.View;
- import android.view.View.OnClickListener;
- import android.view.ViewGroup;
- import android.widget.Button;
- import android.widget.Toast;
- import com.wwj.vf.R;
- /**
- * 第2个Fragment
- *
- * @author wwj
- *
- */
- public class MyFragment2 extends Fragment {
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- }
- @Override
- public View onCreateView(LayoutInflater inflater, ViewGroup container,
- Bundle savedInstanceState) {
- View view = inflater.inflate(R.layout.viewpager2, container, false);
- view.findViewById(R.id.btn).setOnClickListener(new OnClickListener() {
- @Override
- public void onClick(View v) {
- Toast.makeText(getActivity(), "这个Fragment2哦,要注意了!!", Toast.LENGTH_SHORT).show();
- }
- });
- return view;
- }
- @Override
- public void onActivityCreated(Bundle savedInstanceState) {
- super.onActivityCreated(savedInstanceState);
- }
- @Override
- public void onPause() {
- super.onPause();
- }
- }
好啦,在Activity里添加两个Fragment
- package com.wwj.vf;
- import java.util.ArrayList;
- import java.util.List;
- import android.os.Bundle;
- import android.support.v4.app.Fragment;
- import android.support.v4.app.FragmentActivity;
- import android.support.v4.view.ViewPager;
- import com.wwj.vf.adapter.FragAdapter;
- import com.wwj.vf.ui.MyFragment1;
- import com.wwj.vf.ui.MyFragment2;
- /**
- * 主Activity,包含两个fragment
- *
- * @author wwj
- *
- */
- public class MainActivity extends FragmentActivity {
- private ViewPager vp;
- private FragAdapter adapter;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- vp = (ViewPager) findViewById(R.id.viewpager);
- List<Fragment> fragments = new ArrayList<Fragment>();
- fragments.add(new MyFragment1());
- fragments.add(new MyFragment2());
- adapter = new FragAdapter(getSupportFragmentManager(), fragments);
- vp.setAdapter(adapter);
- vp.setCurrentItem(0);
- }
- }
简单的ViewPage和Fragment的搭配使用就这样了
ViewPage+Fragment的使用例子相关推荐
- 【转】基于Android Fragment功能的例子
原文网址:http://blog.csdn.net/eyu8874521/article/details/8252216 通过最近空闲时候对Fragment的学习,尝试着写了一个小Demo,将在开发的 ...
- Android Fragment功能的例子
实现的功能很简单,也是最基本的,上下分别是两个Fragment,上面的Fragment中是一个listview,当点击item时,下面的Fragment显示对应的文字详细信息 具体的实现步骤如下: ① ...
- 基于Android Fragment功能的例子
通过最近空闲时候对Fragment的学习,尝试着写了一个小Demo,将在开发的时候能常用到的Fragment知识放在一起,写过了这个Demo对Android Fragment的了解更加深入了,以后做起 ...
- ViewPage最全解析
简单说明: ViewPager是android扩展包v4包中的类,直接继承了ViewGroup类,和LinearLayout等布局一样,都是一个容器,需要在里面添加我们想要显示的内容. 一.在xml中 ...
- android之Fragment(官网资料翻译)二
添加一个用户界面 fragment通常用来作为一个activity的用户界面的一部分,并将它的layout提供给activity.为了给一个fragment提供一 个layout,你必须实现 onCr ...
- activity中fragment 返回键不退出_优雅地处理加载中(loading),重试(retry)和无数据(empty)等...
LoadSir是一个高效易用,低碳环保,扩展性良好的加载反馈页管理框架,在加载网络或其他数据时候,根据需求切换状态页面,可添加自定义状态页面,如加载中,加载失败,无数据,网络超时,占位图,登录失效等常 ...
- android的fragment讲解
Fragment要点 Fragment作为Activity界面的一部分组成出现 可以在一个Activity中同时出现多个Fragment,并且,一个Fragment亦可在多个Activity中使用. ...
- 傲慢的上校的fragment讲解
Fragment要点 Fragment作为Activity界面的一部分组成出现 可以在一个Activity中同时出现多个Fragment,并且,一个Fragment亦可在多个Activity中使用. ...
- Android学习之 Fragment
[eoe特刊]Fragment- 特刊-eoe Fragment应用的介绍 - memegood123的专栏 - 博客频道 - CSDN.NET android之Fragment(官网资料翻译) - ...
最新文章
- 51单片机实现对24C02进行页写、顺序读取并显示验证
- 欢迎使用CSDN-markdown编辑器2018
- Matlab画图中的小技巧
- 鸿蒙2.0内测版手机版,不再遮遮掩掩,鸿蒙2.0测试版下月发布,用于手机内测
- jdk1.8 64位 32位免费下载
- Kafka图形管理界面Kafka-eagle安装配置详解
- QQ小程序开发之 一些前期准备:预约开发账号、下载安装开发者工具、创建qq小程序
- [转]AVALONDOCK 2.0入门指南第一部分
- [ESXI6.5集成realtek网卡的镜像
- 访问FTP站点下载文件,提示“当前的安全设置不允许从该位置下载文件”
- 重装系统ie无法解析服务器名称,教你解决ie浏览器打不开的方法
- 二级路由器的设置上网
- HTML标签的属性和特性
- djs-050微型计算机,合肥造DJS-050机—中国微机的摇篮
- 《黑客大曝光:移动应用安全揭秘及防护措施》一2.1 基础移动网络功能
- 智能反射面(IRS)在无线通信安全领域应用的论文复现
- html5 input与textarea标签及其属性
- mysql的rows大小超过8126_Row size too large ( 8126). Changing some columns to TEXT or BLOB
- laravel voyager 安装
- 简单理解vertical-align
热门文章
- 【错误记录】Kotlin 编译报错 ( Not nullable value required to call an ‘iterator()‘ method on for-loop range )
- 【鸿蒙 HarmonyOS】UI 组件 ( 文本输入框 TextField 组件 )
- 【Netty】零拷贝案例 ( transferTo | transferFrom )
- 【Android 应用开发】Activity 返回堆栈清除操作 ( 默认状态 | 清除返回堆栈配置 | 不清除返回堆栈配置 | 清除指定界面配置 )
- 【嵌入式开发】时钟初始化 ( 时钟相关概念 | 嵌入式时钟体系 | Lock Time | 分频参数设置 | CPU 异步模式设置 | APLL MPLL 时钟频率设置 )
- 【IOS 开发】Objective - C 面向对象高级特性 - 包装类 | 类处理 | 类别 | 扩展 | 协议 | 委托 | 异常处理 | 反射
- [C# 设计模式] Adapter - 适配器模式(两种)
- javascript之值传递与引用传递
- MongoDB应用篇(转)
- linux的 0号进程(idle进程) 和 1 号进程(init进程)