android创建快捷方式来打开应用中特定的Activity

简介:

有段时间没有记录过了。

这也是换工作以后写的第一篇吧,现在公司是在做sdk的接入,对于我来说,能接触到更多不同于以前应用的很多东西,提供自己的服务给更多的人。

虽然是只是进行迭代,但是我觉得对我也有很大的帮助。


现在sdk应设计的要求要在使用了我们sdk的游戏在安装打开以后就要创建一个快捷方式,然后这个快捷方式不是用来打开应用,是为了进行静默下载所创建的,但是我们知道android里边快捷方式是与应用绑定的,他只能打开Activity,我一开始的设想是我捕捉到快捷方式的点击事件,然后开一个service来进行下载,但是首先我们不能捕捉到快捷方式的点击事件,应用这个都是launcher来进行操作的,看过launcher.java的人应该知道他其实是一个Activity,我们打开手机看到的桌面,所有的应用图标都是运行在这个activity上的,快捷方式其实就是一个TextView,然后添加了一个点击事件,点击了以后也没有任何的广播等等的通知,谁也不知道他点击了哪个,所以这是行不同的。

那么就只能用一个没有标题栏的纯粹透明的activity来实现,在点击快捷方式的时候打开这个Activity,然后开启下载任务,然后finish();

这个应该就可以实现了,但是如果你现在当前应用是打开的,那么你点击快捷方式的话是会跳转到你希望的Activity,但是还会呼起程序的第一个Activity。

代码是这样的

(1)

	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		  setResult(RESULT_CANCELED);
		preferences  = getSharedPreferences("cpf", MODE_PRIVATE);
		setContentView(R.layout.main);
		int flag = preferences.getInt("flag",0);
		if (flag == 0) {
			ShortCutClass.createShortcut(this);
			preferences.edit().putInt("flag", 1).commit();
		}else {
			Log.e("tag", "我是一只小小小小鸟");
		}
		
	}

package com.skywang.widget;

import android.annotation.SuppressLint;
import android.app.Activity;
import android.content.ComponentName;
import android.content.Intent;
import android.os.Bundle;
import android.os.Parcelable;

@SuppressLint("NewApi")
public class ShortCutClass {

	public  static void createShortcut(Activity context) {  
     /*   Intent shortcut = new Intent("com.android.launcher.action.INSTALL_SHORTCUT");  
        shortcut.putExtra(Intent.EXTRA_SHORTCUT_NAME, context.getString(R.string.app_name));  
        shortcut.putExtra("duplicate", false);//设置是否重复创建  
        Intent intent = new Intent();  
        intent.addCategory(Intent.CATEGORY_LAUNCHER);  
        intent.setClass(context, ExampleAppWidgetProvider.class);//设置第一个页面  
        intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
        shortcut.putExtra(Intent.EXTRA_SHORTCUT_INTENT, intent);  
        ShortcutIconResource iconRes = Intent.ShortcutIconResource.fromContext(context, R.drawable.ic_launcher);  
        shortcut.putExtra(Intent.EXTRA_SHORTCUT_ICON_RESOURCE, iconRes);  
        context.sendBroadcast(shortcut);  */
/*	    Intent shortcut = new Intent("com.android.launcher.action.INSTALL_SHORTCUT");     
        
	    //快捷方式的名称     
	    shortcut.putExtra(Intent.EXTRA_SHORTCUT_NAME, context.getString(R.string.app_name));     
	    shortcut.putExtra("duplicate", false); //不允许重复创建     
	             
	    //指定当前的Activity为快捷方式启动的对象: 如 com.everest.video.VideoPlayer     
	    //注意: ComponentName的第二个参数必须加上点号(.),否则快捷方式无法启动相应程序     
	    Intent intent = new Intent(context,CopyOfMainActivity.class);
	    intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
	    shortcut.putExtra(Intent.EXTRA_SHORTCUT_INTENT, intent);
	    //快捷方式的图标     
	    ShortcutIconResource iconRes = Intent.ShortcutIconResource.fromContext(context, R.drawable.ic_launcher);     
	    shortcut.putExtra(Intent.EXTRA_SHORTCUT_ICON_RESOURCE, iconRes);     
	             
	    context.sendBroadcast(shortcut);  */
		
		Intent intent = new Intent(/*"cn.kuwo.player.action.SHORTCUT"*/);
		Bundle bundle = new Bundle();
		bundle.putString("noteId", "100");//传递参数
		intent.putExtras(bundle);
		ComponentName cn = new ComponentName("com.skywang.widget",  "com.skywang.widget.CopyOfMainActivity"); 
		intent.setComponent(cn); 
		intent.setAction("android.intent.action.MAIN"); 
		
		// 自定义action
		Intent shortcutintent = new Intent(
		"com.android.launcher.action.INSTALL_SHORTCUT");
		// 不允许重复创建
		shortcutintent.putExtra("duplicate", false);
		// 需要现实的名称
		shortcutintent.putExtra(Intent.EXTRA_SHORTCUT_NAME, "apk");
		// 快捷图片
		Parcelable icon = Intent.ShortcutIconResource.fromContext(
		context.getApplicationContext(), R.drawable.ic_launcher);
		shortcutintent.putExtra(Intent.EXTRA_SHORTCUT_ICON_RESOURCE, icon);
		// 点击快捷图片,运行的程序主入口
		shortcutintent.putExtra(Intent.EXTRA_SHORTCUT_INTENT, intent);
		// 发送广播。OK
		context.sendBroadcast(shortcutintent);
    }  
}
清单文件中设置

        
        <activity 
            android:name="com.skywang.widget.MainActivity"
            android:exported="true"  
           android:icon="@drawable/ic_launcher"  
           android:label="@string/app_name"  
           android:screenOrientation="portrait"  
           android:theme="@android:style/Theme.Translucent.NoTitleBar"
            >
            <intent-filter >
                <action android:name="android.intent.action.MAIN"/>
                <category android:name="android.intent.category.LAUNCHER"/>
            </intent-filter>
        </activity>
        
        <activity android:name="com.skywang.widget.CopyOfMainActivity"
               
            >
         <intent-filter >
              <action android:name="cn.kuwo.player.action.SHORTCUT"/>
                <action android:name="android.intent.action.MAIN"/>
                <category android:name="android.intent.category.DEFAULT" /> <!-- 必须加上这个,否则下面无法直接使用自定的action -->
                </intent-filter>
        </activity>

