亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

android實現上下滾動的TextView

2020-04-11 12:22:03
字體:
來源:轉載
供稿:網友

一 說明
    這里重要應用類 AutoTextView,這是一個自定義的類,繼承至TextSwitcher,下面臨 AutoTextView類做簡要說明:

    1. 該類應用的重點,在于設置兩個動畫, setInAnimation(...)  和 setOutAnimation(...),分離是文字進入的動畫和文字退出的動畫;

    2. 類中定義了一個外部類-Rotate3dAnimation,重要靠該類實現文字進出動畫,該外部類繼承至Animation。說來偶合,這個恰好是在apiDemo中看到了,自定義Animation我還是第一次應用,動畫邏輯均在void applyTransformation(float interpolatedTime, Transformation t)中實現,代碼相當鋒利,我在原來的基礎上,更改了一下,實現了上述的效果,

二 代碼部分:
1.AutoTextView.java

復制代碼 代碼如下:

package com.example.animtextview;

import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Camera;
import android.graphics.Matrix;
import android.util.AttributeSet;
import android.view.Gravity;
import android.view.View;
import android.view.animation.AccelerateInterpolator;
import android.view.animation.Animation;
import android.view.animation.Transformation;
import android.widget.TextSwitcher;
import android.widget.TextView;
import android.widget.ViewSwitcher;

public class AutoTextView extends TextSwitcher implements
  ViewSwitcher.ViewFactory {

 private float mHeight;
 private Context mContext;
 //mInUp,mOutUp分離構成向下翻頁的進出動畫
 private Rotate3dAnimation mInUp;
 private Rotate3dAnimation mOutUp;

 //mInDown,mOutDown分離構成向下翻頁的進出動畫
 private Rotate3dAnimation mInDown;
 private Rotate3dAnimation mOutDown;

 public AutoTextView(Context context) {
  this(context, null);
  // TODO Auto-generated constructor stub
 }

 public AutoTextView(Context context, AttributeSet attrs) {
  super(context, attrs);
  // TODO Auto-generated constructor stub
  TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.auto3d);
  mHeight = a.getDimension(R.styleable.auto3d_textSize, 36);
  a.recycle();
  mContext = context;
  init();
 }

 private void init() {
  // TODO Auto-generated method stub
  setFactory(this);
  mInUp = createAnim(-90, 0 , true, true);
  mOutUp = createAnim(0, 90, false, true);
  mInDown = createAnim(90, 0 , true , false);
  mOutDown = createAnim(0, -90, false, false);
  //TextSwitcher重要用于文件切換,比如 從文字A 切換到 文字 B,
  //setInAnimation()后,A將執行inAnimation,
  //setOutAnimation()后,B將執行OutAnimation
        setInAnimation(mInUp);
        setOutAnimation(mOutUp);
 }

 private Rotate3dAnimation createAnim(float start, float end, boolean turnIn, boolean turnUp){
        final Rotate3dAnimation rotation = new Rotate3dAnimation(start, end, turnIn, turnUp);
        rotation.setDuration(800);
        rotation.setFillAfter(false);
        rotation.setInterpolator(new AccelerateInterpolator());
        return rotation;
 }

 //這里返回的TextView,就是我們看到的View
 @Override
 public View makeView() {
  // TODO Auto-generated method stub
  TextView t = new TextView(mContext);
  t.setGravity(Gravity.CENTER);
  t.setTextSize(mHeight);
  t.setMaxLines(2);
  return t;
 }
 //定義動作,向下滾動翻頁
 public void previous(){
  if(getInAnimation() != mInDown){
   setInAnimation(mInDown);
  }
  if(getOutAnimation() != mOutDown){
   setOutAnimation(mOutDown);
  }
 }
 //定義動作,向上滾動翻頁
 public void next(){
  if(getInAnimation() != mInUp){
   setInAnimation(mInUp);
  }
  if(getOutAnimation() != mOutUp){
   setOutAnimation(mOutUp);
  }
 }

  class Rotate3dAnimation extends Animation {
      private final float mFromDegrees;
      private final float mToDegrees;
      private float mCenterX;
      private float mCenterY;
      private final boolean mTurnIn;
      private final boolean mTurnUp;
      private Camera mCamera;

      public Rotate3dAnimation(float fromDegrees, float toDegrees, boolean turnIn, boolean turnUp) {
          mFromDegrees = fromDegrees;
          mToDegrees = toDegrees;
          mTurnIn = turnIn;
          mTurnUp = turnUp;
      }

      @Override
      public void initialize(int width, int height, int parentWidth, int parentHeight) {
          super.initialize(width, height, parentWidth, parentHeight);
          mCamera = new Camera();
          mCenterY = getHeight() / 2;
          mCenterX = getWidth() / 2;
      }

      @Override
      protected void applyTransformation(float interpolatedTime, Transformation t) {
          final float fromDegrees = mFromDegrees;
          float degrees = fromDegrees + ((mToDegrees - fromDegrees) * interpolatedTime);

          final float centerX = mCenterX ;
          final float centerY = mCenterY ;
          final Camera camera = mCamera;
          final int derection = mTurnUp ? 1: -1;

          final Matrix matrix = t.getMatrix();

          camera.save();
          if (mTurnIn) {
              camera.translate(0.0f, derection *mCenterY * (interpolatedTime - 1.0f), 0.0f);
          } else {
              camera.translate(0.0f, derection *mCenterY * (interpolatedTime), 0.0f);
          }
          camera.rotateX(degrees);
          camera.getMatrix(matrix);
          camera.restore();

          matrix.preTranslate(-centerX, -centerY);
          matrix.postTranslate(centerX, centerY);
      }
  }
}


