• Android应用开发基础篇(11)-----ViewFlipper


    链接地址:http://www.cnblogs.com/lknlfy/archive/2012/03/01/2376067.html

    一、概述

          ViewFlipper这个部件是用来实现多页显示的,多页之间的显示一般通过手势的滑动来实现,比如处于Home界面时,可以通过滑动来显示另一页,有点像Activity之间的切换。下面的实现没有涉及到手势识别这个功能。

    二、要求

         掌握ViewFlipper的使用。

    三、实现

         新建工程MyFlipper,修改/res/layout/main.xml文件,在里面添加一个ViewFlipper,完整的main.xml文件如下:

    复制代码
     1 <?xml version="1.0" encoding="utf-8"?>
    2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3 android:layout_width="fill_parent"
    4 android:layout_height="fill_parent"
    5 android:orientation="vertical" >
    6
    7 <ViewFlipper
    8 android:id="@+id/viewflipper"
    9 android:layout_width="fill_parent"
    10 android:layout_height="fill_parent"
    11 >
    12
    13 </ViewFlipper>
    14
    15 </LinearLayout>
    复制代码

    在/res/layout下新建2个文件firstview.xml和secondview.xml。这两个文件的内容几乎一样,只是显示的内容不一样,firstview.xml如下:

    复制代码
     1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    2 android:layout_width="fill_parent"
    3 android:layout_height="fill_parent"
    4 android:orientation="vertical" >
    5
    6 <TextView
    7 android:layout_width="fill_parent"
    8 android:layout_height="wrap_content"
    9 android:text="这是第一个View"
    10 android:textColor="#FFFF0000"
    11 android:gravity="center_horizontal"
    12 android:textSize="20dip"
    13 />
    14
    15
    16 <Button
    17 android:id="@+id/firstbutton"
    18 android:layout_width="fill_parent"
    19 android:layout_height="wrap_content"
    20 android:text="显示第二个View"
    21 />
    22
    23
    24 </LinearLayout>
    复制代码

    secondview.xml如下:

    复制代码
     1 <?xml version="1.0" encoding="utf-8"?>
    2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3 android:layout_width="fill_parent"
    4 android:layout_height="fill_parent"
    5 android:orientation="vertical" >
    6
    7 <TextView
    8 android:layout_width="fill_parent"
    9 android:layout_height="wrap_content"
    10 android:text="这是第二个View"
    11 android:textColor="#FF0000FF"
    12 android:gravity="center_horizontal"
    13 android:textSize="20dip"
    14 />
    15
    16 <Button
    17 android:id="@+id/secondbutton"
    18 android:layout_width="fill_parent"
    19 android:layout_height="wrap_content"
    20 android:text="显示第一个View"
    21 />
    22
    23
    24 </LinearLayout>
    复制代码

    接着,修改MyFlipperActivity.java文件,主要是定义一个ViewFlipper对象,向它添加两个View,设置两个按钮的监听,在监听里显示前、后一个View。

    复制代码
     1 package com.nan.flipper;
    2
    3 import android.app.Activity;
    4 import android.os.Bundle;
    5 import android.view.LayoutInflater;
    6 import android.view.View;
    7 import android.widget.Button;
    8 import android.widget.ViewFlipper;
    9
    10 public class MyFlipperActivity extends Activity
    11 {
    12 private ViewFlipper mViewFlipper = null;
    13 private LayoutInflater mLayoutInflater = null;
    14
    15 private Button firstButton = null;
    16 private Button secondButton = null;
    17
    18 /** Called when the activity is first created. */
    19 @Override
    20 public void onCreate(Bundle savedInstanceState)
    21 {
    22 super.onCreate(savedInstanceState);
    23 setContentView(R.layout.main);
    24
    25 mViewFlipper = (ViewFlipper)this.findViewById(R.id.viewflipper);
    26
    27 mLayoutInflater = LayoutInflater.from(MyFlipperActivity.this);
    28 //将布局文件firstview.xml变为View对象
    29 View firstView = mLayoutInflater.inflate(R.layout.firstview, null);
    30 //将布局文件secondview.xml变为View对象
    31 View secondView = mLayoutInflater.inflate(R.layout.secondview, null);
    32 //添加View
    33 mViewFlipper.addView(firstView);
    34 //添加View
    35 mViewFlipper.addView(secondView);
    36
    37 firstButton = (Button)firstView.findViewById(R.id.firstbutton);
    38 //设置按钮监听
    39 firstButton.setOnClickListener(new View.OnClickListener()
    40 {
    41
    42 @Override
    43 public void onClick(View v)
    44 {
    45 // TODO Auto-generated method stub
    46 //显示后一个View
    47 mViewFlipper.showNext();
    48 }
    49 });
    50
    51 secondButton = (Button)secondView.findViewById(R.id.secondbutton);
    52 //设置按钮监听
    53 secondButton.setOnClickListener(new View.OnClickListener()
    54 {
    55
    56 @Override
    57 public void onClick(View v)
    58 {
    59 // TODO Auto-generated method stub
    60 //显示前一个View
    61 mViewFlipper.showPrevious();
    62 }
    63 });
    64
    65 }
    66
    67 }
    复制代码

    好了,运行该程序:

    点击一下“显示第二个View”按钮,效果如下:

    好了,完成。
          如果加上手势识别的话就可以通过滑动来切换页面了。

    如果一件事情你觉得难的完不成,你可以把它分为若干步,并不断寻找合适的方法。最后你发现你会是个超人。不要给自己找麻烦,但遇到麻烦绝不怕,更不要退缩。 电工查找电路不通点的最快方法是:分段诊断排除,快速定位。你有什么启示吗? 求知若饥,虚心若愚。 当你对一个事情掌控不足的时候,你需要做的就是“梳理”,并制定相应的规章制度,并使资源各司其职。
  • 相关阅读:
    SQL Server 2005高级程序设计
    SQL语言艺术
    无益的程序
    Django Ajax动态图形监控
    C/C++ Qt 基本文件读写方法
    Django 实现统计网站访问状态
    Python 实现 WebSocket 通信
    Django Admin后台定制简单监控页
    Django Ajax 实现Web命令行执行
    C/C++ Qt QThread 线程组件应用
  • 原文地址:https://www.cnblogs.com/wvqusrtg/p/5179046.html
Copyright © 2020-2023  润新知