欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android Application級別自定義Toast

 更新時間:2018年08月28日 10:30:37   作者:絡(luò)雨涼  
這篇文章主要為大家詳細介紹了Android Application級別自定義Toast,具有一定的參考價值,感興趣的小伙伴們可以參考一下

在Android開發(fā)過程中,有時會需要一些消息提示,大多數(shù)情況可以用dialog來做,但有些消息不需要用戶去點擊取消并且不能對用戶體驗產(chǎn)生影響的提示,就需要toast來做了。但可惜的是,toast是系統(tǒng)級的,凡是涉及到系統(tǒng)的又會涉及到其他APP,有些定制系統(tǒng)可以對App的消息通知進行設(shè)置,一旦禁止了APP的通知toast則不會顯示。而且在Android 7以后toast還需要申請權(quán)限麻煩死了有木有,勞資就想安安靜靜的提示一下有這么麻煩嗎!所以,本人特地研究了下能在Application級別不受限制提示的toast。

先看效果:

效果很簡單,就是一個頭部即現(xiàn)即隱的提示,外加過渡動畫。其實自定義系統(tǒng)級的toast也能實現(xiàn)這種效果,但之前已經(jīng)說了系統(tǒng)級的toast有限制。

話不多說,現(xiàn)在介紹下這是如何實現(xiàn)的吧!

首先申明這是基于WindowManager產(chǎn)生的view,本人看了系統(tǒng)級toast的源碼好像也是基于WindowManager的。WindowManager是個神奇的東西,在這就不多做介紹了,我們只需要知道activity.getWindowManager().addView(layout, params)可以給整個Activity界面添加一個view層,這一層可以不影響activity的操作。竟然有這個功能瞬間漲姿勢了有不有!細心人的應(yīng)該察覺到了這和FrameLayout挺像,其實Activity的root就是一個FrameLayout。

好了,既然Activity有這個功能,那tosat做起來就有頭緒了。

先實現(xiàn)java類代碼(個人愛好,喜歡先主后次):

/**
 * App級toast
 */
public class AppToast
{
  private Activity activity;
 
  private ViewGroup layout;
  private ViewGroup content;
  private TextView textView;
 
  private Animation startAnimation;
  private Animation centerAnimation;
  private Animation endAnimation;
 
  private DelayTask task;
  private boolean isShow;
 
  private LayoutParams params;
 
  /**
   * APP級別Toast
   */
  public AppToast(Activity activity)
  {
    this.activity = activity;
 
    layout = (ViewGroup) LayoutInflater.from(activity).inflate(R.layout.toast, null);
    content = (ViewGroup) layout.getChildAt(0);
    textView = (TextView) content.getChildAt(0);
    params = new LayoutParams();
    params.height = LayoutParams.WRAP_CONTENT;
    params.width = LayoutParams.MATCH_PARENT;
    params.gravity = Gravity.TOP;
    params.type = LayoutParams.TYPE_APPLICATION;
    params.format = PixelFormat.TRANSLUCENT;
    params.flags = LayoutParams.FLAG_KEEP_SCREEN_ON | LayoutParams.FLAG_NOT_FOCUSABLE |
        LayoutParams.FLAG_NOT_TOUCHABLE;
    activity.getWindowManager().addView(layout, params);
    layout.setVisibility(View.GONE);
 
    // 開始動畫
    startAnimation = new AlphaAnimation(0, 1);
    startAnimation.setDuration(500);
 
    // 中間動畫
    centerAnimation = new AlphaAnimation(0.92f, 1);
    centerAnimation.setDuration(500);
 
    // 結(jié)束動畫
    endAnimation = new AlphaAnimation(1, 0);
    endAnimation.setDuration(500);
    endAnimation.setInterpolator(new AccelerateInterpolator());
 
    // 結(jié)束動畫監(jiān)聽
    endAnimation.setAnimationListener(new Animation.AnimationListener()
    {
      @Override
      public void onAnimationStart(Animation animation)
      {
      }
 
      @Override
      public void onAnimationEnd(Animation animation)
      {
        layout.setVisibility(View.GONE);
      }
 
      @Override
      public void onAnimationRepeat(Animation animation)
      {
      }
    });
  }
 
