int pid = android.os.Process.myPid()
ActivityManager mActivityManager = (ActivityManager) context
.getSystemService(Context.ACTIVITY_SERVICE)
for (ActivityManager.RunningAppProcessInfo appProcess : mActivityManager
.getRunningAppProcesses()) {
if (appProcess.pid == pid) {
return appProcess.processName
}
}
return null
}
你可键搭以遍历他,然后打印进程悔晌冥看稿前拿看
在Android中退出程序比较麻烦,尤其是在多个Activity的程序中,在2.2之前可以采用如下代码退出程序:Java代码
[java]
ActivityManager am = (ActivityManager)getSystemService (Context.ACTIVITY_SERVICE)
am.restartPackage(getPackageName())
ActivityManager am = (ActivityManager)getSystemService (Context.ACTIVITY_SERVICE)
am.restartPackage(getPackageName())
此种方法是一种最方便和最者好旁简单的退出程序的办法,但是在2.2和2.2之后就不能用了,那么如果我们要退出程序有4种办法:
采用content
view栈:如袜仔果程序是多界面,但是又没有强制要求每一个界面一个Activity,可以将每个界面设计为一个View,在界面切换时,只需要调用
Activity的setContentView方法设置Activity的Contentview,这样退出程序只需要将这一个Activity退出
就可以了,但是需要设计一个栈来管理content view。
可以自定义一个Activity的栈,在程序退出时将栈中的所有的Activity进行finish,这种方法,我以前的文章中有详述。
前两种方法的精髓之处都是需要自己设计一个栈用来管理界面或者Activity,这样程序就比较复杂一些。 第3中方法就是,先让程序到Home界面,然后再将process杀死:代码如下:
[java]
Intent intent = new Intent(Intent.ACTION_MAIN)
intent.addCategory(Intent.CATEGORY_HOME)
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP)
startActivity(intent)
android.os.Process.killProcess(Process.myPid())
Intent intent = new Intent(Intent.ACTION_MAIN)
intent.addCategory(Intent.CATEGORY_HOME)
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP)
startActivity(intent)
android.os.Process.killProcess(Process.myPid())
4.还有一种就是使用方法是使用Android的Broadcast机制。在所有的Activity中注册退出程序的消息,当收到消息时调用finish方法。 然后再有退出程序功能的Activity上广播关闭消息。代首橡码如下:
[java]
package com.kingtone.activity
import android.app.Activity
import android.content.BroadcastReceiver
import android.content.Context
import android.content.Intent
import android.content.IntentFilter
/**
* 所有Activity的父类,用来注册退出程序的广播事件,
* 并且对收到的退出程序事件进行处理
* @author Administrator
*
*/
public class CommonActivity extends Activity {
//广播的内部类,当收到关闭事件时,调用finish方法结束activity
private BroadcastReceiver broadcastReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
finish()
}
}
@Override
public void onResume() {
super.onResume()
//在当前的activity中注册广播
IntentFilter filter = new IntentFilter()
filter.addAction(GlobalVarable.EXIT_ACTION)
this.registerReceiver(this.broadcastReceiver, filter)
}
}
package com.kingtone.activity
import android.app.Activity
import android.content.BroadcastReceiver
import android.content.Context
import android.content.Intent
import android.content.IntentFilter
/**
* 所有Activity的父类,用来注册退出程序的广播事件,
* 并且对收到的退出程序事件进行处理
* @author Administrator
*
*/
public class CommonActivity extends Activity {
//广播的内部类,当收到关闭事件时,调用finish方法结束activity
private BroadcastReceiver broadcastReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
finish()
}
}
@Override
public void onResume() {
super.onResume()
//在当前的activity中注册广播
IntentFilter filter = new IntentFilter()
filter.addAction(GlobalVarable.EXIT_ACTION)
this.registerReceiver(this.broadcastReceiver, filter)
}
}
在需要退出程序的Activity(CommonActivity的子类)中,退出程序代码如下:
[java]
Intent intent = new Intent()
intent.setAction(GlobalVarable.EXIT_ACTION)// 退出动作
this.sendBroadcast(intent)// 发送广播
super.finish()
//退出后台线程,以及销毁静态变量
System.exit(0)
Intent intent = new Intent()
intent.setAction(GlobalVarable.EXIT_ACTION)// 退出动作
this.sendBroadcast(intent)// 发送广播
super.finish()
//退出后台线程,以及销毁静态变量
System.exit(0)
监听并处理用户按下back键的方法
[java]
package com.example.android_test01
import android.app.Activity
import android.app.AlertDialog
import android.app.AlertDialog.Builder
import android.content.DialogInterface
import android.content.DialogInterface.OnClickListener
import android.os.Bundle
import android.view.KeyEvent
import android.view.Menu
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
// TODO Auto-generated method stub
System.out.println("你按下了back1")
show_simple()
return super.onKeyDown(keyCode, event)
}
//先调用的onKeyDown(int keyCode, KeyEvent event)方法,然后调用的onBackPressed()方法
@Override
public void onBackPressed() {
// TODO Auto-generated method stub
System.out.println("按下back,立刻退出activity时调用")
super.onBackPressed()
}
public void show_simple()
{
AlertDialog.Builder builder=new Builder(this)
builder.setTitle("欢迎使用本软件")
builder.setPositiveButton("确定", new OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
//退出应用
finish()
}
})
builder.setNegativeButton("取消", new OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
}
})
builder.create().show()
}
}
package com.example.android_test01
import android.app.Activity
import android.app.AlertDialog
import android.app.AlertDialog.Builder
import android.content.DialogInterface
import android.content.DialogInterface.OnClickListener
import android.os.Bundle
import android.view.KeyEvent
import android.view.Menu
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
// TODO Auto-generated method stub
System.out.println("你按下了back1")
show_simple()
return super.onKeyDown(keyCode, event)
}
//先调用的onKeyDown(int keyCode, KeyEvent event)方法,然后调用的onBackPressed()方法
@Override
public void onBackPressed() {
// TODO Auto-generated method stub
System.out.println("按下back,立刻退出activity时调用")
super.onBackPressed()
}
public void show_simple()
{
AlertDialog.Builder builder=new Builder(this)
builder.setTitle("欢迎使用本软件")
builder.setPositiveButton("确定", new OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
//退出应用
finish()
}
})
builder.setNegativeButton("取消", new OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
}
})
builder.create().show()
}
}
/*** 程序是否在前台运行
*
*/
public boolean isAppOnForeground() {
ActivityManager activityManager = (ActivityManager) getApplicationContext()
.getSystemService(Context.ACTIVITY_SERVICE)
String packageName = getApplicationContext().getPackageName()
/**
* 获取Android设备中所有正在运行的App
*/
List<ActivityManager.RunningAppProcessInfo>appProcesses = activityManager
.getRunningAppProcesses()
if (appProcesses == null)
return false
for (ActivityManager.RunningAppProcessInfo appProcess : appProcesses) {
// The name of the process that this object is associated with.
if (appProcess.processName.equals(packageName)
&&appProcess.importance == ActivityManager.RunningAppProcessInfo.IMPORTANCE_FOREGROUND) {
return true
}
}
return false
}
这是我在网上找到的亏迟例子,主要的实现原理就是,使用ActivityManager,首先拿到自己App的包名,再拿到Android设备中所有正在运行的App包名,然后对所有的App进行遍历,通过判断正在运行的App中包名有没有和自己的App相等,从而判断自己的App是否退到销悔李后台.
@Override
protected void onPause() {
super.onPause()
if(!isAppOnForeground()){
Toast.makeText(getApplicationContext(), TAG+"onPause:",
Toast.LENGTH_SHORT).show()
}else {
sendBroadcast(new Intent(NotificationIntentReceiver.ACTION_ENABLE_MESSAGES)
.setClass(this, NotificationIntentReceiver.class))
Toast.makeText(getApplicationContext(), TAG+"后台运行1",
Toast.LENGTH_SHORT).show()
}
}
然后在onPause()方法中,进行判断,上面代码中实现的是,App退出后台就发送广播前竖,然后在广播中执行Notification,然后在回到Activity时,在onResume()中清除应该清除Notification.
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)