在一个工具类里的某个方法,或者View里需要调用Context.但是工具类还有View里没有这个上下文怎么办?现在我写一个简单的Demo让大家随意的用Context.想什么时候有Context,什么时候就有Context.

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

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

<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.供外部调用.用法如下:

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行代码):

<?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,代码如下

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.代码如下:

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代码如下:

<?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,代码如下:

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);      }     }  

第六步:运行上述工程效果如下:
点击第一个按钮

点击第二个按钮

以上就是android里context的使用方法。

更多相关文章

  1. Android数据库操作的简单封装
  2. Android中的跨进程通信方法实例及特点分析(二):ContentProvider
  3. COCOS2D-X跨ANDROID&IOS平台开发入门教程
  4. Android:HttpClient工具类
  5. Android(安卓)基于google Zxing实现二维码、条形码扫描,仿微信二
  6. 基于ffmpeg+opengl+opensl es的android视频播放器
  7. 浅析Android(安卓)M新功能Adoptable Storage Devices(适配的存储
  8. 简单处理Android(安卓)65536方法越界问题
  9. Android中AnimationDrawable使用的简单实例

随机推荐

  1. Android简明开发教程二十四:总结及示例代
  2. C#开发Android应用的必备——Mono for An
  3. Android(安卓)7.0新特性
  4. android 预装第三方apk的方法
  5. Android蓝牙开发浅谈
  6. 初探Android中的binder机制
  7. Android之群英传笔记(一)
  8. Android横竖屏切换相关总结
  9. Android深度好文锦集
  10. android主线程报ANR的问题!