1. 程式人生 > >android全域性獲取Context物件(在靜態函式中實現toast)

android全域性獲取Context物件(在靜態函式中實現toast)

全域性獲取Context物件的意義:

當應用程式的架構逐漸複雜起來的時候,很多邏輯程式碼都將脫離Activity或者Service,但是如果此時你又恰恰需要使用Context,這個時候就需要用到全域性獲取Context了。

舉個例子,如果此時需要實現一個從網路獲取圖片的類,我有多個Activity,並且每個Activity都需要從網路獲取圖片。在圖片無法獲得的時候,我需要用Toast來提示使用者。那麼看似一個簡單的Toast此時卻顯得讓人頭疼了,在函式中如何能獲取到Context物件了?換言之,我怎麼知道我當前函式使用在哪個Activity中。

有兩種方案可以實現:

1、在函式的建構函式中新增一個Context的引數,每次在使用函式的時候都同時匯入當前使用的Activity。(但是此方案有點推卸責任的嫌疑,因為我們把獲取Context的責任轉移給了Toast的呼叫方,倘若呼叫方也是一個方法,並且沒有Context的引數,那怎麼辦呢?)

2、全域性獲取Context物件。此方法也正是本文所講的方法。

方法其實很簡單,直接上圖上程式碼:

MainActivity:

import android.app.Activity;
import android.content.DialogInterface;
import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Button;
import android.widget.Toast;

public class MainActivity extends Activity implements View.OnClickListener {

    private Button button1;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        button1=(Button)findViewById(R.id.toast1);
        button1.setOnClickListener(this);
    }

    @Override
    public void onClick(View view) {
        switch(view.getId()){
            case R.id.toast1:
                ToastShow1.ToastShow1();
                break;
        }
    }


    
}

ToastShow1:

import android.widget.Toast;

public class ToastShow1 {
    public static void ToastShow1() {
        Toast.makeText(MyApplication.getContext(),"Toast實現成功",Toast.LENGTH_LONG).show();
    }
}

MyApplication:

import android.app.Application;
import android.content.Context;

public class MyApplication extends Application {
    private  static Context context;

    @Override
    public void onCreate() {
        super.onCreate();
        context=getApplicationContext();
    }

    public static Context getContext() {
        return context;
    }
}

我們要告知系統,當程式啟動的時候應該初始化MyApplication這個類,而不是系統預設的Application類。

這裡在指定的MyApplication的時候一定要加上完整的包名,不然系統將無法找到這個類。

AndroidManifest:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.getcontexttest">

    <application
        android:name="com.example.getcontexttest.MyApplication"
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity
            android:name=".MainActivity"
            android:label="@string/app_name"
            android:theme="@style/AppTheme.NoActionBar">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>


activity_main:

<?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="match_parent"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin">

    <Button
        android:id="@+id/toast1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="Toast1" />
    
</LinearLayout>