2. MainActivity.java
復制代碼 代碼如下:

package com.example.animtextview;

import android.os.Bundle;
import android.app.Activity;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class MainActivity extends Activity implements OnClickListener {

 private Button mBtnNext;
 private Button mBtnPrev;
 private AutoTextView mTextView02;
 private static int sCount = 10;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  init();
 }
 private void init() {
  // TODO Auto-generated method stub
  mBtnNext = (Button) findViewById(R.id.next);
  mBtnPrev = (Button) findViewById(R.id.prev);
  mTextView02 = (AutoTextView) findViewById(R.id.switcher02);
  mTextView02.setText("Hello world!");
  mBtnPrev.setOnClickListener(this);
  mBtnNext.setOnClickListener(this);
 }

 @Override
 public void onClick(View arg0) {
  // TODO Auto-generated method stub
  switch (arg0.getId()) {
  case R.id.next:
   mTextView02.next();
   sCount++;
   break;
  case R.id.prev:
   mTextView02.previous();
   sCount--;
   break;
  }
  mTextView02.setText(sCount%2==0 ?
    sCount+"AAFirstAA" :
    sCount+"BBBBBBB");
  System.out.println("getH: ["+mTextView02.getHeight()+"]");

 }
}

3. activity_main.xml

復制代碼 代碼如下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:auto3d="http://schemas.android.com/apk/res/com.example.animtextview"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content" >

        <Button
            android:id="@+id/next"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentLeft="true"
            android:layout_alignParentTop="true"
            android:text="@string/next" />

        <Button
            android:id="@+id/prev"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:layout_alignParentTop="true"
            android:text="@string/prev" />
    </RelativeLayout>

    <com.example.animtextview.AutoTextView
        android:id="@+id/switcher02"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@android:color/holo_green_dark"
        auto3d:textSize="30sp" />

</LinearLayout>

    代碼中沒寫太多注釋,不過結構還算清晰,應該不難看懂!

