谈谈Android里的Context的使用!!!
来源:互联网 发布:网络数据库管理员 编辑:程序博客网 时间:2024/05/16 06:08
大家好,今天给大家分享一下Android里的Context的一些用法,以前经常有人在群里问我比如我在一个工具类里的某个方法,或者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 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 MainApplicationextends 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();
- }
- }
package com.tutor.application;import android.app.Application;import android.content.Context;public class MainApplication extends Application {/** * 全局的上下文. */private static Context mContext;@Overridepublic void onCreate() {super.onCreate();mContext = getApplicationContext();}/**获取Context. * @return */public static Context getContext(){return mContext;}@Overridepublic 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>
<?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 staticvoid showToast(Context context,String msg){
- Toast.makeText(context, msg, Toast.LENGTH_SHORT).show();
- }
- /**
- * 调用全局的Context.
- * @param msg
- */
- public staticvoid showToast(String msg){
- Toast.makeText(MainApplication.getContext(), msg, Toast.LENGTH_SHORT).show();
- }
- }
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 MainViewextends 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();
- }
- }
- }
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代码如下:
- <?xmlversion="1.0"encoding="utf-8"?>
- <LinearLayoutxmlns: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>
<?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 ApplicationDemoActivityextends Activity {
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- MainView mMainView = new MainView(this);
- setContentView(mMainView);
- }
- }
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---- 点击第一个按钮
好了今天就讲到这里,大家对Context有什么疑问的,可以留言!!!
- 谈谈Android里的Context的使用!!!
- 谈谈Android里的Context的使用!!!
- 谈谈Android里的Context的使用!!!
- 谈谈Android里的Context的使用!!!
- 谈谈Android里的Context的使用!
- 谈谈Android里的Context的使用!!!
- 谈谈Android里的Context的使用!!!
- 谈谈Android里的Context的使用!!!
- 谈谈Android里的Context的使用!
- Android里Context的使用
- Android里Context的使用
- Android里的Context的使用
- 浅谈Android里的Context的使用
- Android里的Context
- android Context的使用
- android里context从哪里来的????
- android的context使用,工具类context
- BroadcastReceiver里的context
- 安装ileanring6问题
- Spring中报"Could not resolve placeholder"的解决方案
- Android 解析后台返回为Json数据的简单例子!!!
- 敢送iPhone5了,哈哈!!!加油~~~~~~
- Struts2中对数字进行格式化:1、将数字用‘,’号分隔;2、将小数格式化为百分比
- 谈谈Android里的Context的使用!!!
- 解决Android解析图片的OOM问题!!!
- 与蜂共舞—ZigBee技术一瞥
- 【hadoop学习】VMware+RedHat+jdk的安装
- jquery基本用法大全【最新2012版】
- Linux init详解
- 在linux中 应用程序如何调用模块内的函数
- vmware linux安装samba服务
- ios6.0下使用iad