App Shortcuts 快捷方式

Android Nougat 7.1(API 25) 新功能:App Shortcuts 快捷方式

AppShortcuts

是什么?

是将应用程序的常见操作或任务暴露给启动项的一种方法。通过长按应启动图标显示快捷方式。

快捷方式可以拖拽到桌面单独放置,变成单独的桌面快捷方式。

  1. 静态:在xml文件中定义
  2. 动态:由ShortcutManager发布,可根据用户的行为或偏好添加,支持动态更新

静态 Shortcuts##

  1. AndroidManifest.xml中的main activity上添加

         
             
             
             
         

         

activity需满足两个条件:

  1. actionandroid.intent.action.MAIN
  2. categoryandroid.intent.category.LAUNCHER
  3. res/xml目录下创建shortcuts.xml文件,里面包含静态的shortcuts
 
 
         
             
        
 

根标签,可以包含多个,每一个代表一个静态shortcut

  • enabledshortcut是否可用
  • iconshortcut左侧显示的图标
  • shortcutDisabledMessage:选择不可用的shortcut时给用户的一个提示
  • shortcutId:唯一的idid相同时只显示第一个
  • shortcutShortLabel:配置短名称,长名称显示不下时显示短名称
  • shortcutLongLabel:配置长名称,launcher优先选择显示
  • intent:确定一个或多个意图,并绑定shortcut
    • targetPackage: 指定目标应用的包名
    • targetClass: 要跳转的目标类
    • action: 必须配置,否则崩溃
    • categories: 目前官方只给提供了android.shortcut.conversation
      每个可以添加多个
 
 
         
            
             
        
 

点击快捷方式会创建一个intents栈(MainActivity -> Static ShortcutActivity),当返回时回到MainActivity

App Shortcuts 快捷方式_第1张图片
app_shortcut_static_back_stack

动态 Shortcuts

可以在使用应用的过程中构建,更新,或者删除。
相关方法:ShortcutManagerShortcutInfo.Builder

@Override
protected void onCreate(Bundle savedInstanceState) {    
    super.onCreate(savedInstanceState);    
    setContentView(R.layout.activity_main);
  
    ShortcutManager shortcutmanager = getSystemService(ShortcutManager.class);
    ShortcutInfo webShortcut = new ShortcutInfo.Builder(this, "shortcut_web")            
                  .setShortLabel("web")        
                  .setLongLabel("Open baidu.com web site")        
                  .setIcon(Icon.createWithResource(this, R.mipmap.ic_launcher))        
                  .setIntent(new Intent(Intent.ACTION_VIEW, Uri.parse("https://baidu.com")))        
                  .build();
    shortcutmanager.setDynamicShortcuts(Collections.singletonList(webShortcut));
}

ShortcutManager

可对动态shortcut完成以下操作:

  • 发布(Publish):setDynamicShortcuts(List)addDynamicShortcuts(List)
  • 更新(Update):updateShortcuts(List)
  • 删除(Remove):removeDynamicShortcuts(List)removeAllDynamicShortcuts()

ShortcutInfo.Builder

方法中第二个参数是shortcutid,多个shortcutid相同时,前面的shortcut会被覆盖。

多个Intent构建back stack

@Override
protected void onCreate(Bundle savedInstanceState) {    
    super.onCreate(savedInstanceState);    
    setContentView(R.layout.activity_main);
 
    ShortcutManager shortcutmanager = getSystemService(ShortcutManager.class);
    ShortcutInfo dynamicShortcut = new ShortcutInfo.Builder(this, "shortcut_dynamic")            
        .setShortLabel("Dynamic")        
        .setLongLabel("Open dynamic shortcut")        
        .setIcon(Icon.createWithResource(this, R.mipmap.ic_launcher))        
        .setIntents(new Intent[]{                
            new Intent(Intent.ACTION_MAIN, Uri.EMPTY, this, MainActivity.class)                        
                .setFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK),                
            new Intent("TwoActivity.action")       
         })        
        .build();
    shortcutmanager.setDynamicShortcuts(Arrays.asList(dynamicShortcut));
}

//AndroidManifest.xml
    
            
                
            
    

和静态一样,最后一个Intent打开TwoActivity页面,前面的构建back stack, 即返回退回到MainActivity

注意:Intent必须指定Action,否则抛出异常。

Shortcut 排序

含多个Shortcuts时,默认按照添加顺序排列,通过setRank()可改变排序。

ShortcutInfo webShortcut = new ShortcutInfo.Builder(MainActivity.this, "shortcut_web") 
    .setRank(1)  //参数不能为负数
    .build(); 
ShortcutInfo dynamicShortcut = new ShortcutInfo.Builder(MainActivity.this, "shortcut_dynamic") 
    .setRank(0) 
    .build(); 
shortcutManager.updateShortcuts(Arrays.asList(webShortcut, dynamicShortcut));

只能改变动态shortcuts的排序,且按照xml中先后顺序排列,故:静态的shortcuts离应用图标最近,动态shortcuts在其之上排序,首位级别为0,依次类推。

App Shortcuts 快捷方式_第2张图片
app_shortcut_ranks

其他

ShortcutInfo.BuildersetShortLabel(CharSequence)接收一个CharSequence作为参数,这意味着可以添加自定义的span

ForegroundColorSpan colorSpan = new ForegroundColorSpan(getResources().
    getColor(android.R.color.holo_red_dark, getTheme())); 
String label = "catinean.com"; 
SpannableStringBuilder colouredLabel = new SpannableStringBuilder(label); 
colouredLabel.setSpan(colorSpan, 0, label.length(), Spanned.SPAN_INCLUSIVE_INCLUSIVE); 

ShortcutInfo webShortcut = new ShortcutInfo.Builder(MainActivity.this, "shortcut_web")   
    .setShortLabel(colouredLabel) 
    .setRank(1) 
    .build();
shortcutmanager.setDynamicShortcuts(Collections.singletonList(webShortcut));
App Shortcuts 快捷方式_第3张图片
app_shortcut_colour

数量限制

静态和动态shortcuts加起来总数最多五个,否则抛出异常:java.lang.IllegalArgumentException: Max number of dynamic shortcuts exceeded,但当正好有5个时, 长按只显示4个。

参考

Exploring Android Nougat 7.1 App Shortcuts

你可能感兴趣的:(App Shortcuts 快捷方式)