自己定义控件三部曲之动画篇(十三)——实现ListView Item进入动画
前言:宝剑锋从磨砺出,梅花香自苦寒来
相关文章:
《Android自己定义控件三部曲文章索引》: http://blog.csdn.net/harvic880925/article/details/50995268
前面两篇我们解说了使用layoutAnimation和LayoutTransition实现ViewGroup中Item载入动画的方法。但他们都各自存在问题:
layoutAnimation尽管是API 1中就已经引入,但仅仅能在动画初次创建时才干使用指定动画。
控件创建以后,再往ViewGroup里加Item就不会再有动画。这显然是不合适的!
LayoutTransition能够实现不管何时往ViewGroup中加入控件都能够给当中控件使用动画。但最大的问题是,它的API等级是11。
并且也没有兼容包可供我们使用这个函数。
这样问题就来了,假设我们想在兼容API 8以上的机型。完毕ListView中各个Item进入时都加入动画,这要怎么来做呢?
今天我们要完毕的效果图例如以下:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />
从效果图中能够看到,当每一个Item进入的时候。都加入了动画。
前面我们说了layoutAnimation和LayoutTransition所存在的问题。那抛开这两个函数,我们要怎样实现Item进入动画呢?
别忘了。ListView在得到每一个Item时会调用BaseAdapter的getView方法。getView中每一个convertView就是当前要显示的Item所相应的View。所以我们直接对convertView加入动画不就好了。
上面的原理理解起来并不难。以下我们就看看怎样实现的吧。
一、搭框架
这部分,我们主要是先搭出来要实现的框架,把ListView填充起来。效果例如以下:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />
这里实现的效果就是把listview填充起来,总共用了九张图片。listview列表循环显示这九张图片,但我在每一个图片上显示了当前item所在的位置。
好了,以下就来看代码吧
1、item布局(item_layout.xml)
我们先来看看listview的Item是怎么布局的:
<?xml version="1.0" encoding="utf-8"? >
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/img"
android:layout_width="fill_parent"
android:layout_height="250dp"
android:scaleType="centerCrop"
android:layout_margin="5dp"
android:layout_gravity="center"/> <TextView
android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="20dp"
android:layout_gravity="center"/> </FrameLayout>
代码非常好理解,从效果图中也能够看出。底部一个imageview,中间一个文字来表示当前item所在的位置。
2、ListAdapter
这里就是ListView的Adapter的代码位置了,完整的代码例如以下,然后再细讲:
public class ListAdapter extends BaseAdapter {
private List<Drawable> mDrawableList = new ArrayList<>();
private int mLength = 0;
private LayoutInflater mInflater;
private Context mContext;
private ListView mListView; public ListAdapter(Context context, ListView listView, List<Drawable> drawables, int length) {
mDrawableList.addAll(drawables);
mLength = length;
mInflater = LayoutInflater.from(context);
mContext = context;
mListView = listView;
} @Override
public int getCount() {
return mLength;
} @Override
public Object getItem(int position) {
return mDrawableList.get(position % mDrawableList.size());
} @Override
public long getItemId(int position) {
return position;
} @Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null; if (convertView == null) { holder = new ViewHolder();
convertView = mInflater.inflate(R.layout.item_layout, null);
holder.mImageView = (ImageView) convertView.findViewById(R.id.img);
holder.mTextView = (TextView) convertView.findViewById(R.id.text); } else {
holder = (ViewHolder) convertView.getTag();
} convertView.setTag(holder); holder.mImageView.setImageDrawable(mDrawableList.get(position % mDrawableList.size()));
holder.mTextView.setText(position+""); return convertView;
} public class ViewHolder {
public ImageView mImageView;
public TextView mTextView;
}
}
首先是构造函数:
public ListAdapter(Context context, ListView listView, List<Drawable> drawables, int length) {
mDrawableList.addAll(drawables);
mLength = length;
mInflater = LayoutInflater.from(context);
mContext = context;
mListView = listView;
}
首先是传进来的几个參数,List<Drawable> drawables是listview要循环显示的图片的Drawable对象列表,length表示当前listview要显示多少行。可能有些同学会注意到,我们还把ListView对象给传进来了,然后在上面的代码中并没实用到,当中把listview封装进Adapter是一个好习惯,由于我们可能会在Adapter中监听listview的状态从而改变item的显示情况。我们这里眼下还没实用到Listview
然后是getItem函数:
@Override
public Object getItem(int position) {
return mDrawableList.get(position % mDrawableList.size());
}
我们知道本身的BaseAdapter并没有使用getItem(int position)函数,重写这个函数是为了让我们在BaseAdapter实例中。能够通过getItem来获取我们想要的实例(相似以下这样):
ListView listView = (ListView)findViewById(R.id.list);
final ListAdapter adapter = new ListAdapter(this,listView,drawables,300);
listView.setAdapter(adapter);
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<? > parent, View view, int position, long id) {
//关键在这里哦
Drawable drawable = (Drawable) adapter.getItem(position);
}
});
这里我们将当前位置所相应的图片Drawable传过去:
public Object getItem(int position) {
return mDrawableList.get(position % mDrawableList.size());
}
大家可能会疑问:为什么要用position % mDrawableList.size()来得到当前图片在图片列表中的索引?由于我们是循环显示的图片的,比方我们总共同拥有九张图片,那当前是第12个item时,显示的应当是第3张图了,position的值为12(由于Adapter的position是从0開始的)。所以12%9 = 3。这就对上了。理解不了的同学,多拿几个数来算算,比方当显示到第15张时,position是多少。相应的图片应该是哪一张呢?
最后getView()函数
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null; if (convertView == null) { holder = new ViewHolder();
convertView = mInflater.inflate(R.layout.item_layout, null);
holder.mImageView = (ImageView) convertView.findViewById(R.id.img);
holder.mTextView = (TextView) convertView.findViewById(R.id.text);
} else {
holder = (ViewHolder) convertView.getTag();
} convertView.setTag(holder); holder.mImageView.setImageDrawable(mDrawableList.get(position % mDrawableList.size()));
holder.mTextView.setText(position+""); return convertView;
}
这段代码就不用我讲了吧,就是主要的getView使用方法。假设大家不理解为什么要利用 convertView.setTag(holder);的方式来反复使用convertView,能够參考这篇文章《BaseAdapter——convertView回收机制与动态控件响应》
在理解了convertview回收机制以后。这里最难的地方应该就是赋值的位置了:
holder.mImageView.setImageDrawable(mDrawableList.get(position % mDrawableList.size()));
holder.mTextView.setText(position+"");
依据位置找到图片的drawable我们上面已经讲过了,这也就没什么难度了,就不再细讲了。
3、主布局(main.xml)
主布局非常easy,就仅仅有一个ListView控件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="#ffffff"> <ListView
android:id="@+id/list"
android:layout_width="fill_parent"
android:layout_height="fill_parent"/>
</LinearLayout>
4、MyActivity.java
最后是在MyActivity中构造ListAdapter并设置进listview的过程了:
public class MyActivity extends Activity { @Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main); List<Drawable> drawables = new ArrayList<>();
drawables.add(getResources().getDrawable(R.drawable.pic1));
drawables.add(getResources().getDrawable(R.drawable.pic2));
drawables.add(getResources().getDrawable(R.drawable.pic3));
drawables.add(getResources().getDrawable(R.drawable.pic4));
drawables.add(getResources().getDrawable(R.drawable.pic5));
drawables.add(getResources().getDrawable(R.drawable.pic6));
drawables.add(getResources().getDrawable(R.drawable.pic7));
drawables.add(getResources().getDrawable(R.drawable.pic8));
drawables.add(getResources().getDrawable(R.drawable.pic9)); ListView listView = (ListView)findViewById(R.id.list);
ListAdapter adapter = new ListAdapter(this,listView,drawables,300);
listView.setAdapter(adapter);
}
}
这段代码非常easy了,就是先构造图片所相应的Drawable列表,然后构造ListAdapter实例。最后设置进Listview将其显示出来。没什么难度。也没什么好讲了。
到这里,我们listview就构造完毕了。以下就看怎样向当中的item加入动画的环节了。
二、Item加入动画——初步实现
1、动画文件(bottom_in_anim.xml)
先定义从底部进入的动画:
<? xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:duration="1000">
<translate android:fromYDelta="100%" android:toYDelta="0"/>
<alpha android:fromAlpha="0" android:toAlpha="1"/>
</set>
这段动画不难理解,效果是从底部进入,alpha值从0变到1;
2、在Adapter中加入动画代码
首先。我们在ListAdapter中初始化的时候。载入动画:
public class ListAdapter extends BaseAdapter {
…………
private Animation animation; public ListAdapter(Context context, ListView listView, List<Drawable> drawables, int length) {
…………
animation = AnimationUtils.loadAnimation(mContext,R.anim.bottom_in_anim);
}
…………
}
然后在getView的时候为每一个convertView加入上动画
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null; if (convertView == null) { holder = new ViewHolder();
convertView = mInflater.inflate(R.layout.item_layout, null);
holder.mImageView = (ImageView) convertView.findViewById(R.id.img);
holder.mTextView = (TextView) convertView.findViewById(R.id.text);
} else {
holder = (ViewHolder) convertView.getTag();
}
convertView.startAnimation(animation);
convertView.setTag(holder); holder.mImageView.setImageDrawable(mDrawableList.get(position % mDrawableList.size()));
holder.mTextView.setText(position+""); return convertView;
}
让一个view開始动画非常easy,仅仅须要调用convertView.startAnimation(animation);就可以;这样就能够实如今构造item的时候就開始动画
ListAdapter完整代码例如以下
public class ListAdapter extends BaseAdapter {
private List<Drawable> mDrawableList = new ArrayList<>();
private int mLength = 0;
private LayoutInflater mInflater;
private Context mContext;
private ListView mListView;
private Animation animation; public ListAdapter(Context context, ListView listView, List<Drawable> drawables, int length) {
mDrawableList.addAll(drawables);
mLength = length;
mInflater = LayoutInflater.from(context);
mContext = context;
mListView = listView;
animation = AnimationUtils.loadAnimation(mContext,R.anim.bottom_in_anim);
} @Override
public int getCount() {
return mLength;
} @Override
public Object getItem(int position) {
return mDrawableList.get(position % mDrawableList.size());
} @Override
public long getItemId(int position) {
return position;
} @Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null; if (convertView == null) { holder = new ViewHolder();
convertView = mInflater.inflate(R.layout.item_layout, null);
holder.mImageView = (ImageView) convertView.findViewById(R.id.img);
holder.mTextView = (TextView) convertView.findViewById(R.id.text);
} else {
holder = (ViewHolder) convertView.getTag();
}
convertView.startAnimation(animation);
convertView.setTag(holder); holder.mImageView.setImageDrawable(mDrawableList.get(position % mDrawableList.size()));
holder.mTextView.setText(position+""); return convertView;
} public class ViewHolder {
public ImageView mImageView;
public TextView mTextView;
}
}
效果图为:
从效果图中能够看出,我们初步实现了在item生成的时候加入进入动画
三、优化
上面尽管攻克了进入时加入动画的问题,但细致的同学能够看出,在这个效果图中还存在几个问题。可能上面的效果图还看不清楚详细存在的问题
1、假设上拉的时候。一下上拉了几个item,那些要显示的item会一起从底部出现
2、在下拉的时候。上部出现的item也会应用上动画
首先,解决第二个问题比較简单,仅仅须要推断当前手指是上滑还上下滑就能够了,仅仅有当手指向上滑的时候,才对底部出现的item加入上入场动画,其他时间不加入动画就可以
第一个问题事实上也比較easy解决。我们能够通过listview.getChildCount()得到当前ListView中有多少个item。我们仅仅给最后一个加入动画就可以。其他的就直接显示就好了。
1、上下滑动问题
首先。我们首先解决上下滑动问题,这个问题事实上比較好解决,仅仅须要监听listview的OnScrollListener,依据它推断出当前ListView是上滑还是下滑就能够了。
先看我们在onScrollListner中都有哪些參数:
AbsListView.OnScrollListener mOnScrollListener = new AbsListView.OnScrollListener() {
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) { } @Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
}
};
我们主要关注onScroll的监听。
onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount)
有四个參数:
- 第一个參数AbsListView view:是当前listview的对象
- 第二个參数int firstVisibleItem:表示当前第一个可见的item在listview全部item中的索引。这里须要非常注意。firstVisibleItem与getChildAt(int position)中的參数position的意义不同。firstVisibleItem是指在整个ListView中的位置。而getChildAt(int position)中參数position传的是当前屏幕显示区域中item的索引,屏幕中第一个item的view能够通过getChildAt(0)得到。
- 第三个參数int visibleItemCount:表示当前屏幕中可见的有几条item
- 第四个參数int totalItemCount:表示当前listview总共同拥有多少条item,得到的值与adapter.getCount()的值相同。
在理解了上面四个參数以后,我们再来看看下移的情况;
向下移动包含两种情况:
第一:屏幕中第一个item或前几个item一起移出屏幕,在这样的情况下,我们仅仅须要推断firstVisibleItem是否比上次的值大就可以。即第一个显示的item是不是已经向下移了
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
/**
* firstVisibleItem > mFirstPosition表示向下滑动一个或多个Item
*/
isScrollDown = firstVisibleItem > mFirstPosition;
mFirstPosition = firstVisibleItem;
}
第二:可能用户并没有一次性移一整条item,而是仅让当前item向上移了一点点。这里,由于当前可见的第一个item的位置仍然是firstVisibleItem,仅仅是它的top值变了。
例如以下图:
在这个效果图中,仅仅是将第一个item向上移动了一点点,第一个item左上角的坐标从(0,-100)变成了(0,-200)。所以从这个图中,我们能够得到怎样计算在这样的情况下是否上移。
@Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
View firstChild = view.getChildAt(0);
if (firstChild == null) return;
int top = firstChild.getTop();
/**
* mFirstTop > top表示在当前这个item中滑动
*/
isScrollDown = mFirstTop > top;
mFirstTop = top;
}
仅仅须要推断当前第一个item的左上角坐标是不是变小了就可以。这里须要注意,得到屏幕中显示的第一个Item是通过ListView.getChildAt(int position)函数得到的。
我们上面已经讲到。ListView.getChildAt(int position)中參数position表示的是当前item所在屏幕显示区域中的索引。屏幕中第一个item的索引是0
所以我们将这两种情况进行合并。得到完整的onScrollListener:
AbsListView.OnScrollListener mOnScrollListener = new AbsListView.OnScrollListener() {
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) { } @Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
View firstChild = view.getChildAt(0);
if (firstChild == null) return;
int top = firstChild.getTop();
/**
* firstVisibleItem > mFirstPosition表示向下滑动一整个Item
* mFirstTop > top表示在当前这个item中滑动
*/
isScrollDown = firstVisibleItem > mFirstPosition || mFirstTop > top;
mFirstTop = top;
mFirstPosition = firstVisibleItem;
}
};
然后在getView的时候,推断假设是向下滑动,就加入动画
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null; if (convertView == null) { holder = new ViewHolder();
convertView = mInflater.inflate(R.layout.item_layout, null);
holder.mImageView = (ImageView) convertView.findViewById(R.id.img);
holder.mTextView = (TextView) convertView.findViewById(R.id.text);
} else {
holder = (ViewHolder) convertView.getTag();
} if (isScrollDown) {
convertView.startAnimation(animation);
}
convertView.setTag(holder); holder.mImageView.setImageDrawable(mDrawableList.get(position % mDrawableList.size()));
holder.mTextView.setText(position + ""); return convertView;
}
2、多个item同一时候动画问题
由于我们仅仅能在Item生成时给这个Item加入动画,所以要解决多个item同一时候移动的问题,我们仅仅能给最后一个Item加入动画,其他item不给他们加入。但我们怎么知道当前这个item是不是要显示的最后一个item呢?无法得各,所以一个中转方案是。在每一个item在加入动画前。都把当前显示区域内全部item动画给取消,然后给当前convertView加入上动画。当listview滚动到最后一个Item的时候,自然,相同也是先把全部动画取消,然后给他自己加入上动画,所以这样看起来就好像是仅仅给他自己加入了动画。之前滚动的item是没有动画的。
代码例如以下:
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null; if (convertView == null) { holder = new ViewHolder();
convertView = mInflater.inflate(R.layout.item_layout, null);
holder.mImageView = (ImageView) convertView.findViewById(R.id.img);
holder.mTextView = (TextView) convertView.findViewById(R.id.text);
} else {
holder = (ViewHolder) convertView.getTag();
} //清除当前显示区域中全部item的动画
for (int i=0;i<mListView.getChildCount();i++){
View view = mListView.getChildAt(i);
view.clearAnimation();
}
//然后给当前item加入上动画
if (isScrollDown) {
convertView.startAnimation(animation);
}
convertView.setTag(holder); holder.mImageView.setImageDrawable(mDrawableList.get(position % mDrawableList.size()));
holder.mTextView.setText(position + ""); return convertView;
}
在这段代码中,相比上面的代码。我们仅仅加入了一段语句:
for (int i=0;i<mListView.getChildCount();i++){
View view = mListView.getChildAt(i);
view.clearAnimation();
}
上面我们讲了mListView.getChildAt(int position)的使用方法。说到它的參数position表示的是在当前屏幕显示区域中当前item的索引。所以在当前屏幕中第一个item的索引是0;而mListView.getChildCount()则表示当前屏幕显示区域中,总共同拥有多少个item。所以我们利用上面的代码。对屏幕显示区域中每一个item进行索引,然后取消他们的动画就可以。
此时ListAdapter完整的代码为:
public class ListAdapter extends BaseAdapter {
private List<Drawable> mDrawableList = new ArrayList<>();
private int mLength = 0;
private LayoutInflater mInflater;
private Context mContext;
private ListView mListView;
private Animation animation;
private int mFirstTop, mFirstPosition;
private boolean isScrollDown; public ListAdapter(Context context, ListView listView, List<Drawable> drawables, int length) {
mDrawableList.addAll(drawables);
mLength = length;
mInflater = LayoutInflater.from(context);
mContext = context;
mListView = listView;
animation = AnimationUtils.loadAnimation(mContext, R.anim.bottom_in_anim);
mListView.setOnScrollListener(mOnScrollListener);
} AbsListView.OnScrollListener mOnScrollListener = new AbsListView.OnScrollListener() {
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) { } @Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
View firstChild = view.getChildAt(0);
if (firstChild == null) return;
int top = firstChild.getTop();
/**
* firstVisibleItem > mFirstPosition表示向下滑动一整个Item
* mFirstTop > top表示在当前这个item中滑动
*/
isScrollDown = firstVisibleItem > mFirstPosition || mFirstTop > top;
mFirstTop = top;
mFirstPosition = firstVisibleItem;
}
}; @Override
public int getCount() {
return mLength;
} @Override
public Object getItem(int position) {
return mDrawableList.get(position % mDrawableList.size());
} @Override
public long getItemId(int position) {
return position;
} @Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null; if (convertView == null) { holder = new ViewHolder();
convertView = mInflater.inflate(R.layout.item_layout, null);
holder.mImageView = (ImageView) convertView.findViewById(R.id.img);
holder.mTextView = (TextView) convertView.findViewById(R.id.text);
} else {
holder = (ViewHolder) convertView.getTag();
} //清除当前显示区域中全部item的动画
for (int i=0;i<mListView.getChildCount();i++){
View view = mListView.getChildAt(i);
view.clearAnimation();
}
//然后给当前item加入上动画
if (isScrollDown) {
convertView.startAnimation(animation);
}
convertView.setTag(holder); holder.mImageView.setImageDrawable(mDrawableList.get(position % mDrawableList.size()));
holder.mTextView.setText(position + ""); return convertView;
} public class ViewHolder {
public ImageView mImageView;
public TextView mTextView;
}
}
到这里,有关listview中加入动画的部分就结束了,以下来看一下终于的效果图吧:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />
源代码在文章底部给出
假设本文有帮到你,记得加关注哦
源代码下载地址:http://download.csdn.net/detail/harvic880925/9474080
请大家尊重原创者版权,转载请标明出处: http://blog.csdn.net/harvic880925/article/details/50988685 谢谢
自己定义控件三部曲之动画篇(十三)——实现ListView Item进入动画的更多相关文章
- 自己定义控件三部曲之动画篇(七)——ObjectAnimator基本使用
前言: 假如生活欺骗了你, 不要悲伤,不要心急! 忧郁的日子里须要镇静: 相信吧,快乐的日子终将会来临! 心儿永远向往着未来: 如今却常是忧郁. 一切都是瞬息,一切都将会过去: 而那过去了的,就会成为 ...
- 自己定义控件三部曲视图篇(二)——FlowLayout自适应容器实现
前言:我最大的梦想,就是有一天.等老了坐在摇椅上回望一生,有故事给孩子们讲--. 相关文章: <Android自己定义控件三部曲文章索引>:http://blog.csdn.net/har ...
- android--------自定义控件 之 基本流程篇
在我们平常的Android开发中经常和控件打交道,有时Android提供的控件未必能满足业务的需求,这个时候就需要我们实现自定义一些控件 自定义控件可以设计出很多你想要的功能和模块,在开发中是很重要的 ...
- android--------自定义控件 之 基本实现篇
前面简单的讲述了Android中自定义控件中的几个方法,今天通过代码来实现一个简单的案例 自定义一个扇形图 自定义控件示例: 这里先介绍继承View的方式为例 public class Circula ...
- Android自己定义控件之应用程序首页轮播图
如今基本上大多数的Android应用程序的首页都有轮播图.就是像下图这种(此图为转载的一篇博文中的图.拿来直接用了): 像这种组件我相信大多数的应用程序都会使用到,本文就是自己定义一个这种组件,能够动 ...
- Android自己定义控件:进度条的四种实现方式
前三种实现方式代码出自: http://stormzhang.com/openandroid/2013/11/15/android-custom-loading/ (源代码下载)http://down ...
- 自己定义控件事实上非常easy1/6
尊重原创转载请注明:From AigeStudio(http://blog.csdn.net/aigestudio)Power by Aige 侵权必究! 炮兵镇楼 上一节我们粗略地讲了下怎样去实现我 ...
- Android 实现形态各异的双向側滑菜单 自己定义控件来袭
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/39670935.本文出自:[张鸿洋的博客] 1.概述 关于自己定义控件側滑已经写了 ...
- git-osc自己定义控件之:CircleImageView
git-osc自己定义控件之:CircleImageView 一.CircleImageView的使用 在项目中能够发现,用户的头像都是圆形的.感觉非常好奇,昨天最终发现了,原来是自定了一个Image ...
随机推荐
- Shell编程中Shift的用法【转】
本文转载自:http://www.cnblogs.com/image-eye/archive/2011/08/20/2147153.html Shell编程中Shift的用法 位置参数可以用shift ...
- J2EE7与Servlet3.x
J2EE7结构图 JWS:即Java Web Service,指与webservice相关的JavaEE技术部分,webservice是一种基于XML的独立的.跨平台的.互操作的应用程序,XML又包含 ...
- 第19章 Redis的一些常用技术
19.1 Redis的基础事务 图19-1 Redis命令执行事务的过程 19-1:在Spring中使用Redis ...
- 函数和指针 C++
一.用函数指针变量调用函数. 指针变量也可以指向一个函数,一个函数在编译时被分配给一个入口地址.这个函数入口地址就称为函数的指针.可以用一个指针变量指向函数,然后通过该指针变量调用此函数. 定义指向函 ...
- [转载]Windows Server 2008 R2 之二十五AD RMS信任策略
原文地址:Windows Server 2008 R2 之二十五AD RMS信任策略作者:从心开始 可以通过添加信任策略,让 AD RMS 可以处理由不同的 AD RMS 群集进行权限保护的内容的授权 ...
- js 对象方法、类方法、原型方法区别
function People(name){this.name=name;//对象方法this.Introduce=function(){alert("My name is "+t ...
- 不用任何插件,实现一个tab栏切换
//使用jquery中获取当前索引的方法.显示隐藏 <script> $(".tab_list li").on('click', function () { $(thi ...
- Android网络编程随想录(四)
前面三篇文章从最基础的TCP,HTTP协议理论开始,然后介绍了在Android的开发中所使用的HttpClient和HttpUrlConnection这两种Http客户端.在本文中,我们一起来学习一下 ...
- Codeforces Round #449
960 asteri 1384 492 00:04 -1 892 01:33 960 PEPElotas 1384 488 00:06 896 00:26 960 ...
- Struts2框架学习(二)——访问流程及架构
1.Struts2的执行流程 从客户端发送请求过来,先经过前端控制器(核心过滤器StrutsPrepareAndExecuteFilter)过滤器中执行一组拦截器(一组拦截器就会完成部分功能代码),拦 ...