仿有道词典 ListView item飞入效果
来源:互联网 发布:linux ntp 时间不同步 编辑:程序博客网 时间:2024/06/16 18:12
最近在使用有道词典的单词本功能时,发现每次进去ListView item 都有一个 自右向左 飞入动画的效果,研究了一下给实现了。
这里用到了LayoutAnimationController 类,LayoutAnimationController用于为一个Layout里面的控件或者是Viewgroup的控件设置动画效果。
1.每一个控件都会有相同的动画效果2.这些动画效果在不同的时间现实出来
有两种方式可以实现:
1.下面以XML文件实现,先在res下新建anim文件夹,新建一个文件list_item_anim.xml
<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/accelerate_interpolator" > <translate android:fromXDelta="100%p" android:toXDelta="0" android:duration="200" /> </set>
然后新建一个文件layoutanimation.xml
<?xml version="1.0" encoding="utf-8"?><layoutAnimation xmlns:android="http://schemas.android.com/apk/res/android" android:animation="@anim/list_item_anim" android:animationOrder="normal" android:delay="0.5" />
在ListView中使用
<ListView android:id="@+id/lvMain" android:layout_width="match_parent" android:layout_height="match_parent" android:cacheColorHint="@android:color/transparent" android:layoutAnimation="@anim/layoutanimation"/>
2、代码实现
Animation animation = (Animation)AnimationUtils.loadAnimation(MainActivity.this, R.anim.list_item_anim); LayoutAnimationController controller = new LayoutAnimationController(animation); controller.setOrder(LayoutAnimationController.ORDER_NORMAL); controller.setDelay(0.5f);//注意这个地方是以秒为单位,是浮点型数据,所以要加fmListView.setLayoutAnimation(controller);
显示的顺序有三种可选:
LayoutAnimationController.ORDER_NORMAL; //顺序显示
LayoutAnimationController.ORDER_REVERSE;//反显示
LayoutAnimationController.ORDER_RANDOM//随机显示
二、实现有道词典 ListView item飞入效果
看了上面的介绍,大概你已经能知道如何去实现ListView item飞入效果,这里直接上代码了。
activity_main.xml
<RelativeLayout 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" tools:context=".MainActivity" > <ListView android:id="@+id/lvMain" android:layout_width="match_parent" android:layout_height="match_parent" android:cacheColorHint="@android:color/transparent"/></RelativeLayout>
MainActivity.java
package com.example.listexpanddemo;import java.util.ArrayList;import java.util.List;import android.app.Activity;import android.content.Context;import android.graphics.BitmapFactory;import android.os.Bundle;import android.util.DisplayMetrics;import android.util.Log;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.view.animation.Animation;import android.view.animation.AnimationUtils;import android.view.animation.LayoutAnimationController;import android.widget.AdapterView;import android.widget.AdapterView.OnItemClickListener;import android.widget.BaseAdapter;import android.widget.ImageView;import android.widget.ListView;import android.widget.TextView;import com.example.listexpanddemo.model.AppInfo;public class MainActivity extends Activity {private static final String TAG = "MainActivity";private ListView mListView;private CustomListAdapter mAdapter;private List<AppInfo> mList = new ArrayList<AppInfo>();private int mLcdWidth = 0;private float mDensity = 0;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);loadMobileConfig();buildAppData();mAdapter = new CustomListAdapter(this);mListView = (ListView) findViewById(R.id.lvMain);mListView.setAdapter(mAdapter);mListView.setOnItemClickListener(new OnItemClickListener() {@Overridepublic void onItemClick(AdapterView<?> parent, View view,int position, long id) {Log.e(TAG, "click position:" + position);}});Animation animation = (Animation)AnimationUtils.loadAnimation(MainActivity.this, R.anim.list_item_anim); LayoutAnimationController controller = new LayoutAnimationController(animation); controller.setOrder(LayoutAnimationController.ORDER_NORMAL); controller.setDelay(0.5f);//注意这个地方是以秒为单位,是浮点型数据,所以要加fmListView.setLayoutAnimation(controller);}/** * 加载手机屏幕的宽高 */private void loadMobileConfig() {DisplayMetrics dm = getResources().getDisplayMetrics();mLcdWidth = dm.widthPixels;mDensity = dm.density;Log.e(TAG, "mLcdWidth:" + mLcdWidth + " mDensity:" + mDensity);}/** * 初始化应用数据 */private void buildAppData() {for (int i = 0; i < 20; i++) {AppInfo ai = new AppInfo();ai.setAppIcon(BitmapFactory.decodeResource(getResources(),R.drawable.ic_launcher));ai.setAppName("应用Demo_" + i);ai.setAppVer("版本: " + (i % 10 + 1) + "." + (i % 8 + 2) + "."+ (i % 6 + 3));ai.setAppSize("大小: " + i * 10 + "MB");mList.add(ai);}}public class CustomListAdapter extends BaseAdapter {private LayoutInflater mInflater;public CustomListAdapter(Context context) {mInflater = LayoutInflater.from(context);}@Overridepublic int getCount() {return mList.size();}@Overridepublic Object getItem(int arg0) {return mList.get(arg0);}@Overridepublic long getItemId(int position) {return position;}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {if (getCount() == 0) {return null;}ViewHolder holder = null;if (convertView == null) {convertView = mInflater.inflate(R.layout.expand_item, null);holder = new ViewHolder();holder.ivImage = (ImageView) convertView.findViewById(R.id.ivIcon);holder.tvName = (TextView) convertView.findViewById(R.id.tvName);holder.tvVer = (TextView) convertView.findViewById(R.id.tvVer);holder.tvSize = (TextView) convertView.findViewById(R.id.tvSize);convertView.setTag(holder);} else {holder = (ViewHolder) convertView.getTag();}AppInfo ai = mList.get(position);holder.ivImage.setImageBitmap(ai.getAppIcon());holder.tvName.setText(ai.getAppName());holder.tvVer.setText(ai.getAppVer());holder.tvSize.setText(ai.getAppSize());return convertView;}}public static class ViewHolder {private ImageView ivImage;private TextView tvName;private TextView tvVer;private TextView tvSize;}}
expand_item.xml
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" android:padding="5dip"> <RelativeLayout android:layout_width="match_parent" android:layout_height="wrap_content"> <ImageView android:id="@+id/ivIcon" android:src="@drawable/ic_launcher" android:layout_width="wrap_content" android:layout_height="wrap_content" android:contentDescription="@string/image_desc"/> <LinearLayout android:id="@+id/appInfo" android:layout_toRightOf="@id/ivIcon" android:layout_marginLeft="5dip" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:id="@+id/tvName" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/name" android:textColor="#000000" android:textSize="16sp"/> <TextView android:id="@+id/tvVer" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/ver" android:textColor="#666666" android:textSize="13sp"/> <TextView android:id="@+id/tvSize" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/size" android:textColor="#666666" android:textSize="13sp"/> </LinearLayout> <Button android:id="@+id/btnClick" android:focusable="false" android:layout_width="80dip" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:layout_centerVertical="true" android:text="@string/mgr" android:textColor="#000000" android:textSize="16sp"/> </RelativeLayout> </LinearLayout>
飞入动画 list_item_anim.xml
<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/accelerate_interpolator" > <translate android:fromXDelta="100%p" android:toXDelta="0" android:duration="200" /> </set>
先这样了,源码有时间再上传
- 仿有道词典 ListView item飞入效果
- ListView底部item飞入动画效果
- 仿有道词典
- 实现ListView的item逐个飞入效果——LayoutAnimationController
- ListView的飞入效果
- 连接有道网页仿写有道词典
- 仿有道词典应用项目源码
- 仿淘宝购物车飞入效果
- ListView飞入加载item及滑动删除item
- ListView飞入加载item及滑动删除item
- ListView飞入加载item及滑动删除item
- ListView飞入加载item及滑动删除item
- ListView飞入加载item及滑动删除item
- ListView飞入加载item及滑动删除item
- ListView飞入加载item及滑动删除item
- Android ListView侧滑item,仿QQ删除效果
- ListView飞入加载item及滑动删除ite
- 有道词典
- linux下socket的分配算法
- linux(ubuntu) mysql 常见命令
- 精简版的MySQL制作步骤
- 将Oracle的数据倒入EXCEL中的方法
- 老中医顺口溜
- 仿有道词典 ListView item飞入效果
- svn报错,有冲突:Conflict discovered in ...
- Ext.Net 1.x_Ext.Net.GridPanel嵌套Checkbox
- android 导入外部工程没反应
- Linux hosts.allow与hosts.deny文件设置
- java工程的日志的配置和使用
- jsoncpp一个简单的解析json的库
- App退出程序
- 3 分钟搞定 Android Push