  /**
   * 顯示Toast
   */
  public void show(String s)
  {
    show(s, 1500);
  }
 
  /**
   * 顯示Toast
   */
  public void show(String s, int delay)
  {
    textView.setText(s);
    start();
    if (task != null)
    {
      task.stop();
    }
    task = new DelayTask(delay)
    {
      @Override
      public void logic()
      {
        end();
      }
    };
    task.start();
  }
 
  /**
   * 開始
   */
  private void start()
  {
    if (!isShow)
    {
      layout.setVisibility(View.VISIBLE);
      content.startAnimation(startAnimation);
      isShow = true;
    } else
    {
      content.startAnimation(centerAnimation);
    }
  }
 
  /**
   * 結(jié)束
   */
  private void end()
  {
    content.startAnimation(endAnimation);
    isShow = false;
  }
}

先在構(gòu)造方法AppToast(Activity activity)中加載自定義toast的布局以及初始化params參數(shù)。然后添加各個過程所需的動畫。這其中有個重點,就是params.type = LayoutParams.TYPE_APPLICATION,記住一定要是TYPE_APPLICATION,而不是TYPE_TOAST,TYPE_TOAST會在Android 7上被莫名其妙的限制。
有些人可能會注意到除了開始動畫和結(jié)束動畫,為什么還有個中間動畫?其實這是為了多重toast提示做的一個辨別機制,我們在用系統(tǒng)級toast的時候有些人應(yīng)該能感受到toast并不是重疊顯示,但也不是直接替換內(nèi)容,而是在替換內(nèi)容的時候微微的閃一下表示內(nèi)容變更了,所以在這里就用了一個中間動畫來執(zhí)行那“閃一下”的效果。

關(guān)于其中用到的一個延時器類DelayTask,這是本人為了方便自行設(shè)計的一個工具類,其效果就是延時執(zhí)行一段UI邏輯,其代碼如下:

/**
 * 延時器類
 *
 * @author zls
 *
 * @version 1.0
 *
 * @time 2015-12-27下午7:52:10
 */
public abstract class DelayTask
{
 protected Thread thread;
 private boolean isRun;
 
 /**
 * 延時器
 */
 public DelayTask(final long delay)
 {
 thread = new Thread()
 {
  @Override
  public void run()
  {
  try
  {
   sleep(delay);
   if(isRun)
   {
   mHandler.sendEmptyMessage(0);
   }
  } catch (Exception e)
  {
  }
  }
 };
 }
 
 protected Handler mHandler = new Handler()
 {
 @Override
 public void handleMessage(Message msg)
 {
  logic();
 }
 };
 
 /** 開始執(zhí)行 */
 public void start()
 {
 isRun = true;
 thread.start();
 }
 
 /** 停止執(zhí)行 */
 public void stop()
 {
 isRun = false;
 }
 
 /** 執(zhí)行邏輯 */
 public abstract void logic();
}

有興趣的朋友可以借鑒下,覺得這么設(shè)計不太好的也可以用你們自己設(shè)計的延時器來用。

現(xiàn)在上toast的布局代碼:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:orientation="vertical"
  android:paddingTop="5dp"
  android:paddingLeft="15dp"
  android:paddingRight="15dp">
 
  <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@drawable/toast_shape"
    android:fitsSystemWindows="true"
    android:orientation="vertical">
 
    <TextView
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:layout_margin="20dp"
      android:gravity="center"
      android:text="默認提示"
      android:textColor="#fff"
      android:textSize="15sp"/>
  </LinearLayout>
 
</LinearLayout>

測試Activity的代碼:

public class MainActivity extends AppCompatActivity
{
  private AppToast toast;
 
  @Override
  protected void onCreate(Bundle savedInstanceState)
  {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main_activity);
 
    toast = new AppToast(this);
  }
 
  public void ok(View v)
  {
    toast.show("這是Toast測試!" + Math.random());
  }
}

Demo下載

就此結(jié)束,希望能幫到需要此功能的朋友。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論