Android 3D 라벨 클 라 우 드 효과 구현

4625 단어 Android라벨 구름
최근 업무 수요 에 따라 3D 별 순환 효 과 를 요구 하 며 백방으로 찾 아 마침내 이 기능 을 찾 았 다.
먼저 효과 도 를 살 펴 보 자.

우선 제3자 의존 라 이브 러 리 를 추가 합 니 다.

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"}; 
  /*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); 
 } 
} 
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기