LauncherAppWidgetInfo.java revision 7b168a1bb94044d9ae11004bae18beba9eed46fd
131dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project/*
231dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project * Copyright (C) 2009 The Android Open Source Project
331dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project *
431dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
531dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project * you may not use this file except in compliance with the License.
631dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project * You may obtain a copy of the License at
731dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project *
831dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
931dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project *
1031dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
1131dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
1231dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1331dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project * See the License for the specific language governing permissions and
1431dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project * limitations under the License.
1531dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project */
1631dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project
17325dc23624160689e59fbac708cf6f222b20d025Daniel Sandlerpackage com.android.launcher3;
1831dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project
197376faefbbcbe30cc4e3f706ab95c254a4707d98The Android Open Source Projectimport android.appwidget.AppWidgetHostView;
20af44209bfa60da3c7ab49b7f508f9effd316ee41Michael Jurkaimport android.content.ComponentName;
2131dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Projectimport android.content.ContentValues;
2231dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project
2331dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project/**
246569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy * Represents a widget (either instantiated or about to be) in the Launcher.
2531dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project */
267b168a1bb94044d9ae11004bae18beba9eed46fdAnjali Koppalpublic class LauncherAppWidgetInfo extends ItemInfo {
2731dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project
2831dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project    /**
296569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy     * Indicates that the widget hasn't been instantiated yet.
306569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy     */
316569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy    static final int NO_ID = -1;
326569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy
336569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy    /**
34629de3ef739883c0962423cc0c3a26299f162d3dRomain Guy     * Identifier for this widget when talking with
35629de3ef739883c0962423cc0c3a26299f162d3dRomain Guy     * {@link android.appwidget.AppWidgetManager} for updates.
3631dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project     */
376569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy    int appWidgetId = NO_ID;
386569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy
39af44209bfa60da3c7ab49b7f508f9effd316ee41Michael Jurka    ComponentName providerName;
40ded9f8d8658d0b6601006c0a954cd3bf530e55c1Adam Cohen
416569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy    // TODO: Are these necessary here?
426569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy    int minWidth = -1;
436569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy    int minHeight = -1;
446569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy
45211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung    private boolean mHasNotifiedInitialWidgetSizeChanged;
46211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung
4731dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project    /**
487376faefbbcbe30cc4e3f706ab95c254a4707d98The Android Open Source Project     * View that holds this widget after it's been created.  This view isn't created
4931dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project     * until Launcher knows it's needed.
5031dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project     */
517376faefbbcbe30cc4e3f706ab95c254a4707d98The Android Open Source Project    AppWidgetHostView hostView = null;
5231dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project
5311a4937fbff0dbc50fb022513dc3b6c643154445Winson Chung    LauncherAppWidgetInfo(int appWidgetId, ComponentName providerName) {
546569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy        itemType = LauncherSettings.Favorites.ITEM_TYPE_APPWIDGET;
5511a4937fbff0dbc50fb022513dc3b6c643154445Winson Chung        this.appWidgetId = appWidgetId;
566569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy        this.providerName = providerName;
576569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy
586569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy        // Since the widget isn't instantiated yet, we don't know these values. Set them to -1
596569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy        // to indicate that they should be calculated based on the layout and minWidth/minHeight
606569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy        spanX = -1;
616569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy        spanY = -1;
626569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy    }
636569f2c80e179c2f8ed73dae6b01d971ec20f005Patrick Dubroy
6431dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project    @Override
6531dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project    void onAddToDatabase(ContentValues values) {
6631dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project        super.onAddToDatabase(values);
677376faefbbcbe30cc4e3f706ab95c254a4707d98The Android Open Source Project        values.put(LauncherSettings.Favorites.APPWIDGET_ID, appWidgetId);
68d5e66bfca1dc4fdbab7513d88c6568bc4d17bca8Chris Wren        values.put(LauncherSettings.Favorites.APPWIDGET_PROVIDER, providerName.flattenToString());
6931dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project    }
7031dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project
71211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung    /**
72211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung     * When we bind the widget, we should notify the widget that the size has changed if we have not
73211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung     * done so already (only really for default workspace widgets).
74211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung     */
75211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung    void onBindAppWidget(Launcher launcher) {
76aaa5c21ee2e03def644fb6ba8eadbb59873ddd45Adam Cohen        if (!mHasNotifiedInitialWidgetSizeChanged) {
77211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung            notifyWidgetSizeChanged(launcher);
78211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung        }
79211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung    }
80211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung
81211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung    /**
82211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung     * Trigger an update callback to the widget to notify it that its size has changed.
83211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung     */
84211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung    void notifyWidgetSizeChanged(Launcher launcher) {
85211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung        AppWidgetResizeFrame.updateWidgetSizeRanges(hostView, launcher, spanX, spanY);
86211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung        mHasNotifiedInitialWidgetSizeChanged = true;
87211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung    }
88211bac3cd89b26bda4ff52df984731d11156dc38Winson Chung
8931dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project    @Override
9031dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project    public String toString() {
918802e960495e61803c18ea3dda2e30ef0a611d8fDaniel Sandler        return "AppWidget(id=" + Integer.toString(appWidgetId) + ")";
9231dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project    }
939c1289cb3bfb74f86e53ec7ac6dd76bb39666b2dJoe Onorato
949c1289cb3bfb74f86e53ec7ac6dd76bb39666b2dJoe Onorato    @Override
959c1289cb3bfb74f86e53ec7ac6dd76bb39666b2dJoe Onorato    void unbind() {
969c1289cb3bfb74f86e53ec7ac6dd76bb39666b2dJoe Onorato        super.unbind();
979c1289cb3bfb74f86e53ec7ac6dd76bb39666b2dJoe Onorato        hostView = null;
989c1289cb3bfb74f86e53ec7ac6dd76bb39666b2dJoe Onorato    }
9931dd503c6aa69018e694d91724d46db49ea09327The Android Open Source Project}
100