`
wangleyiang
  • 浏览: 224377 次
社区版块
存档分类
最新评论

Android ViewFlipper简单示例

阅读更多

ViewFlipper简单示例,详情请参考:http://developer.android.com/reference/android/widget/ViewFlipper.html

 

main.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:orientation="vertical" android:background="#ffffff">

    <ViewFlipper
        android:id="@+id/viewFlipper"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" >

        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent" android:gravity="center">

            <TextView
                android:id="@+id/textView1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="1"
                android:textSize="60dip" />
        </LinearLayout>

        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:gravity="center" >

            <TextView
                android:id="@+id/textView1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="2"
                android:textSize="60dip" />
        </LinearLayout>

        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:gravity="center" >

            <TextView
                android:id="@+id/textView1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="3"
                android:textSize="60dip" />
        </LinearLayout>

        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:gravity="center" >

            <TextView
                android:id="@+id/textView1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="4"
                android:textSize="60dip" />
        </LinearLayout>

        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:gravity="center" >

            <TextView
                android:id="@+id/textView1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="5"
                android:textSize="60dip" />
        </LinearLayout>
    </ViewFlipper>

    <Button
        android:id="@+id/left_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_margin="5dip"
        android:text="左" />

    <Button
        android:id="@+id/right_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_alignParentTop="true"
        android:layout_margin="5dip"
        android:text="右" />

</RelativeLayout>

 说明:

  • 使用RelativeLayout做父容器,添加按钮在ViewFlipper顶部;
  • ViewFlipper的每个子页面并列于该View内;
  • ViewFlipper的每个子页面显示一个TextView;

main.xml效果:



 main.xml布局结构:



 运行效果图:



 

 

 说明:

  1. 点击顶部按钮,可以完成页面切换;
  2. 点击底部按钮,可以实现页面切换;
  3. 滑动页面,可以实现页面的切换;

切换动画/res/anim/目录下的动画文件分别如下:

push_left_in.xml:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >

    <translate
        android:duration="500"
        android:fromXDelta="100%p"
        android:toXDelta="0" />

    <alpha
        android:duration="500"
        android:fromAlpha="0.1"
        android:toAlpha="1.0" />

</set>

 push_left_out.xml:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >

    <translate
        android:duration="500"
        android:fromXDelta="0"
        android:toXDelta="-100%p" />

    <alpha
        android:duration="500"
        android:fromAlpha="1.0"
        android:toAlpha="0.1" />

</set>

 push_right_in.xml:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >

    <translate
        android:duration="500"
        android:fromXDelta="-100%p"
        android:toXDelta="0" />

    <alpha
        android:duration="500"
        android:fromAlpha="0.1"
        android:toAlpha="1.0" />

</set>

 push_right_out.xml:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >

    <translate
        android:duration="500"
        android:fromXDelta="0"
        android:toXDelta="100%p" />

    <alpha
        android:duration="500"
        android:fromAlpha="1.0"
        android:toAlpha="0.1" />

</set>

主要代码:

import android.app.Activity;
import android.graphics.PixelFormat;
import android.os.Bundle;
import android.view.Gravity;
import android.view.MotionEvent;
import android.view.View;
import android.view.Window;
import android.view.WindowManager;
import android.view.View.OnClickListener;
import android.view.WindowManager.LayoutParams;
import android.widget.Button;
import android.widget.ViewFlipper;

public class MainActivity extends Activity implements OnClickListener {
	
	private WindowManager windowManager;
	
	private Button leftButton;
	private Button rightButton;
	
	private ViewFlipper viewFlipper;
	
	private float xDown;
	private float yDown;

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);

		getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
				WindowManager.LayoutParams.FLAG_FULLSCREEN);
		getWindow().requestFeature(Window.FEATURE_NO_TITLE);
		
		setContentView(R.layout.main);

		viewFlipper = (ViewFlipper) this.findViewById(R.id.viewFlipper);
		
		windowManager = (WindowManager) getApplicationContext().getSystemService("window");
		LayoutParams windowManagerParams = new WindowManager.LayoutParams();
		windowManagerParams.type = LayoutParams.TYPE_PHONE;
		windowManagerParams.format = PixelFormat.RGBA_8888;
		windowManagerParams.flags = LayoutParams.FLAG_NOT_TOUCH_MODAL
				| LayoutParams.FLAG_NOT_FOCUSABLE;
		windowManagerParams.x = 0;
		windowManagerParams.y = 0;
		windowManagerParams.width = WindowManager.LayoutParams.WRAP_CONTENT;
		windowManagerParams.height = WindowManager.LayoutParams.WRAP_CONTENT;
		
		leftButton = new Button(this);
		leftButton.setBackgroundResource(android.R.drawable.alert_light_frame);
		leftButton.setText("<");
		leftButton.setOnClickListener(this);
		windowManagerParams.gravity = Gravity.LEFT | Gravity.BOTTOM;
		windowManager.addView(leftButton, windowManagerParams);
		
		rightButton = new Button(this);
		rightButton.setBackgroundResource(android.R.drawable.alert_light_frame);
		rightButton.setText(">");
		rightButton.setOnClickListener(this);
		windowManagerParams.gravity = Gravity.RIGHT | Gravity.BOTTOM;
		windowManager.addView(rightButton, windowManagerParams);
		
		findViewById(R.id.left_button).setOnClickListener(this);
		findViewById(R.id.right_button).setOnClickListener(this);
		
	}

	private void showPrevious() {
		viewFlipper.setInAnimation(this, R.anim.push_left_in);
		viewFlipper.setOutAnimation(this, R.anim.push_left_out);
		viewFlipper.showPrevious();
	}

	private void showNext() {
		viewFlipper.setInAnimation(this, R.anim.push_right_in);
		viewFlipper.setOutAnimation(this, R.anim.push_right_out);
		viewFlipper.showNext();
	}

	@Override
	public boolean onTouchEvent(MotionEvent event) {
		switch (event.getAction()) {
		case MotionEvent.ACTION_DOWN:
			xDown = event.getX();
			yDown = event.getY();
			break;
		case MotionEvent.ACTION_MOVE:
			break;
		case MotionEvent.ACTION_UP:
			float dx = event.getX() - xDown;
			float dy = event.getY() - yDown;
			// 简单定义:当x方向变化量的绝对值大于y方向时,为水平方向滑动
			if (Math.abs(dx) > Math.abs(dy)) {
				// 水平方向变化量大于0时,为向右运动
				if (dx > 0) {
					showNext();
				}
				// 水平方向变化量小于0时,为向左运动
				else if (dx < 0) {
					showPrevious();
				}
			}
			break;
		}
		return true;
	}

	@Override
	protected void onStop() {
		super.onStop();
		windowManager.removeView(leftButton);
		windowManager.removeView(rightButton);
	}

	@Override
	public void onClick(View v) {
		if (v == leftButton) {
			showPrevious();
			return;
		}
		if (v == rightButton) {
			showNext();
			return;
		}
		switch (v.getId()) {
		case R.id.left_button:
			showPrevious();
			break;
		case R.id.right_button:
			showNext();
			break;
		default:
			break;
		}
	}
}

 说明:

  • 底部两个白色背景的按钮是通过WindowManager添加的,是系统级别的窗口,故需要添加对应的权限;
  • 添加<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />权限;
  • 通过viewFlipper.setInAnimation和viewFlipper.setOutAnimation方法设置动画效果;
  • 在onStop时,需要remove添加的系统级别的窗口,否则点击Home后,那两个系统级别的按钮还存在于桌面;
  • getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);请求全屏;
  • getWindow().requestFeature(Window.FEATURE_NO_TITLE);请求没有标题栏;

多说一句:就个人而言,不喜欢总是要各种权限的应用!除非操作需要,尽量不要随意添加权限!:)

 

 

 

 

  • 大小: 7 KB
  • 大小: 9.9 KB
  • 大小: 11.6 KB
  • 大小: 12.9 KB
  • 大小: 11.9 KB
分享到:
评论

相关推荐

    基于Matlab与Yalmip的多用户储能电站日前经济调度优化模型

    内容概要:本文详细介绍了利用Matlab及其Yalmip工具箱,结合Gurobi求解器,实现多用户(如工业园区内的多个工厂)储能电站的日前经济调度优化。主要内容涵盖模型建立、变量定义、目标函数设定、约束条件配置以及求解过程。文中通过具体的代码实例展示了如何根据分时电价和各用户的用电需求,制定最优的储能充放电计划,从而达到降低总体电费的目的。此外,还讨论了一些常见的实现细节和技术难点,如充放电效率的正确处理、初始荷电状态(SOC)的设定等。 适合人群:具有一定编程基础并对电力系统优化感兴趣的工程师或研究人员。 使用场景及目标:适用于希望减少电费支出并提高能源利用效率的企业或机构。通过学习本文提供的方法,能够掌握如何构建和求解类似的优化问题,进而应用于实际工程项目中。 其他说明:文中提到的技术手段不仅限于储能调度,还可以扩展到其他类型的资源分配问题。对于想要深入了解优化理论及其工程应用的人来说,这是一个很好的入门案例。

    OFDRserver.zip

    OFDR分布式传感python代码 包括激光器远程控制 数据解调 这个是一个基于 PC 端的 **OFDR 系统(Optical Frequency Domain Reflectometry,光学频域反射测量)服务端程序**,主要用于控制光纤分布式传感实验中的硬件设备、采集数据并进行初步处理。 以下是该仓库的主要内容与功能总结: --- ### **项目功能简介** 该项目是一个 PC 端服务程序,用于实现 **光纤频域反射测量(OFDR)系统** 的控制和数据采集功能。其核心用途包括: 1. **与实验设备通信**: - 控制波长扫描光源(如 Santec、Yokogawa 等); - 控制 DAQ(数据采集卡,如 Advantech PCIE-1840); - 通过串口与其他设备通信(如温控模块)。 2. **数据采集与同步控制**: - 启动光源扫描; - 通过触发机制同步采集数据; - 采样数据存储为二进制或文本格式,供后续分析。 3. **图形化界面(GUI)操作**: - 使用 Qt 框架实现基本的图形界面,支持设备配置、参数设置、采集控制等功能。 4. **数据处理与显示**: - 实现基本的 FFT 处理; - 可视化信号波形; - 有部分代码实现数据的预处理和拟合操作。 OFDR 光线分布式传感 光频域反射技术 python

    西门子S7-1200 PLC Modbus RTU控制步进电机的梯形图程序实现及调试技巧

    内容概要:本文详细介绍了使用西门子S7-1200 PLC及其485信号板通过Modbus RTU协议控制步进电机的方法。主要内容涵盖硬件配置、关键程序代码、数据处理方法以及常见的调试技巧。文中提供了具体的梯形图代码示例,如初始化Modbus主站、主站轮询、数据指针配置等,并针对实际应用中可能出现的问题给出了详细的解决办法,例如波特率和校验位的正确设置、数据传输时的字节交换处理、通信超时等问题。此外,还强调了硬件连接的重要性,如正确的485接线方式和终端电阻的使用。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是那些需要使用PLC进行设备控制并熟悉西门子博途软件平台的用户。 使用场景及目标:帮助读者掌握利用西门子S7-1200 PLC和Modbus RTU协议控制步进电机的具体实现步骤,提高系统的可靠性和稳定性。适用于工厂自动化生产线、机械设备控制等领域。 其他说明:文中提到的一些细节问题(如波特率的实际值、校验方式的选择等)对于初次接触此类项目的开发者来说非常有价值。同时,作者还分享了一些实用的小贴士,如使用抓包工具来辅助调试,这有助于加快项目进度并减少不必要的麻烦。

    3dmax插件A自动道路.ms

    3dmax插件

    ChromeSetup.exe

    gugeliulanqi

    121311-基于MATLAB的混沌序列图像加密程序.doc

    121311_基于MATLAB的混沌序列图像加密程序.doc

    3dmax插件026-摆瓦片.ms

    3dmax插件

    四相开关磁阻电机Maxwell+Simplorer联合仿真优化及波形分析

    内容概要:本文详细介绍了四相开关磁阻电机在Maxwell和Simplorer联合仿真中的优化技巧和波形分析方法。首先,在Maxwell中,绕组匝数设置避免使用整数,正确选择磁滞回线模型,确保材料定义无误。其次,在Simplorer中,精确设置PWM生成模块的角度区间触发逻辑,防止因不合理设置导致转矩抖动。文中还强调了联合仿真过程中需要重点关注的三个波形:相电流波形、转矩波形以及径向力波形,并提供了针对不同波形异常的具体解决方案。此外,文章分享了一些实用的仿真加速技巧,如调整仿真步长、手动设置气隙网格层数等。最后,通过实例展示了如何利用FFT分析转矩脉动,并提出了降低转矩脉动的有效措施。 适合人群:从事电机设计、电磁场仿真及相关领域的工程师和技术人员。 使用场景及目标:帮助用户掌握四相开关磁阻电机联合仿真的关键技术要点,提高仿真效率和准确性,减少实验成本,为实际产品开发提供理论支持和技术指导。 其他说明:文章不仅涵盖了详细的仿真步骤和技术细节,还包括了许多基于实践经验得出的小贴士,有助于读者更好地理解和应用相关知识。

    信捷PLC与触摸屏在伺服自立袋灌装旋盖设备中的自动化控制实现

    内容概要:本文详细介绍了基于信捷PLC和触摸屏的伺服自立袋灌装旋盖设备及其全自动转盘式整机程序实例。文章首先阐述了项目的背景与需求,强调了设备需要实现高效、精准的灌装和旋盖操作,并确保自动化运行。其次,详细描述了电气图的设计,涵盖PLC的输入输出连接、伺服驱动器与电机的连接、传感器的接入以及触摸屏与PLC的通讯线路等。然后,展示了信捷PLC程序的具体实现,包括梯形图语言编写的灌装量控制程序片段,解释了各个指令的功能和流程。接下来,讨论了触摸屏程序设计,描述了如何通过触摸屏进行参数设置和设备状态监控。最后,总结了整个系统的实现过程,强调了各个环节之间的紧密联系,确保设备的稳定、高效运行。 适合人群:从事自动化设备编程的技术人员,尤其是对PLC编程和触摸屏应用有一定基础的人群。 使用场景及目标:适用于需要开发或优化类似自动化设备的企业和技术团队,旨在提高设备的自动化程度和工作效率,减少人工干预,确保生产过程的稳定性和准确性。 其他说明:文中不仅提供了详细的程序代码和电路图,还分享了许多调试经验和实用技巧,有助于读者更好地理解和应用相关技术。

    蓝桥杯嵌入式全部各个模块程序(模块化编程-例程)

    模块化代码,多个工程

    1.6 技能提升:设计一份个人简历.rp

    1.6 技能提升:设计一份个人简历.rp

    VS2010旗舰版的VB.NET版本任意进制互相转换程序源代码QZQ.zip

    VS2010旗舰版的VB.NET版本任意进制互相转换程序源代码QZQ

    电力系统基于深度强化学习的微网储能系统控制策略研究:优化充放电降低购电成本(含详细可运行代码及解释)

    内容概要:本文深入研究了基于深度强化学习(DRL)的微网储能系统控制策略。首先介绍了微网系统的组成及其特性,重点探讨了光伏发电、储能系统和负荷系统的关键组件数学模型。接着详细描述了Simulink仿真设计实现,包括微网环境模拟类(MicrogridEnv)、双重深度Q网络(Double DQN)算法的实现以及训练过程。为了验证该方法的有效性,文章还进行了对比实验,分别测试了规则策略、传统优化方法和DDQN策略的表现。实验结果显示,DDQN策略在成本节约、SOC合规率等方面明显优于其他两种方法。最后,本文提出了创新点与贡献总结,包括仿真-学习一体化框架、改进的DRL算法以及多维度验证,并展望了后续研究方向如多时间尺度优化、多能源协同、不确定性处理等。 适用人群:从事电力系统、微网技术研究的专业人士,以及对深度强化学习应用于能源领域感兴趣的科研人员和工程师。 使用场景及目标:①掌握微网储能系统的基本构成与工作原理;②理解如何利用深度强化学习优化微网储能控制策略;③学习具体的算法实现细节,包括环境搭建、DDQN算法实现和训练流程;④对比不同控制策略的效果,评估DDQN策略的优势。 其他说明:本文不仅提供了理论分析和技术实现,还展示了详细的实验验证过程,通过具体的实验数据证明了所提方法的有效性。此外,文中提及的多种改进措施和技术细节对于实际工程项目具有重要的参考价值。阅读本文有助于读者全面了解微网储能控制领域的最新进展,为相关研究和技术开发提供有益的指导。

    NET_ORM框架_多数据库支持_复杂数据模型_自动数据库架_1744170807.zip

    NET_ORM框架_多数据库支持_复杂数据模型_自动数据库架_1744170807.zip

    3dmax插件CGOMax物体隔离显示.ms

    3dmax插件

    基于MATLAB/Simulink的V2G微电网24小时仿真:柴油机、风光发电与电动汽车协同调度

    内容概要:本文详细介绍了利用MATLAB/Simulink构建的一个24小时微电网仿真模型,涵盖了柴油机、光伏发电、风力发电和V2G(车辆到电网)四个主要组成部分。文中探讨了各个组件的工作原理及其相互之间的协作机制,特别是在应对功率波动时的表现。具体来说,柴油机作为基荷电源,通过精确的转速控制确保稳定的电力供应;光伏和风力发电则引入了随机性和不确定性因素,如天气突变和风速波动,增加了仿真的真实性;V2G部分展示了电动汽车如何根据电网需求进行智能充放电调度,尤其在应对突发情况时表现出色。此外,文章还提到了一些常见的仿真错误及解决方法,强调了参数设置的重要性。 适合人群:对微电网仿真、V2G技术和MATLAB/Simulink有一定兴趣的研究人员和技术爱好者。 使用场景及目标:适用于希望深入了解微电网内部运作机制的人士,尤其是那些想要研究不同类型能源如何协同工作的专业人士。通过本案例的学习,读者能够掌握如何构建复杂的电力系统仿真模型,并理解各种能量来源在实际应用中的行为特征。 其他说明:文中提供了大量具体的代码片段和参数配置建议,有助于读者更好地理解和复现实验结果。同时,作者分享了一些实践经验,如如何处理数据归一化、避免单位换算错误等,对于初学者非常有帮助。

    【嵌入式竞赛】蓝桥杯嵌入式客观题备考指南:知识点详解与答题技巧提升蓝桥杯嵌

    内容概要:本文详细介绍了蓝桥杯嵌入式比赛的背景、赛制、硬件平台及软件环境,并着重分析了嵌入式客观题的重要性、考试范围及重点内容。蓝桥杯嵌入式比赛采用封闭、限时的比赛方式,硬件平台为STM32G431RBT6,软件环境涉及STM32CubeMX和MDK535。客观题占总分的15%,虽占比不大但每分关键,能影响最终排名和选手心态。考试范围涵盖模电、数电、单片机及STM32数据手册,具体包括放大器、逻辑门电路、寄存器配置等内容。文中通过真题示例与解析,阐述了答题技巧,如先易后难、排除法、注意细节及利用数据手册。备考建议包括选择合适的教材、官方资料和在线课程,建立知识体系,理论与实践结合,总结归纳错题,并合理规划时间。; 适合人群:对嵌入式开发感兴趣并准备参加蓝桥杯嵌入式比赛的学生或爱好者。; 使用场景及目标:①帮助参赛者了解蓝桥杯嵌入式比赛的赛制和要求;②指导参赛者掌握客观题的答题技巧;③提供详细的备考建议,帮助参赛者系统学习和复习相关知识。; 其他说明:嵌入式开发是一门实践性很强的学科,本文强调理论与实践相结合的学习方法,鼓励参赛者通过实验加深理解。同时,合理的时间规划和错题总结有助于提升学习效果。最后,文章表达了对参赛者的祝福和支持,希望他们在比赛中取得优异成绩。

    生态环境物联网AI精细化监测监管系统.doc

    生态环境物联网AI精细化监测监管系统.doc

    WinCC报表零代码配置与优化:从日报到时段报表的全面解析

    内容概要:本文详细介绍了如何利用WinCC自带工具和控件实现零代码的报表生成功能,涵盖日报表、月报表及时段报表的配置方法。主要内容包括:使用WinCC Report Control控件生成日报表,通过VBS脚本处理累计值和差分计算,利用内置函数如DateSerial和TimeInfo处理特殊日期问题,以及通过动态配置和性能优化提高报表生成效率。此外,还提供了避坑指南,确保配置过程中少走弯路。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是对WinCC报表功能有一定了解并希望进一步掌握零代码配置技巧的人群。 使用场景及目标:适用于需要定期生成生产报表的企业,帮助工程师快速高效地完成报表配置,减少对SQL和数据库的依赖,降低配置难度,提高工作效率。 其他说明:文中提供的代码片段和配置步骤经过多个WinCC版本测试,确保兼容性和稳定性。同时,强调了配置完成后进行模拟测试的重要性,以确保报表的正确性和完整性。

    松下PLC FP-XH 4轴控制系统的直线插补实现与优化

    内容概要:本文详细介绍了基于松下PLC FP-XH系列的4轴控制系统开发与应用,特别是在两轴直线插补方面的实现方法及其优化措施。主要内容涵盖PLC程序开发、触摸屏界面设计、电气图纸绘制等方面。文中通过具体实例和代码片段展示了如何设置轴参数、实现直线插补、处理异常情况,并分享了多个实用技巧,如通过FPG指令配置脉冲输出模式、利用PMOV指令库进行插补轨迹分解、设计触摸屏上的高级参数设置等。此外,还强调了电气设计中的抗干扰措施和异常处理机制的重要性。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是对PLC编程和运动控制感兴趣的读者。 使用场景及目标:适用于需要开发和优化4轴控制系统的工程项目,旨在提高系统的稳定性和精度,减少故障发生率,提升生产效率。 其他说明:文章提供了丰富的实战经验和具体的代码示例,有助于读者快速掌握相关技术和解决问题的方法。同时,附带的运行视频和电气图纸也为理解和实施提供了直观的帮助。

Global site tag (gtag.js) - Google Analytics