您的位置:首页 > 移动开发 > Android开发

Android关于context上下文定义全局的,转载一个大神的

2015-01-21 11:14 369 查看
大家好,今天给大家分享一下Android里的Context的一些用法,以前经常有人在群里问我比如我在一个工具类里的某个方法,或者View里需要调用Context.但是工具类还有View里没有这个上下文怎么办?为了解决大家的疑问,为了解决大家的疑问,我今天写一个简单的Demo.让大家如何学好自如的用Context.想什么时候有Context,什么时候就有Context.

这里大致可以分为两种:一是传递Context参数,二是调用全局的Context.

其实我们应用启动的时候会启动Application这个类,这个类是在AndroidManifest.xml文件里其实是默认的

[java] view
plaincopy

<application

android:icon="@drawable/ic_launcher"

android:label="@string/app_name"

>

<activity

android:name=".ApplicationDemoActivity"

android:label="@string/app_name" >

<intent-filter>

<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />

</intent-filter>

</activity>

</application>

这个Application类是单例的,也就是说我们可以自己写个Application(比如名为:MainApplication)类,来代替默认的Applicaiton,这个类可以保存应用的全局变量,我们可以定义一个全局的Context.供外部调用.用法如下:

[java] view
plaincopy

package com.tutor.application;



import android.app.Application;

import android.content.Context;



public class MainApplication extends Application {



/**

* 全局的上下文.

*/

private static Context mContext;



@Override

public void onCreate() {

super.onCreate();



mContext = getApplicationContext();



}



/**获取Context.

* @return

*/

public static Context getContext(){

return mContext;

}





@Override

public void onLowMemory() {

super.onLowMemory();

}





}

我们需要在AndroidMainifest.xml把MainApplication注册进去(第10行代码):

[java] view
plaincopy

<?xml version="1.0" encoding="utf-8"?>

<manifest xmlns:android="http://schemas.android.com/apk/res/android"

package="com.tutor.application"

android:versionCode="1"

android:versionName="1.0" >



<application

android:icon="@drawable/ic_launcher"

android:label="@string/app_name"

android:name=".MainApplication" >

<activity

android:name=".ApplicationDemoActivity"

android:label="@string/app_name" >

<intent-filter>

<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />

</intent-filter>

</activity>

</application>



</manifest>

为了让大家更容易理解,写了一个简单的Demo.步骤如下:

第一步:新建一个Android工程ApplicationDemo,目录结构如下:



第二步:新建MainApplication.java,代码和上面一样我就不贴了.

第三步:新建一个工具类ToolsUtil.java,代码如下

[java] view
plaincopy

package com.tutor.application;



import android.content.Context;

import android.widget.Toast;



/**

* @author frankiewei.

* 应用的一些工具类.

*/

public class ToolUtils {



/**

* 参数带Context.

* @param context

* @param msg

*/

public static void showToast(Context context,String msg){

Toast.makeText(context, msg, Toast.LENGTH_SHORT).show();

}



/**

* 调用全局的Context.

* @param msg

*/

public static void showToast(String msg){

Toast.makeText(MainApplication.getContext(), msg, Toast.LENGTH_SHORT).show();

}

}

第四步:新建一个View命名为MainView.java就是我们Activity现实的View.代码如下:

[java] view
plaincopy

package com.tutor.application;



import android.app.Activity;

import android.content.Context;

import android.util.AttributeSet;

import android.view.LayoutInflater;

import android.view.View;

import android.widget.Button;

import android.widget.FrameLayout;



/**

* @author frankiewei.

* 自定义的MainView.

*/

public class MainView extends FrameLayout implements View.OnClickListener{



private Context mContext;



private Activity mActivity;



/**

* 参数Button.

*/

private Button mArgButton;



/**

* 全局Button.

*/

private Button mGlobleButton;



/**

* 退出Button.

*/

private Button mExitButton;



public MainView(Context context){

super(context);

setupViews();

}



public MainView(Context context, AttributeSet attrs) {

super(context, attrs);

setupViews();

}





private void setupViews(){

//获取View的上下文.

mContext = getContext();

//这里将Context转换为Activity.

mActivity = (Activity)mContext;

LayoutInflater inflater = LayoutInflater.from(mContext);

View v = inflater.inflate(R.layout.main, null);

addView(v);



mArgButton = (Button)v.findViewById(R.id.arg_button);

mGlobleButton = (Button)v.findViewById(R.id.glo_button);

mExitButton = (Button)v.findViewById(R.id.exit_button);



mArgButton.setOnClickListener(this);

mGlobleButton.setOnClickListener(this);

mExitButton.setOnClickListener(this);

}



public void onClick(View v) {

if(v == mArgButton){

ToolUtils.showToast(mContext, "我是通过传递Context参数显示的!");

}else if(v == mGlobleButton){

ToolUtils.showToast("我是通过全局Context显示的!");

}else{

mActivity.finish();

}

}



}

这里MainView.java使用的布局main.xml代码如下:

[html] view
plaincopy

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:orientation="vertical" >



<TextView

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="Welcome to frankie wei's blog."

/>



<Button

android:id="@+id/arg_button"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="传递Context参数"

/>



<Button

android:id="@+id/glo_button"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="全局的Context"

/>



<Button

android:id="@+id/exit_button"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="退出App"

/>



</LinearLayout>

第五步:修改ApplicationDemoActivity.java,代码如下:

[java] view
plaincopy

package com.tutor.application;



import android.app.Activity;

import android.os.Bundle;



public class ApplicationDemoActivity extends Activity {

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);



MainView mMainView = new MainView(this);

setContentView(mMainView);



}



}

第六步:运行上述工程效果如下:






运行效果1 运行效果2---- 点击第一个按钮



运行效果3---- 点击第二个按钮

好了今天就讲到这里,大家对Context有什么疑问的,可以留言!!!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: