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


相关文章
|
18天前
|
开发框架 前端开发 Android开发
Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势
本文深入探讨了 Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势。这对于实现高效的跨平台移动应用开发具有重要指导意义。
82 4
|
1月前
|
JSON Java Android开发
探索安卓开发之旅:打造你的第一个天气应用
【10月更文挑战第30天】在这个数字时代,掌握移动应用开发技能无疑是进入IT行业的敲门砖。本文将引导你开启安卓开发的奇妙之旅,通过构建一个简易的天气应用来实践你的编程技能。无论你是初学者还是有一定经验的开发者,这篇文章都将成为你宝贵的学习资源。我们将一步步地深入到安卓开发的世界中,从搭建开发环境到实现核心功能,每个环节都充满了发现和创造的乐趣。让我们开始吧,一起在代码的海洋中航行!
|
1月前
|
存储 搜索推荐 Java
打造个性化安卓应用:从设计到实现
【10月更文挑战第30天】在数字化时代,拥有一个个性化的安卓应用不仅能够提升用户体验,还能加强品牌识别度。本文将引导您了解如何从零开始设计和实现一个安卓应用,涵盖用户界面设计、功能开发和性能优化等关键环节。我们将以一个简单的记事本应用为例,展示如何通过Android Studio工具和Java语言实现基本功能,同时确保应用流畅运行。无论您是初学者还是希望提升现有技能的开发者,这篇文章都将为您提供宝贵的见解和实用的技巧。
|
1月前
|
搜索推荐 开发工具 Android开发
打造个性化Android应用:从设计到实现的旅程
【10月更文挑战第26天】在这个数字时代,拥有一个能够脱颖而出的移动应用是成功的关键。本文将引导您了解如何从概念化阶段出发,通过设计、开发直至发布,一步步构建一个既美观又实用的Android应用。我们将探讨用户体验(UX)设计的重要性,介绍Android开发的核心组件,并通过实际案例展示如何克服开发中的挑战。无论您是初学者还是有经验的开发者,这篇文章都将为您提供宝贵的见解和实用的技巧,帮助您在竞争激烈的应用市场中脱颖而出。
|
1月前
|
算法 Java 数据库
Android 应用的主线程在什么情况下会被阻塞?
【10月更文挑战第20天】为了避免主线程阻塞,我们需要合理地设计和优化应用的代码。将耗时操作移到后台线程执行,使用异步任务、线程池等技术来提高应用的并发处理能力。同时,要注意避免出现死循环、不合理的锁使用等问题。通过这些措施,可以确保主线程能够高效地运行,提供流畅的用户体验。
45 2
|
2月前
|
Java API Android开发
安卓应用程序开发的新手指南:从零开始构建你的第一个应用
【10月更文挑战第20天】在这个数字技术不断进步的时代,掌握移动应用开发技能无疑打开了一扇通往创新世界的大门。对于初学者来说,了解并学习如何从无到有构建一个安卓应用是至关重要的第一步。本文将为你提供一份详尽的入门指南,帮助你理解安卓开发的基础知识,并通过实际示例引导你完成第一个简单的应用项目。无论你是编程新手还是希望扩展你的技能集,这份指南都将是你宝贵的资源。
68 5
|
2月前
|
移动开发 Dart 搜索推荐
打造个性化安卓应用:从零开始的Flutter之旅
【10月更文挑战第20天】本文将引导你开启Flutter开发之旅,通过简单易懂的语言和步骤,让你了解如何从零开始构建一个安卓应用。我们将一起探索Flutter的魅力,实现快速开发,并见证代码示例如何生动地转化为用户界面。无论你是编程新手还是希望扩展技能的开发者,这篇文章都将为你提供价值。
|
7月前
|
移动开发 安全 Android开发
构建高效Android应用:Kotlin协程的实践与优化策略
【5月更文挑战第30天】 在移动开发领域,性能优化始终是关键议题之一。特别是对于Android开发者来说,如何在保证应用流畅性的同时,提升代码的执行效率,已成为不断探索的主题。近年来,Kotlin语言凭借其简洁、安全和实用的特性,在Android开发中得到了广泛的应用。其中,Kotlin协程作为一种新的并发处理机制,为编写异步、非阻塞性的代码提供了强大工具。本文将深入探讨Kotlin协程在Android开发中的应用实践,以及如何通过协程优化应用性能,帮助开发者构建更高效的Android应用。
|
7月前
|
API 调度 Android开发
打造高效Android应用:探究Kotlin协程的优势与实践
【5月更文挑战第27天】在移动开发领域,性能优化和响应速度是衡量应用质量的关键因素。随着Kotlin语言的普及,协程作为其核心特性之一,为Android开发者提供了一种全新的并发处理方式。本文深入探讨了Kotlin协程在Android应用开发中的优势,并通过实例演示如何在实际项目中有效利用协程提升应用性能和用户体验。
|
7月前
|
移动开发 Android开发 开发者
构建高效Android应用:探究Kotlin协程的优势与实践
【5月更文挑战第21天】在移动开发领域,性能优化和流畅的用户体验是至关重要的。随着Kotlin语言在Android平台的广泛采纳,其并发处理的强大工具—协程(Coroutines),已成为提升应用响应性和效率的关键因素。本文将深入分析Kotlin协程的核心原理,探讨其在Android开发中的优势,并通过实例演示如何有效利用协程来优化应用性能,打造更加流畅的用户体验。
70 4