(转)Android 仿订单出票效果 (附DEMO)

之前我下载了BaseAnimation 开源库(BaseAnimation是基于开源的APP,致力于收集各种动画效果)

BaseAnimation 转载的链接:http://blog.csdn.net/vipzjyno1/article/details/20622621

发现里面有个火车票的出票效果,发现可以优化下:

BaseAnimation内的仿出票效果

可是它的出的票的布局高度啥都是写死的,通过这个思路,我便想到要做个类似于数据是通过网络获取,高度不一定的listview的订单出票效果。

一.  思路:

1)叠在布局上层的是订单信息,而在下层的就是订单内菜单的详细条目,详细条目的布局是置于布局最底层,并且在订单信息相对位置下方,这里使用了FrameLayout来处 理 详细条目布局。

2)出票的详细条目列表采用了LISTVIEW,它的动画初始位置要通过计算LISTVIEW的总高度进行计算获取,之后通过TranslateAnimation 进行Animation动画。

3)采用线程来模拟网络获取延迟的效果。

二.  碰到解决的问题:

1)碰到一个问题,就是如果数据一多,超过了一屏幕,在动画过程中动画衔接效果就很差,并有可能出现断层效果。

解决:通过重写ListView, 计算高度,并且在ListView 外面嵌套了一层ScrollView,这样便可以解决这样的问题。

2) 如果在订单信息布局下方直接放置一个LISTVIEW的话,这样,动画时候,LISTVIEW就会盖在订单信息上方。

解决:LISTVIEW外层一定要嵌套一层布局,并且设定在订单信息下方,这样便不会产生上述问题。

3)由于订单底部

一开始就是出现的,并且在数据刷新后跟随LISTVIEW一起下滑。

解决:采用Listview的addFooterView(底部view)方法,把它添加到LISTVIEW底部,在开始添加完毕后就直接初始化让Listview.setAdapter(null);

这样便在开始底部就显示出来了。

4)如何去计算LISTVIEW的总高度

解决:本DEMO采用了2种方式,

第一种:鉴于订单中每个ITEM的布局都是固定的,于是在布局中设置ITEM的高度为固定值,之后乘以listAdapter.getCount() 加上分割线listView.getDividerHeight() 的总高度

第二种:如果每个ITEM的布局是高度是不一定的话,就会造成影响,便找了一些资料,使用了以下方法:

[java] view plaincopyprint?

  1. /** ListView 总高度 */
  2. public static int totalHeight = 0;
  3. public static void setListViewHeightBasedOnChildren(ListView listView) {
  4. ListAdapter listAdapter = listView.getAdapter();
  5. if (listAdapter == null) {
  6. return;
  7. }
  8. totalHeight = 0;
  9. // 由于ADD了个footer,所以总量减去1
  10. Log.d("listAdapter.getCount()", "" + listAdapter.getCount());
  11. for (int i = 0, len = listAdapter.getCount() - 1; i < len; i++) {
  12. View listItem = listAdapter.getView(i, null, listView);
  13. listItem.measure(0, 0);
  14. totalHeight += listItem.getMeasuredHeight();
  15. Log.d("getMeasuredHeight", "" + listItem.getMeasuredHeight());
  16. }
  17. totalHeight = totalHeight + (listView.getDividerHeight() * (listAdapter.getCount() - 1));
  18. }
	/** ListView 总高度 */
	public static int totalHeight = 0;

	public static void setListViewHeightBasedOnChildren(ListView listView) {
		ListAdapter listAdapter = listView.getAdapter();
		if (listAdapter == null) {
			return;
		}
		totalHeight = 0;
		// 由于ADD了个footer,所以总量减去1
		Log.d("listAdapter.getCount()", "" + listAdapter.getCount());
		for (int i = 0, len = listAdapter.getCount() - 1; i < len; i++) {
			View listItem = listAdapter.getView(i, null, listView);
			listItem.measure(0, 0);
			totalHeight += listItem.getMeasuredHeight();
			Log.d("getMeasuredHeight", "" + listItem.getMeasuredHeight());
		}
		totalHeight = totalHeight + (listView.getDividerHeight() * (listAdapter.getCount() - 1));
	}

计算得到了总高度。

5)实现动画效果

解决:

[java] view plaincopyprint?

  1. /**
  2. * 启动打印订单动画
  3. */
  4. rivate void startAnimation() {
  5. anim = new TranslateAnimation(0.0f, 0.0f, -totalHeight, 0);
  6. anim.setDuration(1000);
  7. anim.setFillAfter(true);
  8. anim.setAnimationListener(new AnimationListener() {
  9. @Override
  10. public void onAnimationStart(Animation animation) {
  11. // TODO Auto-generated method stub
  12. }
  13. @Override
  14. public void onAnimationRepeat(Animation animation) {
  15. // TODO Auto-generated method stub
  16. }
  17. @Override
  18. public void onAnimationEnd(Animation animation) {
  19. // TODO Auto-generated method stub
  20. cListview.clearAnimation();
  21. }
  22. });
  23. cListview.startAnimation(anim);
        /**
	 * 启动打印订单动画
	 */
	private void startAnimation() {
		anim = new TranslateAnimation(0.0f, 0.0f, -totalHeight, 0);
		anim.setDuration(1000);
		anim.setFillAfter(true);
		anim.setAnimationListener(new AnimationListener() {
			@Override
			public void onAnimationStart(Animation animation) {
				// TODO Auto-generated method stub
			}

			@Override
			public void onAnimationRepeat(Animation animation) {
				// TODO Auto-generated method stub
			}

			@Override
			public void onAnimationEnd(Animation animation) {
				// TODO Auto-generated method stub
				cListview.clearAnimation();
			}
		});
		cListview.startAnimation(anim);
	}

最后来看看动画效果把:

由于是第一次写博客,有不足之处望各位大神提出意见和建议,共同进步。谢谢!

转载请附上:http://blog.csdn.net/vipzjyno1/article/details/20623401

DEMO源码下载链接:

http://download.csdn.net/detail/vipzjyno1/7000355

时间: 2024-10-10 03:49:24

(转)Android 仿订单出票效果 (附DEMO)的相关文章

Android仿IOS回弹效果 ScrollView回弹 总结

Android仿IOS回弹效果  ScrollView回弹 总结 应项目中的需求  需要仿IOS 下拉回弹的效果 , 我在网上搜了很多 大多数都是拿scrollview 改吧改吧 试了一些  发现总有点小问题 下面的代码是我对大家发布的做了点小修改   觉得没太大问题 package com.example.myscrollview; import android.content.Context; import android.graphics.Rect; import android.util

Android:JNA实践(附Demo)

一.JNA和JNI的对比   1.JNI的调用流程 Android应用开发中要实现Java和C,C++层交互时,想必首先想到的是JNI,但是JNI的使用过程十分繁琐,需要自己再封装一层JNI接口进行转换(使用SUN规定的数据结构去替代C语言的数据结构),包名.函数名等都要匹配,难以阅读和更新. 如下图是通过JNI实现Java调用C层的方法流程:   2.什么是JNA?与JNI有什么差异? JNA(Java Native Access):建立在JNI之上的Java开源框架,SUN主导开发,用来调用

Android 仿QQ浏览器WebView,滑动隐藏显示ActionBar效果

Android 仿QQ浏览器,滑动隐藏显示ActionBar效果. 往上推,是一个ScrollView会将,actionbar以及内容往上推,当actionbar消失后,将滚动Webview的内容. 此效果是基于QuickReturnHeader源码,修改而来的,代码也不多,实现方法比较简单. 直接上demo:http://download.csdn.net/detail/xufeifandj/8388493 直接看效果图:

Android应用经典主界面框架之一:仿QQ (使用Fragment, 附源码)

最近反复研究日常经典必用的几个android app,从主界面带来的交互方式入手进行分析,我将其大致分为三类.今天记录第一种方式,即主界面下面有几个tab页,最上端是标题栏,tab页和tab页之间不是通过滑动切换的,而是通过点击切换tab页.早期这种架构一直是使用tabhost+activitygroup来使用,随着fragment的出现及google官方也大力推荐使用fragment,后者大有代替前者之势.本文也使用fragment进行搭建,标题中的"经典"指这种交互经典,非本文的代

让Android控件随着屏幕旋转自由转移至任何地方(附demo)

本文主要介绍Android ViewGroup/View的绘制流程,及常用的自定义ViewGroup的方法.在此基础上介绍动态控制View的位置的三种方法,并给出最佳的一种方法. 一.ViewGroup/View的绘制流程 简单的说一个View从无到有需要三个步骤,onMeasure.onLayout.onDraw,即测量大小.放置位置.绘制三个步骤.而ViewGroup的onMeasure.onLayout流程里,又会遍历每个孩子,并最终调到孩子的measure().layout()函数里.与

android仿网易云音乐引导页、仿书旗小说Flutter版、ViewPager切换、爆炸菜单、风扇叶片效果等源码

Android精选源码 复现网易云音乐引导页效果 高仿书旗小说 Flutter版,支持iOS.Android Android Srt和Ass字幕解析器 Material Design ViewPager切换变色美观效果 卡证识别 相机样式 Android炫酷爆炸效果的菜单源码 Android简洁优雅可点击的toast控件,仿手机百度 Android实现水平列表,其中的项目像风扇叶片一样移动效果 让你的RecyclerView秀出传送带效果,支持横向和纵向两种选... 一种流式布局的效果,很像我们

Android仿微信底部菜单栏+顶部菜单栏(附源码)

林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 本文要实现仿微信微信底部菜单栏+顶部菜单栏,采用ViewPage来做,每一个page对应一个XML,当手指在ViewPage左右滑动时,就相应显示不同的page(其实就是xml)并且同时改变底部菜单按钮的图片变暗或变亮,同时如果点击底部菜单按钮,左右滑动page(其实就是xml)并且改变相应按钮的亮度. 最终效果:源码免费下载 一.布局 1.顶部菜单布局,命名为top_layout.xml

android 仿ppt进入动画效果合集

EnterAnimation android 仿ppt进入动画效果合集, 百叶窗效果,擦除效果,盒状效果,阶梯效果,菱形效果,轮子效果,劈裂效果,棋盘效果, 切入效果,扇形展开效果,十字扩展效果,随机线条效果,向内溶解效果,圆形扩展效果, 适用于各种view和viewgroup,activity即用于页面根部viewgroup, 自定义viewgroup自动换行layout, 看效果图 Series of entrance animation effects just like ppt in A

ANDROID自定义视图——仿瀑布布局(附源码)

简介: 在自定义view的时候,其实很简单,只需要知道3步骤: 1.测量--onMeasure():决定View的大小 2.布局--onLayout():决定View在ViewGroup中的位置 3.绘制--onDraw():如何绘制这个View. 第3步的onDraw系统已经封装的很好了,基本不用我们来操心,只需要专注到1,2两个步骤就中好了. 第一步的测量,可以参考:(ANDROID自定义视图--onMeasure,MeasureSpec源码 流程 思路详解) 第二步的布局,可以参考:(AN