可以复制代码进行下测试,这样如果应用没有关掉每次都会呼起来,点击后退键就能看到。

为啥会这个样子了,我查了很多资料,关于创建快捷方式,关于launcher启动,清单文件配置的很多文章,经过很多测试以后,发现原来是应为他们处在同一个Task里边,俩个Activity在同一个Task里边,如果应用没有关闭掉的话那么在我调起我们要打开的Activity的时候,会把这个Task也拿进来,而应用的第一个Activity还在,点击后退就会回到应用界面。所有只要我们在启动模式里边配置下就ok。

android:launchMode="singleInstance"

Demo里边是我试验widget实现快捷方式的代码,对于程序没有影响。

Demo下载地址:http://download.csdn.net/detail/u012808234/9361369


相关文章
|
1天前
|
算法 Java 数据库
Android 应用的主线程在什么情况下会被阻塞?
【10月更文挑战第20天】为了避免主线程阻塞,我们需要合理地设计和优化应用的代码。将耗时操作移到后台线程执行,使用异步任务、线程池等技术来提高应用的并发处理能力。同时,要注意避免出现死循环、不合理的锁使用等问题。通过这些措施,可以确保主线程能够高效地运行,提供流畅的用户体验。
8 2
|
5天前
|
Java API Android开发
安卓应用程序开发的新手指南:从零开始构建你的第一个应用
【10月更文挑战第20天】在这个数字技术不断进步的时代,掌握移动应用开发技能无疑打开了一扇通往创新世界的大门。对于初学者来说,了解并学习如何从无到有构建一个安卓应用是至关重要的第一步。本文将为你提供一份详尽的入门指南,帮助你理解安卓开发的基础知识,并通过实际示例引导你完成第一个简单的应用项目。无论你是编程新手还是希望扩展你的技能集,这份指南都将是你宝贵的资源。
21 5
|
5天前
|
移动开发 Dart 搜索推荐
打造个性化安卓应用:从零开始的Flutter之旅
【10月更文挑战第20天】本文将引导你开启Flutter开发之旅,通过简单易懂的语言和步骤,让你了解如何从零开始构建一个安卓应用。我们将一起探索Flutter的魅力,实现快速开发,并见证代码示例如何生动地转化为用户界面。无论你是编程新手还是希望扩展技能的开发者,这篇文章都将为你提供价值。
|
7天前
|
Android开发
Android面试之Activity启动流程简述
Android面试之Activity启动流程简述
52 6
|
8天前
|
消息中间件 Android开发 索引
Android面试高频知识点(4) 详解Activity的启动流程
Android面试高频知识点(4) 详解Activity的启动流程
16 3
|
8天前
|
缓存 前端开发 Android开发
Android实战之如何截取Activity或者Fragment的内容?
本文首发于公众号“AntDream”,介绍了如何在Android中截取Activity或Fragment的屏幕内容并保存为图片。包括截取整个Activity、特定控件或区域的方法,以及处理包含RecyclerView的复杂情况。
11 3
|
15天前
|
调度 Android开发 开发者
构建高效Android应用:探究Kotlin多线程优化策略
【10月更文挑战第11天】本文探讨了如何在Kotlin中实现高效的多线程方案,特别是在Android应用开发中。通过介绍Kotlin协程的基础知识、异步数据加载的实际案例,以及合理使用不同调度器的方法,帮助开发者提升应用性能和用户体验。
36 4
|
8天前
|
Android开发
Android面试之Activity启动流程简述
Android面试之Activity启动流程简述
9 0
|
6月前
|
移动开发 安全 Android开发
构建高效Android应用:Kotlin协程的实践与优化策略
【5月更文挑战第30天】 在移动开发领域,性能优化始终是关键议题之一。特别是对于Android开发者来说,如何在保证应用流畅性的同时,提升代码的执行效率,已成为不断探索的主题。近年来,Kotlin语言凭借其简洁、安全和实用的特性,在Android开发中得到了广泛的应用。其中,Kotlin协程作为一种新的并发处理机制,为编写异步、非阻塞性的代码提供了强大工具。本文将深入探讨Kotlin协程在Android开发中的应用实践,以及如何通过协程优化应用性能,帮助开发者构建更高效的Android应用。
|
6月前
|
API 调度 Android开发
打造高效Android应用:探究Kotlin协程的优势与实践
【5月更文挑战第27天】在移动开发领域,性能优化和响应速度是衡量应用质量的关键因素。随着Kotlin语言的普及,协程作为其核心特性之一,为Android开发者提供了一种全新的并发处理方式。本文深入探讨了Kotlin协程在Android应用开发中的优势,并通过实例演示如何在实际项目中有效利用协程提升应用性能和用户体验。