时间:2021-05-19
最近业务需求,要求实现一个3D星球环绕效果,经过百般查找,终于找到了这个功能。
来先看看效果图:
首先还是添加第三方依赖库:
compile 'com.moxun:tagcloudlib:1.1.0'布局:
<?xml version="1.0" encoding="utf-8"?> <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" 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"> <com.moxun.tagcloudlib.view.TagCloudView 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" /> </android.support.constraint.ConstraintLayout>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<String> 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"}; 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); } }以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了Android实现3D标签云效果展示的具体代码,供大家参考,具体内容如下一、关于3D标签云TagCloudView是一个完全基于Androi
本文实例讲述了Android编程实现3D旋转效果的方法。分享给大家供大家参考,具体如下:下面的示例是在Android中实现图片3D旋转的效果。实现3D效果一般使
闲扯两句最近想给自己的博客上加上一个3D标签云的效果,用来表示自己博客文章的分组,网上找到了canvas实现的,还有a元素实现的解析3D标签云,我想让标签可以选
本文实例讲述了vue实现标签云效果的方法。分享给大家供大家参考,具体如下:闲扯两句最近想给自己的博客上加上一个3D标签云的效果,用来表示自己博客文章的分组,网上
网站中常常可见一种3D云标签,将重要的关键字突出显示,次要关键字则变小变暗,并将多个关键字以球状显示,非常有立体感。今天小编教给大家在PPT中一种3D球状标签云