Fix demo launcher

- pinShortcuts() needs to be passed all pinned shortcut IDs from the target app,
but originally it was passing those from the target *activity*.

- Also LauncherApps throws IllegalStateException when work profile is off.
Catch runtime exceptions and show a message.

Change-Id: I5a97c808ed7d9aff17bd11aa4ed28ee0efc330f0
This commit is contained in:
Makoto Onuki
2016-07-28 18:10:53 -07:00
parent 8e1f716acc
commit 74d5f56ed8
4 changed files with 74 additions and 52 deletions

View File

@@ -15,17 +15,14 @@
*/ */
package com.example.android.pm.shortcutlauncherdemo; package com.example.android.pm.shortcutlauncherdemo;
import android.app.ListFragment;
import android.content.Context; import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.content.pm.LauncherActivityInfo; import android.content.pm.LauncherActivityInfo;
import android.content.pm.LauncherApps; import android.content.pm.LauncherApps;
import android.content.pm.LauncherApps.ShortcutQuery; import android.content.pm.LauncherApps.ShortcutQuery;
import android.content.pm.ShortcutInfo;
import android.graphics.drawable.Drawable; import android.graphics.drawable.Drawable;
import android.os.Bundle; import android.os.Bundle;
import android.os.UserHandle; import android.os.UserHandle;
import android.os.UserManager;
import android.util.DisplayMetrics; import android.util.DisplayMetrics;
import android.util.Log; import android.util.Log;
import android.view.LayoutInflater; import android.view.LayoutInflater;
@@ -36,7 +33,6 @@ import android.widget.BaseAdapter;
import android.widget.Button; import android.widget.Button;
import android.widget.ImageView; import android.widget.ImageView;
import android.widget.TextView; import android.widget.TextView;
import android.widget.Toast;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
@@ -159,19 +155,23 @@ public class AppListFragment extends MyBaseListFragment {
v.setTag(ai); v.setTag(ai);
v.setVisibility(View.INVISIBLE); v.setVisibility(View.INVISIBLE);
if (mLauncherApps.hasShortcutHostPermission()) { try {
mQuery.setPackage(ai.getComponentName().getPackageName()); if (mLauncherApps.hasShortcutHostPermission()) {
mQuery.setQueryFlags(ShortcutQuery.FLAG_MATCH_DYNAMIC mQuery.setPackage(ai.getComponentName().getPackageName());
| ShortcutQuery.FLAG_MATCH_PINNED mQuery.setQueryFlags(ShortcutQuery.FLAG_MATCH_DYNAMIC
| ShortcutQuery.FLAG_MATCH_MANIFEST | ShortcutQuery.FLAG_MATCH_PINNED
| ShortcutQuery.FLAG_GET_KEY_FIELDS_ONLY); | ShortcutQuery.FLAG_MATCH_MANIFEST
mQuery.setActivity(ai.getComponentName()); | ShortcutQuery.FLAG_GET_KEY_FIELDS_ONLY);
mQuery.setActivity(ai.getComponentName());
if (mLauncherApps.getShortcuts(mQuery, ai.getUser()).size() > 0) { if (mLauncherApps.getShortcuts(mQuery, ai.getUser()).size() > 0) {
v.setOnClickListener(this); v.setOnClickListener(this);
v.setVisibility(View.VISIBLE); v.setVisibility(View.VISIBLE);
v.setText("Shortcuts"); v.setText("Shortcuts");
}
} }
} catch (Exception e) {
Log.w(Global.TAG, "Caught exception", e);
} }
} }
@@ -191,8 +191,12 @@ public class AppListFragment extends MyBaseListFragment {
final LauncherActivityInfo ai = (LauncherActivityInfo) v.getTag(); final LauncherActivityInfo ai = (LauncherActivityInfo) v.getTag();
switch (v.getId()) { switch (v.getId()) {
case R.id.launch: case R.id.launch:
mLauncherApps.startMainActivity(ai.getComponentName(), ai.getUser(), try {
null, null); mLauncherApps.startMainActivity(ai.getComponentName(), ai.getUser(),
null, null);
} catch (Exception e) {
Global.showToast(getContext(), e.getMessage());
}
return; return;
case R.id.action2: case R.id.action2:
showShortcutsForPackage(ai); showShortcutsForPackage(ai);

View File

@@ -15,6 +15,13 @@
*/ */
package com.example.android.pm.shortcutlauncherdemo; package com.example.android.pm.shortcutlauncherdemo;
import android.content.Context;
import android.widget.Toast;
public class Global { public class Global {
public static final String TAG = "ShortcutLauncherDemo"; public static final String TAG = "ShortcutLauncherDemo";
public static void showToast(Context context, String message) {
Toast.makeText(context, message, Toast.LENGTH_SHORT).show();
}
} }

View File

@@ -30,7 +30,6 @@ import android.support.v4.view.ViewPager;
import android.view.ViewGroup; import android.view.ViewGroup;
public class ShortcutLauncherMain extends Activity { public class ShortcutLauncherMain extends Activity {
private LauncherApps mLauncherApps;
private ViewPager mPager; private ViewPager mPager;
private PagerAdapter mPagerAdapter; private PagerAdapter mPagerAdapter;
@@ -40,8 +39,6 @@ public class ShortcutLauncherMain extends Activity {
setContentView(R.layout.main); setContentView(R.layout.main);
mLauncherApps = getSystemService(LauncherApps.class);
mPager = (ViewPager) findViewById(R.id.pager); mPager = (ViewPager) findViewById(R.id.pager);
mPager.setOffscreenPageLimit(2); mPager.setOffscreenPageLimit(2);
mPagerAdapter = new MyPagerAdapter(getFragmentManager()); mPagerAdapter = new MyPagerAdapter(getFragmentManager());

View File

@@ -24,6 +24,7 @@ import android.os.Bundle;
import android.os.UserHandle; import android.os.UserHandle;
import android.os.UserManager; import android.os.UserManager;
import android.text.TextUtils; import android.text.TextUtils;
import android.util.Log;
import android.widget.Toast; import android.widget.Toast;
import com.example.android.pm.shortcutdemo.ShortcutAdapter; import com.example.android.pm.shortcutdemo.ShortcutAdapter;
@@ -93,49 +94,62 @@ public class ShortcutListFragment extends MyBaseListFragment {
private void togglePin(ShortcutInfo selected) { private void togglePin(ShortcutInfo selected) {
final String packageName = selected.getPackage(); final String packageName = selected.getPackage();
final List<String> pinned = new ArrayList<>(); try {
for (ShortcutInfo si : mAdapter.getShortcuts()) { final ShortcutQuery q = new ShortcutQuery()
if (si.isPinned() .setPackage(packageName)
&& si.getPackage().equals(packageName) .setQueryFlags(ShortcutQuery.FLAG_MATCH_PINNED)
&& si.getUserHandle().equals(selected.getUserHandle())) { ;
final List<String> pinned = new ArrayList<>();
for (ShortcutInfo si : mLauncherApps.getShortcuts(q, android.os.Process.myUserHandle())) {
pinned.add(si.getId()); pinned.add(si.getId());
} }
if (selected.isPinned()) {
pinned.remove(selected.getId());
} else {
pinned.add(selected.getId());
}
mLauncherApps.pinShortcuts(packageName, pinned, selected.getUserHandle());
} catch (Exception e) {
Global.showToast(getContext(), e.getMessage());
} }
if (selected.isPinned()) {
pinned.remove(selected.getId());
} else {
pinned.add(selected.getId());
}
mLauncherApps.pinShortcuts(packageName, pinned, selected.getUserHandle());
} }
private void launch(ShortcutInfo si) { private void launch(ShortcutInfo si) {
mLauncherApps.startShortcut(si.getPackage(), si.getId(), null, null, try {
si.getUserHandle()); mLauncherApps.startShortcut(si.getPackage(), si.getId(), null, null,
si.getUserHandle());
} catch (Exception e) {
Global.showToast(getContext(), e.getMessage());
}
} }
@Override @Override
protected void refreshList() { protected void refreshList() {
if (!mLauncherApps.hasShortcutHostPermission()) { try {
return; if (!mLauncherApps.hasShortcutHostPermission()) {
return;
}
final List<ShortcutInfo> list = new ArrayList<>();
for (UserHandle user : getTargetUsers()) {
final Bundle b = getArguments();
mQuery.setQueryFlags(
(b.getBoolean(ARG_INCLUDE_DYNAMIC) ? ShortcutQuery.FLAG_MATCH_DYNAMIC : 0) |
(b.getBoolean(ARG_INCLUDE_MANIFEST) ? ShortcutQuery.FLAG_MATCH_MANIFEST : 0) |
(b.getBoolean(ARG_INCLUDE_PINNED) ? ShortcutQuery.FLAG_MATCH_PINNED : 0));
mQuery.setPackage(b.getString(ARG_TARGET_PACKAGE));
mQuery.setActivity(b.getParcelable(ARG_TARGET_ACTIVITY));
list.addAll(mLauncherApps.getShortcuts(mQuery, user));
}
Collections.sort(list, mShortcutComparator);
mAdapter.setShortcuts(list);
} catch (Exception e) {
Log.w(Global.TAG, "Caught exception", e);
} }
final List<ShortcutInfo> list = new ArrayList<>();
for (UserHandle user : getTargetUsers()) {
final Bundle b = getArguments();
mQuery.setQueryFlags(
(b.getBoolean(ARG_INCLUDE_DYNAMIC) ? ShortcutQuery.FLAG_MATCH_DYNAMIC : 0) |
(b.getBoolean(ARG_INCLUDE_MANIFEST) ? ShortcutQuery.FLAG_MATCH_MANIFEST : 0) |
(b.getBoolean(ARG_INCLUDE_PINNED) ? ShortcutQuery.FLAG_MATCH_PINNED : 0));
mQuery.setPackage(b.getString(ARG_TARGET_PACKAGE));
mQuery.setActivity(b.getParcelable(ARG_TARGET_ACTIVITY));
list.addAll(mLauncherApps.getShortcuts(mQuery, user));
}
Collections.sort(list, mShortcutComparator);
mAdapter.setShortcuts(list);
} }
private final Comparator<ShortcutInfo> mShortcutComparator = private final Comparator<ShortcutInfo> mShortcutComparator =