三 小結
    我認為該控件實現的難點在于 動畫文件的編寫,即Rotate3dAnimation中applyTransformation(...)方法的實現,通過控制camara在Y方向上挪動和在X方向上的旋轉,從而造成上下翻滾的視覺感,然后將該值轉換到matrix上,從而改變了參數(..,Transformation t).有興致的朋友可以直接改寫該方法,便可失掉不同動畫效果的TextSwitcher.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩亚洲一区二区三区| 欧美性少妇18aaaa视频| 亚洲精品美女免费| xxx成人少妇69| 日韩成人在线观看| 国产成人久久久精品一区| 中文字幕一精品亚洲无线一区| 午夜精品99久久免费| 国产a级全部精品| 精品国偷自产在线视频| 伊人久久久久久久久久久| 精品国产网站地址| 国产一区视频在线| 国产午夜精品全部视频在线播放| 欧美综合在线第二页| 欧美日韩成人在线观看| 26uuu亚洲国产精品| 国产欧美日韩精品在线观看| 亚洲直播在线一区| 欧美在线xxx| 精品国产91乱高清在线观看| 欧美性受xxxx白人性爽| 黑人精品xxx一区一二区| 欧美高清videos高潮hd| 国产成人av在线播放| 国产亚洲精品美女久久久久| 日韩免费视频在线观看| 久久人人爽人人爽人人片亚洲| 成人激情电影一区二区| 国产精品aaaa| 亚洲成人av资源网| 亚洲视频专区在线| 俺也去精品视频在线观看| 亚洲午夜国产成人av电影男同| 亚洲大胆人体视频| 欧美在线视频观看免费网站| 国产成人+综合亚洲+天堂| 国产精品专区h在线观看| 欧美日韩国产黄| 91在线|亚洲| 日本道色综合久久影院| 亚洲一区免费网站| 欧美日韩国产综合新一区| 成人性生交大片免费看小说| 国产精品国产三级国产aⅴ浪潮| 久久久久久欧美| 亚洲国产精品久久91精品| 激情懂色av一区av二区av| 精品国产精品三级精品av网址| 日韩精品中文字幕在线播放| 热久久99这里有精品| 91国语精品自产拍在线观看性色| 91精品久久久久久久久青青| 欧美性受xxx| 555www成人网| 亚洲有声小说3d| 午夜精品99久久免费| 日韩美女视频免费看| 欧美性xxxx极品高清hd直播| 亚洲免费视频在线观看| 97涩涩爰在线观看亚洲| 日韩成人中文字幕在线观看| 日韩av成人在线| 欧美另类交人妖| 国产日韩换脸av一区在线观看| 丝袜亚洲另类欧美重口| 国产va免费精品高清在线| 懂色av影视一区二区三区| 亚洲电影av在线| 亚洲国产欧美日韩精品| 欧美激情精品久久久久久黑人| 久久精品视频免费播放| 欧美特级www| 91精品国产免费久久久久久| 免费91麻豆精品国产自产在线观看| 欧美大肥婆大肥bbbbb| 国产亚洲aⅴaaaaaa毛片| 国产成人精品日本亚洲| 操日韩av在线电影| 在线观看91久久久久久| 精品网站999www| 97视频在线观看免费| 欧美日本啪啪无遮挡网站| 97香蕉久久夜色精品国产| 高清一区二区三区四区五区| 亚洲成人网久久久| 一区二区三区www| 91精品啪aⅴ在线观看国产| 视频一区视频二区国产精品| 欧美国产日韩免费| 亚洲欧美综合v| 久久成人精品视频| 一区二区三区美女xx视频| 国产在线观看精品| 久久精品人人爽| 欧美影院成年免费版| 亚洲日本欧美中文幕| 日产日韩在线亚洲欧美| 久久久国产成人精品| 国产日韩av在线| 成人激情视频小说免费下载| xxx成人少妇69| 欧美日韩国产成人在线| 亚洲最大在线视频| 国产成人av在线| 午夜精品一区二区三区在线视| 久久久伊人欧美| 国产精品人成电影在线观看| 久久69精品久久久久久久电影好| 一本色道久久综合亚洲精品小说| 国产精品一区二区三| 国产成人免费av电影| 91精品国产自产在线老师啪| www.亚洲成人| 欧美另类在线观看| 在线观看国产欧美| 欧美疯狂性受xxxxx另类| 亚洲精品理论电影| 日韩在线视频网站| 亚洲视频在线视频| 国产亚洲精品久久久久久777| 国产精品成熟老女人| 国产美女高潮久久白浆| 欧美激情图片区| 中文字幕日韩欧美在线视频| 97精品伊人久久久大香线蕉| 91国产在线精品| 菠萝蜜影院一区二区免费| 久久久精品在线| 中文字幕v亚洲ⅴv天堂| 欧美性在线观看| 日日狠狠久久偷偷四色综合免费| 欧美日韩第一页| 北条麻妃一区二区三区中文字幕| 亚洲国产毛片完整版| 国产美女高潮久久白浆| 色综合久久悠悠| 69影院欧美专区视频| 夜夜嗨av色综合久久久综合网| 成人自拍性视频| 国产精品久久久| 色婷婷久久一区二区| 91美女片黄在线观| 亚洲japanese制服美女| 欧美日韩ab片| 欧美理论电影在线播放| 欧美日韩aaaa| 欧美性xxxx在线播放| 精品国产鲁一鲁一区二区张丽| 精品国产一区二区三区久久狼黑人| 91精品久久久久久久久久久| 亚洲成人在线视频播放| 成人黄色在线免费| 91精品国产综合久久久久久蜜臀| 国内精品一区二区三区四区| 国产成人久久精品| 久久91精品国产91久久跳| 久久人人爽人人爽人人片亚洲| 久久久精品国产亚洲| 狠狠躁夜夜躁久久躁别揉| 亚洲free性xxxx护士白浆| 国产精品啪视频| 欧美精品久久久久久久免费观看| 在线播放精品一区二区三区|