android實現滾動文本效果
本文實例為大家分享了android實現滾動文本效果的具體代碼,供大家參考,具體內容如下
效果圖
實現方法
直接上代碼
首先是一個自定義layout,繼承自FrameLayout
public class AnimationTextLayout extends FrameLayout { private static final String TAG = 'AnimationTextLayout'; private List<String> tipList; private List<Integer> displayList; private List<TextView> viewList; private List<VirtualPos> virtualPosList; private double deviantAngle = 0; public AnimationTextLayout(@NonNull Context context) { super(context); initView(); } public AnimationTextLayout(@NonNull Context context, @Nullable AttributeSet attrs) { super(context, attrs); initView(); } public AnimationTextLayout(@NonNull Context context, @Nullable AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); initView(); } private void initView() { viewList = new ArrayList<>(); displayList = new ArrayList<>(); virtualPosList = new ArrayList<>(); } /** * 設置需要顯示的數據 * * @param data 需要顯示的數據 */ public void setData(List<String> data) { this.tipList = data; initTips(); } private void initTips() { while (tipList.size() > viewList.size()) { addTipsView(); } refreshTips(); initVirPos(); post(new Runnable() { @Override public void run() { initPosition(); requestLayout(); } }); } /** * 計算虛擬位置 */ private void initVirPos() { virtualPosList.clear(); for (int i = 0; i < viewList.size(); i++) { double angle = (Math.PI * ((double) i / viewList.size())*2)+(deviantAngle*Math.PI*2); if (angle>Math.PI*2){ angle-=Math.PI*2; } VirtualPos virtualPos = new VirtualPos(); virtualPos.text = tipList.get(i); virtualPos.z = 100 * Math.sin(angle); virtualPos.y = 100 * Math.cos(angle); virtualPosList.add(virtualPos); } } /** * 將虛擬位置轉化為實際高度和位置 */ private void initPosition() { for (int i = 0; i < viewList.size(); i++) { TextView textView = viewList.get(i); VirtualPos virtualPos=virtualPosList.get(i); int realY = (int) ((100 - virtualPos.y)/200 *getMeasuredHeight()); FrameLayout.LayoutParams layoutParams = (LayoutParams) textView.getLayoutParams(); layoutParams.topMargin = realY; if (virtualPos.z>=0){ float textSize= (float) (( virtualPos.z)/100)*20+5; textView.setTextSize(textSize); textView.setVisibility(VISIBLE); }else { textView.setVisibility(GONE); } Log.d(TAG, 'initPosition: y=='+realY); } } private void refreshTips() { for (int i = 0; i < viewList.size(); i++) { TextView tip = viewList.get(i); if (i < tipList.size()) { tip.setVisibility(VISIBLE); tip.setText(tipList.get(i)); continue; } tip.setVisibility(GONE); } } private TextView addTipsView() { TextView textView = new TextView(getContext()); textView.setTextSize(COMPLEX_UNIT_DIP, 12); textView.setTextColor(Color.parseColor('#444444')); textView.setPadding(ConvertUtil.dp2px(5), ConvertUtil.dp2px(3), ConvertUtil.dp2px(5), ConvertUtil.dp2px(3)); LayoutParams layoutParams = new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT); layoutParams.gravity=Gravity.CENTER_HORIZONTAL; layoutParams.rightMargin = ConvertUtil.dp2px(6); addView(textView, layoutParams); viewList.add(textView); return textView; } /** * 虛擬位置,最大x,y,z 最大值為100,最小值為-100 */ public static class VirtualPos { public double x; public double y; public double z; public String text; } /** * 滾動的偏移值 * @param deviantAngle 最大為1 */ public void setDeviantAngle(float deviantAngle) { this.deviantAngle = deviantAngle; initVirPos(); initPosition(); } public double getDeviantAngle() { return deviantAngle; }}
調用方布局
<FrameLayout 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='.AnimationTextActivity'> <com.lanlengran.test.view.AnimationTextLayout android: android:layout_width='match_parent' android:background='@color/colorAccent' android:layout_height='400dp'/></FrameLayout>
調用方代碼
public class AnimationTextActivity extends Activity { private AnimationTextLayout mAnimTextLayout; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_animation_text); mAnimTextLayout = findViewById(R.id.anim_text_layout); List<String> testData = new ArrayList<>(); for (int i = 0; i < 30; i++) { testData.add('測試數據' + i); } mAnimTextLayout.setData(testData); ObjectAnimator animator = ObjectAnimator.ofFloat(mAnimTextLayout, 'deviantAngle', 0f, 1f); animator.setDuration(5000); animator.setRepeatCount(-1); animator.start(); }}
注意事項
此處的動畫只是為了演示。可以根據需要改變自定view的改變滾動值的方法,就可以使滾輪滾動。例如將滾動的角度和手指拖動相結合啥的
/** * 滾動的偏移值 * @param deviantAngle 最大為1*/public void setDeviantAngle(float deviantAngle)
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。
相關文章:
