本文共 2068 字,大约阅读时间需要 6 分钟。
周一好,又到了每周最困的一天,最近都被啮齿类动物搞的累死,废话不多,今天上一个自定义的ViewGroup实现一个3D球形集合。
效果图:
效果还不错,可以作为短小文字内容的展示用
How to use?
Grade:
compile 'com.moxun:tagcloudlib:1.1.0'
Eclipse:
把这些代码Copy到自己的项目里去吧!
控件有几个自定义标签共给大家设置,诸如转的速度啊,初始颜色结束颜色啊之类的。
如何填充数据?
首先你要写一个Adapter继承TagsAdapter 像这样
public class TextTagsAdapter extends TagsAdapter
TagsAdapter是作者自定义的一个抽象,只是为了好理解叫Adapter但是跟我们平时listview用的那一系列Adapter没啥关系
public abstract class TagsAdapter
作者写了一系列的抽象方法和一个监听数据变化的接口供给我们使用。
public abstract class TagsAdapter { private OnDataSetChangeListener onDataSetChangeListener; public abstract int getCount(); public abstract View getView(Context context, int position, ViewGroup parent); public abstract Object getItem(int position); public abstract int getPopularity(int position); public abstract void onThemeColorChanged(View view,int themeColor); public final void notifyDataSetChanged() { onDataSetChangeListener.onChange(); } protected interface OnDataSetChangeListener{ void onChange(); } protected void setOnDataSetChangeListener(OnDataSetChangeListener listener) { onDataSetChangeListener = listener; }}
这边来说说他的视图操作,控件本身是不带有任何子视图的也就是,它本身是没有那些“NO.X”操作的,那么也就是说我们需要用代码添加那些控件,就在getView里操作
public View getView(Context context, final int position, ViewGroup parent)
例子中是这样的
@Override public View getView(Context context, final int position, ViewGroup parent) { TextView tv = new TextView(context); ViewGroup.MarginLayoutParams lp = new ViewGroup.MarginLayoutParams(100, 100); tv.setLayoutParams(lp); tv.setText("No." + position); tv.setGravity(Gravity.CENTER); tv.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Log.e("Click","Tag " + position + " clicked."); } }); return tv; }
当然,控件也就能添加自身的Click操作。
其他方法,就是一些就是普通的设置和传参方法了。
源码地址:
作者Git: