在Activity中设置DragSortListViewActivity
public class DragSortListViewActivity extends AppCompatActivity {
private DragSortListView dragSortListView;
private DragSortAdapter dragSortAdapter;
private List list;
// 监听器在手机拖动停下的时候触发
private DragSortListView.DropListener onDrop = new DragSortListView.DropListener() {
@Override
public void drop(int from, int to) {// from to 分别表示 被拖动控件原位置 和目标位置
if (from != to) {
MyJaveBean item = (MyJaveBean) dragSortAdapter.getItem(from);// 得到listview的适配器
dragSortAdapter.remove(from);// 在适配器中”原位置“的数据。
dragSortAdapter.insert(item, to);// 在目标位置中插入被拖动的控件。
}
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_dragsortlistview);
dragSortListView=findViewById(R.id.activity_dragsortlistview_listview);
dragSortListView.setDropListener(onDrop);
list=new ArrayList(4);
MyJaveBean myJaveBean1=new MyJaveBean();
myJaveBean1.setName(“高数”);
MyJaveBean myJaveBean2=new MyJaveBean();
myJaveBean2.setName(“英语”);
MyJaveBean myJaveBean3=new MyJaveBean();
myJaveBean3.setName(“数据结构”);
MyJaveBean myJaveBean4=new MyJaveBean();
myJaveBean4.setName(“政治”);
list.add(myJaveBean1);
list.add(myJaveBean2);
list.add(myJaveBean3);
list.add(myJaveBean4);
dragSortAdapter=new DragSortAdapter(DragSortListViewActivity.this,list);
dragSortListView.setAdapter(dragSortAdapter);
dragSortListView.setDragEnabled(true); // 设置是否可拖动。
}
}
list自定义类型为MyJaveBean,其类中主要就是id,name和get,set方法,不赘述
private DragSortListView.DropListener onDrop = new DragSortListView.DropListener() {
@Override
public void drop(int from, int to) {// from to 分别表示 被拖动控件原位置 和目标位置
if (from != to) {
MyJaveBean item = (MyJaveBean) dragSortAdapter.getItem(from);// 得到listview的适配器
dragSortAdapter.remove(from);// 在适配器中”原位置“的数据。
dragSortAdapter.insert(item, to);// 在目标位置中插入被拖动的控件。
}
}
};
这里用到了DragSortListView.DropListener唯一一个回调函数drop,from表示从哪个子view开始,to表示拖到哪个子view。而函数中用到适配器的remove 和insert方法,所谓实现拖动后排序,其实就是得到原来位置上的item,删除原来位置的数据,并在新位置插入选中的item。
而当拖动的View位于一个新条目上方的时候会调用DragSortListView.DragListener中的回调drag,如下。这个listener其实是一个监听拖动路径,即拖动过程中经过了那几个item。
public interface DragListener {
public void drag(int from, int to);
}
在该类中,通过设置adapter来让系统知道到底进行什么操作,代码如下:
@Override
public void setAdapter(ListAdapter adapter) {
if (adapter != null) {
mAdapterWrapper = new AdapterWrapper(adapter);
adapter.registerDataSetObserver(mObserver);
if (adapter instanceof DropListener) {
setDropListener((DropListener) adapter);
}
if (adapter instanceof DragListener) {
setDragListener((DragListener) adapter);
}
if (adapter instanceof RemoveListener) {
setRemoveListener((RemoveListener) adapter);
}
} else {
mAdapterWrapper = null;
}
super.setAdapter(mAdapterWrapper);
}
public class DragSortAdapter extends BaseAdapter {
private Context context;
private List list;
public DragSortAdapter(Context context, List list){
this.context=context;
this.list=list;
}
@Override
public int getCount() {
return list.size();
}
@Override
public Object getItem(int position) {
return list.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
public void remove(int arg0) {// 删除指定位置的item
list.remove(arg0);
this.notifyDataSetChanged();// 不要忘记更改适配器对象的数据源
}
public void insert(MyJaveBean item, int arg0) {// 在指定位置插入item
list.add(arg0, item);
this.notifyDataSetChanged();
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder viewHolder;
if(null==convertView){
convertView=View.inflate(context, R.layout.dragsort_listview_item,null);
viewHolder=new ViewHolder();
viewHolder.dellayout= (RelativeLayout) convertView.findViewById(R.id.dragsort_listview_item_layout);
viewHolder.titletextview= (TextView) convertView.findViewById(R.id.dragsort_listview_item_textview);
convertView.setTag(viewHolder);
}else{
viewHolder= (ViewHolder) convertView.getTag();
}
String name=list.get(position).getName();
viewHolder.titletextview.setText(name);
return convertView;
}
public static class ViewHolder{
private TextView titletextview;
private RelativeLayout dellayout;
}
}
其中viewHolder用来缓存myJavaBean对象,而不必每次都重新创建很多对象,从而提升性能。加载数据是在public View getView(int position, View convertView, ViewGroup parent) {}方法中进行的。即将每一次都重新定义一个View载入布局,再加载数据 。
这里自定义一个简单的浮动视图管理类继承DragSortListView.FloatViewManager
public class SimpleFloatViewManager implements DragSortListView.FloatViewManager {
private Bitmap mFloatBitmap;
private ImageView mImageView;
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
面试复习路线,梳理知识,提升储备
自己的知识准备得怎么样,这直接决定了你能否顺利通过一面和二面,所以在面试前来一个知识梳理,看需不需要提升自己的知识储备是很有必要的。
关于知识梳理,这里再分享一下我面试这段时间的复习路线:(以下体系的复习资料是我从各路大佬收集整理好的)
资料获取方式:前往我的GitHub
- 架构师筑基必备技能
- Android高级UI与FrameWork源码
- 360°全方面性能调优
- 解读开源框架设计思想
- NDK模块开发
- 微信小程序
- Hybrid 开发与Flutter
知识梳理完之后,就需要进行查漏补缺,所以针对这些知识点,我手头上也准备了不少的电子书和笔记,这些笔记将各个知识点进行了完美的总结:
《960全网最全Android开发笔记》
《379页Android开发面试宝典》
历时半年,我们整理了这份市面上最全面的安卓面试题解析大全
包含了腾讯、百度、小米、阿里、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。熟悉本文中列出的知识点会大大增加通过前两轮技术面试的几率。
如何使用它?
1.可以通过目录索引直接翻看需要的知识点,查漏补缺。
2.五角星数表示面试问到的频率,代表重要推荐指数
《507页Android开发相关源码解析》
只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。
329)]
《960全网最全Android开发笔记》
[外链图片转存中…(img-2ULMO8hX-1711181050329)]
《379页Android开发面试宝典》
历时半年,我们整理了这份市面上最全面的安卓面试题解析大全
包含了腾讯、百度、小米、阿里、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。熟悉本文中列出的知识点会大大增加通过前两轮技术面试的几率。
如何使用它?
1.可以通过目录索引直接翻看需要的知识点,查漏补缺。
2.五角星数表示面试问到的频率,代表重要推荐指数
[外链图片转存中…(img-pmiKornQ-1711181050329)]
《507页Android开发相关源码解析》
只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。
真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。