android 3d标签云效果,Android实现3D标签云效果

最近业务需求,要求实现一个3D星球环绕效果,经过百般查找,终于找到了这个功能。

来先看看效果图:

d120b2ca9131353e0173d8cfb38caebe.png

首先还是添加第三方依赖库:

compile 'com.moxun:tagcloudlib:1.1.0'

布局:

xmlns:app="http://schemas.android.com/apk/res-auto"

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context="com.example.administrator.my3d_demo.MainActivity">

android:id="@+id/tag_cloud"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:layout_margin="10dp"

app:autoScrollMode="uniform"

app:darkColor="#ff00ff00"

app:lightColor="#ffff0000"

app:radiusPercent="0.5"

app:scrollSpeed="3" />

MainActivity代码:

package com.example.administrator.my3d_demo;

import android.graphics.Color;

import android.support.v7.app.AppCompatActivity;

import android.os.Bundle;

import com.moxun.tagcloudlib.view.TagCloudView;

public class MainActivity extends AppCompatActivity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

TagCloudView tagCloudView = (TagCloudView) findViewById(R.id.tag_cloud);

tagCloudView.setBackgroundColor(Color.LTGRAY);

TextTagsAdapter tagsAdapter = new TextTagsAdapter(new String[20]);

tagCloudView.setAdapter(tagsAdapter);

}

}

一个适配器代码:

package com.example.administrator.my3d_demo;

import android.content.Context;

import android.support.annotation.NonNull;

import android.util.Log;

import android.view.Gravity;

import android.view.View;

import android.view.ViewGroup;

import android.widget.TextView;

import com.moxun.tagcloudlib.view.TagsAdapter;

import java.util.ArrayList;

import java.util.Collections;

import java.util.List;

import java.util.Random;

public class TextTagsAdapter extends TagsAdapter {

private List dataSet = new ArrayList<>();

public TextTagsAdapter(@NonNull String... data) {

dataSet.clear();

Collections.addAll(dataSet, data);

}

@Override

public int getCount() {

return dataSet.size();

}

@Override

public View getView(final Context context, final int position, ViewGroup parent) {

String[] name = {"1", "2", "3", "4", "5", "6", "7", "8", "9"};

/*int[] name={R.mipmap.ic_launcher,R.mipmap.ic_launcher,R.mipmap.ic_launcher,

R.mipmap.ic_launcher,R.mipmap.ic_launcher,R.mipmap.ic_launcher,

R.mipmap.ic_launcher,R.mipmap.ic_launcher,R.mipmap.ic_launcher};*/

Random rand = new Random();

int randNum = rand.nextInt(9);

TextView tv = new TextView(context);

ViewGroup.MarginLayoutParams lp = new ViewGroup.MarginLayoutParams(100, 100);

tv.setLayoutParams(lp);

tv.setText("No." + name[randNum]);

tv.setGravity(Gravity.CENTER);

tv.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

Log.e("Click", "Tag " + position + " clicked.");

}

});

return tv;

}

@Override

public Object getItem(int position) {

return dataSet.get(position);

}

@Override

public int getPopularity(int position) {

return position % 7;

}

@Override

public void onThemeColorChanged(View view, int themeColor) {

((TextView) view).setTextColor(themeColor);

}

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持找一找教程网。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值