翻翻git之---炫酷的自定义翻滚View TagCloudView

Posted 王亟亟

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了翻翻git之---炫酷的自定义翻滚View TagCloudView相关的知识,希望对你有一定的参考价值。

转载请注明出处:王亟亟的大牛之路

周一好,又到了每周最困的一天,最近都被啮齿类动物搞的累死,废话不多,今天上一个自定义的ViewGroup实现一个3D球形集合。

效果图:

这里写图片描述

效果还不错,可以作为短小文字内容的展示用


How to use?

Grade:

compile 'com.moxun:tagcloudlib:1.1.0'

Eclipse:

这里写图片描述

把这些代码Copy到自己的项目里去吧!

控件有几个自定义标签共给大家设置,诸如转的速度啊,初始颜色结束颜色啊之类的。

  <declare-styleable name="TagCloudView">
        <attr name="autoScrollMode">
            <enum name="disable" value="0"/>
            <enum name="decelerate" value="1"/>
            <enum name="uniform" value="2"/>
        </attr>

        <attr name="radiusPercent" format="float"/>
        <attr name="scrollSpeed" format="float"/>
        <attr name="lightColor" format="color"/>
        <attr name="darkColor" format="color"/>
    </declare-styleable>

如何填充数据?

首先你要写一个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操作。

其他方法,就是一些就是普通的设置和传参方法了。

源码地址:https://github.com/misakuo/3dTagCloudAndroid/archive/master.zip

作者Git:https://github.com/misakuo/3dTagCloudAndroid

以上是关于翻翻git之---炫酷的自定义翻滚View TagCloudView的主要内容,如果未能解决你的问题,请参考以下文章

翻翻git之---"有趣效果"的自定义View EasyArcLoading

Android 自定义 View:炫酷的剑气加载效果实现

翻翻git之---自定义View实现水位上涨效果 WaveProgressView

翻翻git之---可用作课程表/排班表的自定义table库ScrollTableView

CSS3制作炫酷的自定义发光文字_Div+Css教程_三联

Android自定义View(RollWeekView-炫酷的星期日期选择控件)