The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2008 The Android Open Source Project |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
Daniel Sandler | 325dc23 | 2013-06-05 22:57:57 -0400 | [diff] [blame] | 17 | package com.android.launcher3; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 18 | |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 19 | import android.content.ContentValues; |
Kenny Guy | ed13187 | 2014-04-30 03:02:21 +0100 | [diff] [blame] | 20 | import android.content.Context; |
Winson Chung | be36516 | 2012-05-07 10:34:12 -0700 | [diff] [blame] | 21 | import android.content.Intent; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 22 | import android.graphics.Bitmap; |
| 23 | import android.util.Log; |
| 24 | |
Kenny Guy | ed13187 | 2014-04-30 03:02:21 +0100 | [diff] [blame] | 25 | import com.android.launcher3.compat.UserHandleCompat; |
| 26 | import com.android.launcher3.compat.UserManagerCompat; |
| 27 | |
Winson Chung | be36516 | 2012-05-07 10:34:12 -0700 | [diff] [blame] | 28 | import java.io.ByteArrayOutputStream; |
| 29 | import java.io.IOException; |
Sameer Padala | be3e410 | 2014-04-21 19:36:14 -0700 | [diff] [blame] | 30 | import java.util.Arrays; |
Winson Chung | be36516 | 2012-05-07 10:34:12 -0700 | [diff] [blame] | 31 | |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 32 | /** |
| 33 | * Represents an item in the launcher. |
| 34 | */ |
Mathew Inwood | 72fbec1 | 2013-11-19 15:45:07 +0000 | [diff] [blame] | 35 | public class ItemInfo { |
Kenny Guy | ed13187 | 2014-04-30 03:02:21 +0100 | [diff] [blame] | 36 | |
| 37 | /** |
| 38 | * Intent extra to store the profile. Format: UserHandle |
| 39 | */ |
| 40 | static final String EXTRA_PROFILE = "profile"; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 41 | |
| 42 | static final int NO_ID = -1; |
| 43 | |
| 44 | /** |
| 45 | * The id in the settings database for this item |
| 46 | */ |
Anjali Koppal | e3e646e | 2014-03-17 09:34:39 -0700 | [diff] [blame] | 47 | public long id = NO_ID; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 48 | |
| 49 | /** |
| 50 | * One of {@link LauncherSettings.Favorites#ITEM_TYPE_APPLICATION}, |
| 51 | * {@link LauncherSettings.Favorites#ITEM_TYPE_SHORTCUT}, |
Adam Cohen | df2cc41 | 2011-04-27 16:56:57 -0700 | [diff] [blame] | 52 | * {@link LauncherSettings.Favorites#ITEM_TYPE_FOLDER}, or |
The Android Open Source Project | 7376fae | 2009-03-11 12:11:58 -0700 | [diff] [blame] | 53 | * {@link LauncherSettings.Favorites#ITEM_TYPE_APPWIDGET}. |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 54 | */ |
Anjali Koppal | e3e646e | 2014-03-17 09:34:39 -0700 | [diff] [blame] | 55 | public int itemType; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 56 | |
| 57 | /** |
| 58 | * The id of the container that holds this item. For the desktop, this will be |
| 59 | * {@link LauncherSettings.Favorites#CONTAINER_DESKTOP}. For the all applications folder it |
| 60 | * will be {@link #NO_ID} (since it is not stored in the settings DB). For user folders |
| 61 | * it will be the id of the folder. |
| 62 | */ |
Anjali Koppal | e3e646e | 2014-03-17 09:34:39 -0700 | [diff] [blame] | 63 | public long container = NO_ID; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 64 | |
| 65 | /** |
| 66 | * Iindicates the screen in which the shortcut appears. |
| 67 | */ |
Anjali Koppal | e3e646e | 2014-03-17 09:34:39 -0700 | [diff] [blame] | 68 | public long screenId = -1; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 69 | |
| 70 | /** |
| 71 | * Indicates the X position of the associated cell. |
| 72 | */ |
Anjali Koppal | e3e646e | 2014-03-17 09:34:39 -0700 | [diff] [blame] | 73 | public int cellX = -1; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 74 | |
| 75 | /** |
| 76 | * Indicates the Y position of the associated cell. |
| 77 | */ |
Anjali Koppal | e3e646e | 2014-03-17 09:34:39 -0700 | [diff] [blame] | 78 | public int cellY = -1; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 79 | |
| 80 | /** |
| 81 | * Indicates the X cell span. |
| 82 | */ |
Anjali Koppal | e3e646e | 2014-03-17 09:34:39 -0700 | [diff] [blame] | 83 | public int spanX = 1; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 84 | |
| 85 | /** |
| 86 | * Indicates the Y cell span. |
| 87 | */ |
| 88 | int spanY = 1; |
| 89 | |
Romain Guy | 73b979d | 2009-06-09 12:57:21 -0700 | [diff] [blame] | 90 | /** |
Adam Cohen | d41fbf5 | 2012-02-16 23:53:59 -0800 | [diff] [blame] | 91 | * Indicates the minimum X cell span. |
| 92 | */ |
Anjali Koppal | e3e646e | 2014-03-17 09:34:39 -0700 | [diff] [blame] | 93 | public int minSpanX = 1; |
Adam Cohen | d41fbf5 | 2012-02-16 23:53:59 -0800 | [diff] [blame] | 94 | |
| 95 | /** |
| 96 | * Indicates the minimum Y cell span. |
| 97 | */ |
Anjali Koppal | e3e646e | 2014-03-17 09:34:39 -0700 | [diff] [blame] | 98 | public int minSpanY = 1; |
Adam Cohen | 487f7dd | 2012-06-28 18:12:10 -0700 | [diff] [blame] | 99 | |
Adam Cohen | d41fbf5 | 2012-02-16 23:53:59 -0800 | [diff] [blame] | 100 | /** |
Adam Cohen | 487f7dd | 2012-06-28 18:12:10 -0700 | [diff] [blame] | 101 | * Indicates that this item needs to be updated in the db |
Romain Guy | 73b979d | 2009-06-09 12:57:21 -0700 | [diff] [blame] | 102 | */ |
Anjali Koppal | e3e646e | 2014-03-17 09:34:39 -0700 | [diff] [blame] | 103 | public boolean requiresDbUpdate = false; |
Adam Cohen | 487f7dd | 2012-06-28 18:12:10 -0700 | [diff] [blame] | 104 | |
| 105 | /** |
| 106 | * Title of the item |
| 107 | */ |
| 108 | CharSequence title; |
Romain Guy | 73b979d | 2009-06-09 12:57:21 -0700 | [diff] [blame] | 109 | |
Patrick Dubroy | bbaa75c | 2011-03-08 18:47:40 -0800 | [diff] [blame] | 110 | /** |
Kenny Guy | c2bd810 | 2014-06-30 12:30:31 +0100 | [diff] [blame] | 111 | * Content description of the item. |
| 112 | */ |
Kenny Guy | d6fe526 | 2014-07-21 17:11:41 +0100 | [diff] [blame] | 113 | CharSequence contentDescription; |
Kenny Guy | c2bd810 | 2014-06-30 12:30:31 +0100 | [diff] [blame] | 114 | |
| 115 | /** |
Patrick Dubroy | bbaa75c | 2011-03-08 18:47:40 -0800 | [diff] [blame] | 116 | * The position of the item in a drag-and-drop operation. |
| 117 | */ |
| 118 | int[] dropPos = null; |
| 119 | |
Kenny Guy | ed13187 | 2014-04-30 03:02:21 +0100 | [diff] [blame] | 120 | UserHandleCompat user; |
| 121 | |
Michael Jurka | c9d95c5 | 2011-08-29 14:03:34 -0700 | [diff] [blame] | 122 | ItemInfo() { |
Kenny Guy | c2bd810 | 2014-06-30 12:30:31 +0100 | [diff] [blame] | 123 | user = UserHandleCompat.myUserHandle(); |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 124 | } |
| 125 | |
Michael Jurka | c9d95c5 | 2011-08-29 14:03:34 -0700 | [diff] [blame] | 126 | ItemInfo(ItemInfo info) { |
Sunny Goyal | ff57227 | 2014-07-23 13:58:07 -0700 | [diff] [blame] | 127 | copyFrom(info); |
| 128 | // tempdebug: |
| 129 | LauncherModel.checkItemInfo(this); |
| 130 | } |
| 131 | |
| 132 | public void copyFrom(ItemInfo info) { |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 133 | id = info.id; |
| 134 | cellX = info.cellX; |
| 135 | cellY = info.cellY; |
| 136 | spanX = info.spanX; |
| 137 | spanY = info.spanY; |
Adam Cohen | dcd297f | 2013-06-18 13:13:40 -0700 | [diff] [blame] | 138 | screenId = info.screenId; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 139 | itemType = info.itemType; |
| 140 | container = info.container; |
Kenny Guy | ed13187 | 2014-04-30 03:02:21 +0100 | [diff] [blame] | 141 | user = info.user; |
Kenny Guy | c2bd810 | 2014-06-30 12:30:31 +0100 | [diff] [blame] | 142 | contentDescription = info.contentDescription; |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 143 | } |
| 144 | |
Anjali Koppal | e3e646e | 2014-03-17 09:34:39 -0700 | [diff] [blame] | 145 | public Intent getIntent() { |
Winson Chung | 997a923 | 2013-07-24 15:33:46 -0700 | [diff] [blame] | 146 | throw new RuntimeException("Unexpected Intent"); |
| 147 | } |
| 148 | |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 149 | /** |
| 150 | * Write the fields of this item to the DB |
| 151 | * |
Kenny Guy | ed13187 | 2014-04-30 03:02:21 +0100 | [diff] [blame] | 152 | * @param context A context object to use for getting UserManagerCompat |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 153 | * @param values |
| 154 | */ |
Kenny Guy | ed13187 | 2014-04-30 03:02:21 +0100 | [diff] [blame] | 155 | |
| 156 | void onAddToDatabase(Context context, ContentValues values) { |
Romain Guy | 73b979d | 2009-06-09 12:57:21 -0700 | [diff] [blame] | 157 | values.put(LauncherSettings.BaseLauncherColumns.ITEM_TYPE, itemType); |
Adam Cohen | 487f7dd | 2012-06-28 18:12:10 -0700 | [diff] [blame] | 158 | values.put(LauncherSettings.Favorites.CONTAINER, container); |
Adam Cohen | dcd297f | 2013-06-18 13:13:40 -0700 | [diff] [blame] | 159 | values.put(LauncherSettings.Favorites.SCREEN, screenId); |
Adam Cohen | 487f7dd | 2012-06-28 18:12:10 -0700 | [diff] [blame] | 160 | values.put(LauncherSettings.Favorites.CELLX, cellX); |
| 161 | values.put(LauncherSettings.Favorites.CELLY, cellY); |
| 162 | values.put(LauncherSettings.Favorites.SPANX, spanX); |
| 163 | values.put(LauncherSettings.Favorites.SPANY, spanY); |
Kenny Guy | ed13187 | 2014-04-30 03:02:21 +0100 | [diff] [blame] | 164 | long serialNumber = UserManagerCompat.getInstance(context).getSerialNumberForUser(user); |
| 165 | values.put(LauncherSettings.Favorites.PROFILE_ID, serialNumber); |
Adrian Roos | 8f3f683 | 2014-04-28 15:45:52 +0200 | [diff] [blame] | 166 | |
| 167 | if (screenId == Workspace.EXTRA_EMPTY_SCREEN_ID) { |
| 168 | // We should never persist an item on the extra empty screen. |
| 169 | throw new RuntimeException("Screen id should not be EXTRA_EMPTY_SCREEN_ID"); |
| 170 | } |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 171 | } |
| 172 | |
Winson Chung | aafa03c | 2010-06-11 17:34:16 -0700 | [diff] [blame] | 173 | void updateValuesWithCoordinates(ContentValues values, int cellX, int cellY) { |
| 174 | values.put(LauncherSettings.Favorites.CELLX, cellX); |
| 175 | values.put(LauncherSettings.Favorites.CELLY, cellY); |
| 176 | } |
| 177 | |
Joe Onorato | 0589f0f | 2010-02-08 13:44:00 -0800 | [diff] [blame] | 178 | static byte[] flattenBitmap(Bitmap bitmap) { |
| 179 | // Try go guesstimate how much space the icon will take when serialized |
| 180 | // to avoid unnecessary allocations/copies during the write. |
| 181 | int size = bitmap.getWidth() * bitmap.getHeight() * 4; |
| 182 | ByteArrayOutputStream out = new ByteArrayOutputStream(size); |
| 183 | try { |
| 184 | bitmap.compress(Bitmap.CompressFormat.PNG, 100, out); |
| 185 | out.flush(); |
| 186 | out.close(); |
| 187 | return out.toByteArray(); |
| 188 | } catch (IOException e) { |
| 189 | Log.w("Favorite", "Could not write icon"); |
| 190 | return null; |
| 191 | } |
| 192 | } |
| 193 | |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 194 | static void writeBitmap(ContentValues values, Bitmap bitmap) { |
| 195 | if (bitmap != null) { |
Joe Onorato | 0589f0f | 2010-02-08 13:44:00 -0800 | [diff] [blame] | 196 | byte[] data = flattenBitmap(bitmap); |
| 197 | values.put(LauncherSettings.Favorites.ICON, data); |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 198 | } |
| 199 | } |
Adam Cohen | 4eac29a | 2011-07-11 17:53:37 -0700 | [diff] [blame] | 200 | |
| 201 | /** |
| 202 | * It is very important that sub-classes implement this if they contain any references |
| 203 | * to the activity (anything in the view hierarchy etc.). If not, leaks can result since |
| 204 | * ItemInfo objects persist across rotation and can hence leak by holding stale references |
| 205 | * to the old view hierarchy / activity. |
| 206 | */ |
Joe Onorato | 9c1289c | 2009-08-17 11:03:03 -0400 | [diff] [blame] | 207 | void unbind() { |
| 208 | } |
Daniel Sandler | 8802e96 | 2010-05-26 16:28:16 -0400 | [diff] [blame] | 209 | |
| 210 | @Override |
| 211 | public String toString() { |
Winson Chung | c07918d | 2011-07-01 15:35:26 -0700 | [diff] [blame] | 212 | return "Item(id=" + this.id + " type=" + this.itemType + " container=" + this.container |
Adam Cohen | dcd297f | 2013-06-18 13:13:40 -0700 | [diff] [blame] | 213 | + " screen=" + screenId + " cellX=" + cellX + " cellY=" + cellY + " spanX=" + spanX |
Kenny Guy | ed13187 | 2014-04-30 03:02:21 +0100 | [diff] [blame] | 214 | + " spanY=" + spanY + " dropPos=" + Arrays.toString(dropPos) |
| 215 | + " user=" + user + ")"; |
Daniel Sandler | 8802e96 | 2010-05-26 16:28:16 -0400 | [diff] [blame] | 216 | } |
The Android Open Source Project | 31dd503 | 2009-03-03 19:32:27 -0800 | [diff] [blame] | 217 | } |