大家好,今天给大家分享一下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类是单例的,也就是说我们可以自己写个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);
}
}
第六步:运行上述工程效果如下:


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

运行效果3---- 点击第二个按钮
好了今天就讲到这里,大家对Context有什么疑问的,可以留言!!!
源代码点击进入==>
分享到:
相关推荐
大家好,今天给大家分享一下Android里的Context的一些用法. 这里大致可以分为两种:一是传递Context参数,二是调用全局的Context. 其实我们应用启动的时候会启动Application这个类,这个类是在AndroidManifest.xml...
首先,我们来谈谈Android中的消息提示Toast。Toast是一种轻量级的通知方式,它可以在屏幕上的任意位置短暂显示一行文本信息,通常用于告知用户某个操作的结果或者提供简单的反馈。与对话框(Dialog)相比,Toast不会...
本文将详细讲解如何在Android应用中正确使用和理解Context。 首先,让我们明确Context的几种类型: 1. **Activity Context**:通常由Activity类提供,它与用户界面直接关联。Activity Context可以用来启动新的...
接下来,我们谈谈Android中的OOM问题。当应用程序消耗的内存超过系统分配的阈值时,就会触发OOM。这通常是由于大量对象的创建和长时间持有导致的。在Android中,Context是应用程序的基础组件,它用于获取系统服务、...
在这个"Android图片级别Level的使用,旋转动画Demo"中,我们将探讨如何利用Level List和旋转动画来实现动态的视觉效果。 Level List是Android的一种Drawable资源类型,它允许你定义一组Drawable,并为每个Drawable...
接下来,我们谈谈如何在Android中创建Wi-Fi热点,也称为“便携式Wi-Fi热点”或“Wi-Fi直连”。这个功能主要通过`WifiManager`的`setWifiApEnabled()`方法实现。`WifiApAdmin.java`文件很可能包含了用于管理这一功能...
在Android中,可以使用`ConnectivityManager`类来获取当前设备的网络连接状态。这个类提供了多种方法来检查移动数据、Wi-Fi以及其他网络连接。以下是如何获取网络状态的基本步骤: 1. 获取`ConnectivityManager`...
为了在Android项目中使用JUnit,我们需要在build.gradle文件中添加相应的依赖: ```groovy androidTestImplementation 'junit:junit:4.12' testImplementation 'junit:junit:4.12' ``` Android Studio 中的测试...
实现悬浮框的常见方法是使用`android.widget.FrameLayout`或第三方库如`androidx.coordinatorlayout.widget.CoordinatorLayout`配合`androidx.core.view.ViewOutlineProvider`来创建自定义视图。以下是一个简单的...
最后,我们来谈谈Activity的半透明效果。在Android中,可以通过修改Activity的主题或设置透明状态栏来实现。在styles.xml中创建一个新的主题,设置背景颜色为半透明,或者在Activity的AndroidManifest.xml中设置`...
本文将深入探讨如何在Android中使用SQLite进行数据存储,并通过"SQLiteDemo"源代码实例来帮助理解。 首先,我们需要了解SQLite在Android中的基本操作。Android提供了`SQLiteOpenHelper`类,它是操作SQLite数据库的...
这里主要以`HttpURLConnection`为例,因为它自Android API 26开始被推荐使用,具有更好的性能和更低的内存占用。 1. **使用HttpURLConnection进行HTTP请求**: - 首先,创建一个URL对象,指向你要访问的服务器地址...
接着,我们谈谈如何使用AudioRecord API采集音频PCM并保存到文件中。AudioRecord类是Android提供的录音API,用于从设备的麦克风等音频输入源中捕获音频数据。 1. 首先,要使用AudioRecord类,需要先创建一个Audio...
1. **创建Android项目**:使用Android Studio,选择"New Project",然后设置项目名、包名以及目标平台。Android Studio会自动生成必要的文件结构,包括`MainActivity.java`和`activity_main.xml`。 2. **编写Java...
使用`Context.getExternalFilesDir()`或`getExternalCacheDir()`可以访问外部存储的特定目录,但请注意,自Android 6.0(API级别23)起,访问外部存储需要运行时权限。 总的来说,Android中的文件保存涉及`File`和`...
在Android中,处理点击事件通常是通过实现OnClickListener接口或者使用setOnClickListener()方法来完成的。例如,我们可以为上述的Button添加一个点击事件监听器: ```java myButton.setOnClickListener(new View....