RemoteViews.java revision 2dd2197805edb4d9547b143deef2226413218f4c
19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/*
29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project
39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License.
69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at
79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and
149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License.
159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.widget;
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.app.PendingIntent;
209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.Context;
21fa82f22f1d8c4c828bdf9b670006be4f4fec772eDianne Hackbornimport android.content.Intent;
22fa82f22f1d8c4c828bdf9b670006be4f4fec772eDianne Hackbornimport android.content.IntentSender;
239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.PackageManager.NameNotFoundException;
249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.Bitmap;
259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.PorterDuff;
267597065d6b0877ffc460b443fdb1595965ccd7b2Joe Onoratoimport android.graphics.Rect;
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.drawable.Drawable;
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.net.Uri;
29d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringertimport android.os.Bundle;
309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.Parcel;
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.Parcelable;
329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.text.TextUtils;
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.util.Log;
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.LayoutInflater;
359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.RemotableViewMethod;
369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.View;
379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.ViewGroup;
389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.LayoutInflater.Filter;
399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.View.OnClickListener;
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.lang.annotation.ElementType;
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.lang.annotation.Retention;
439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.lang.annotation.RetentionPolicy;
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.lang.annotation.Target;
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.lang.reflect.Method;
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.util.ArrayList;
479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * A class that describes a view hierarchy that can be displayed in
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * another process. The hierarchy is inflated from a layout resource
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * file, and this class provides some basic operations for modifying
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the content of the inflated hierarchy.
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic class RemoteViews implements Parcelable, Filter {
569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private static final String LOG_TAG = "RemoteViews";
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * The package name of the package containing the layout
619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * resource. (Added to the parcel)
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
633030193dc179b3010f2dd3bffe9c1dec54da38fcGilles Debunne    private final String mPackage;
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * The resource ID of the layout file. (Added to the parcel)
679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
683030193dc179b3010f2dd3bffe9c1dec54da38fcGilles Debunne    private final int mLayoutId;
69a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * An array of actions to perform on the view tree once it has been
729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * inflated
739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private ArrayList<Action> mActions;
759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * This annotation indicates that a subclass of View is alllowed to be used
79a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy     * with the {@link RemoteViews} mechanism.
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    @Target({ ElementType.TYPE })
829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    @Retention(RetentionPolicy.RUNTIME)
839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public @interface RemoteView {
849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Exception to send when something goes wrong executing an action
889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static class ActionException extends RuntimeException {
919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public ActionException(Exception ex) {
929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super(ex);
939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public ActionException(String message) {
959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            super(message);
969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Base class for all actions that can be performed on an
1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * inflated view.
1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10318e69dfc7235f8a4bfe257f9d1c43539049a22ceJoe Onorato     *  SUBCLASSES MUST BE IMMUTABLE SO CLONE WORKS!!!!!
1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private abstract static class Action implements Parcelable {
1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public abstract void apply(View root) throws ActionException;
1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public int describeContents() {
1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return 0;
1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
111a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy    }
1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling
1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link android.view.View#setOnClickListener(android.view.View.OnClickListener)}
1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * to launch the provided {@link PendingIntent}.
1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private class SetOnClickPendingIntent extends Action {
1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public SetOnClickPendingIntent(int id, PendingIntent pendingIntent) {
1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.viewId = id;
1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.pendingIntent = pendingIntent;
1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public SetOnClickPendingIntent(Parcel parcel) {
1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            viewId = parcel.readInt();
1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            pendingIntent = PendingIntent.readPendingIntentOrNullFromParcel(parcel);
1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void writeToParcel(Parcel dest, int flags) {
1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            dest.writeInt(TAG);
1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            dest.writeInt(viewId);
1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            pendingIntent.writeToParcel(dest, 0 /* no flags */);
1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void apply(View root) {
1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            final View target = root.findViewById(viewId);
1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (target != null && pendingIntent != null) {
1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                OnClickListener listener = new OnClickListener() {
1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    public void onClick(View v) {
141a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                        // Find target view location in screen coordinates and
142a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                        // fill into PendingIntent before sending.
143a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                        final float appScale = v.getContext().getResources()
144a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                                .getCompatibilityInfo().applicationScale;
145a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                        final int[] pos = new int[2];
1467597065d6b0877ffc460b443fdb1595965ccd7b2Joe Onorato                        v.getLocationOnScreen(pos);
147a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey
148a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                        final Rect rect = new Rect();
149a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                        rect.left = (int) (pos[0] * appScale + 0.5f);
150a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                        rect.top = (int) (pos[1] * appScale + 0.5f);
151a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                        rect.right = (int) ((pos[0] + v.getWidth()) * appScale + 0.5f);
152a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                        rect.bottom = (int) ((pos[1] + v.getHeight()) * appScale + 0.5f);
153a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey
154a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                        final Intent intent = new Intent();
155a503f6f7cf09c64bde708e3bcfb7103378ddfcffJeff Sharkey                        intent.setSourceBounds(rect);
1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        try {
1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                            // TODO: Unregister this handler if PendingIntent.FLAG_ONE_SHOT?
158fa82f22f1d8c4c828bdf9b670006be4f4fec772eDianne Hackborn                            v.getContext().startIntentSender(
1597597065d6b0877ffc460b443fdb1595965ccd7b2Joe Onorato                                    pendingIntent.getIntentSender(), intent,
160fa82f22f1d8c4c828bdf9b670006be4f4fec772eDianne Hackborn                                    Intent.FLAG_ACTIVITY_NEW_TASK,
161fa82f22f1d8c4c828bdf9b670006be4f4fec772eDianne Hackborn                                    Intent.FLAG_ACTIVITY_NEW_TASK, 0);
162fa82f22f1d8c4c828bdf9b670006be4f4fec772eDianne Hackborn                        } catch (IntentSender.SendIntentException e) {
163995d8561a6f6dee9f7b032bb2c3d78d885ba1e56Romain Guy                            android.util.Log.e(LOG_TAG, "Cannot send pending intent: ", e);
1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        }
1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    }
1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                };
1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                target.setOnClickListener(listener);
1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        int viewId;
1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        PendingIntent pendingIntent;
1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public final static int TAG = 1;
1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling a combination of {@link Drawable#setAlpha(int)},
1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link Drawable#setColorFilter(int, android.graphics.PorterDuff.Mode)},
1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * and/or {@link Drawable#setLevel(int)} on the {@link Drawable} of a given view.
1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p>
1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * These operations will be performed on the {@link Drawable} returned by the
1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * target {@link View#getBackground()} by default.  If targetBackground is false,
1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * we assume the target is an {@link ImageView} and try applying the operations
1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * to {@link ImageView#getDrawable()}.
1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p>
1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * You can omit specific calls by marking their values with null or -1.
1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private class SetDrawableParameters extends Action {
1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public SetDrawableParameters(int id, boolean targetBackground, int alpha,
1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int colorFilter, PorterDuff.Mode mode, int level) {
1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.viewId = id;
1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.targetBackground = targetBackground;
1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.alpha = alpha;
1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.colorFilter = colorFilter;
1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.filterMode = mode;
1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.level = level;
1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public SetDrawableParameters(Parcel parcel) {
2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            viewId = parcel.readInt();
2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            targetBackground = parcel.readInt() != 0;
2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            alpha = parcel.readInt();
2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            colorFilter = parcel.readInt();
2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            boolean hasMode = parcel.readInt() != 0;
2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (hasMode) {
2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                filterMode = PorterDuff.Mode.valueOf(parcel.readString());
2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            } else {
2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                filterMode = null;
2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            level = parcel.readInt();
2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void writeToParcel(Parcel dest, int flags) {
2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            dest.writeInt(TAG);
2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            dest.writeInt(viewId);
2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            dest.writeInt(targetBackground ? 1 : 0);
2189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            dest.writeInt(alpha);
2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            dest.writeInt(colorFilter);
2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (filterMode != null) {
2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                dest.writeInt(1);
2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                dest.writeString(filterMode.toString());
2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            } else {
2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                dest.writeInt(0);
2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            dest.writeInt(level);
2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void apply(View root) {
2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            final View target = root.findViewById(viewId);
2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (target == null) {
2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                return;
2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // Pick the correct drawable to modify for this view
2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Drawable targetDrawable = null;
2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (targetBackground) {
2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                targetDrawable = target.getBackground();
2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            } else if (target instanceof ImageView) {
2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                ImageView imageView = (ImageView) target;
2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                targetDrawable = imageView.getDrawable();
2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
245a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy            if (targetDrawable != null) {
246a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                // Perform modifications only if values are set correctly
247a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                if (alpha != -1) {
248a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                    targetDrawable.setAlpha(alpha);
249a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                }
250a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                if (colorFilter != -1 && filterMode != null) {
251a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                    targetDrawable.setColorFilter(colorFilter, filterMode);
252a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                }
253a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                if (level != -1) {
254a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                    targetDrawable.setLevel(level);
255a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                }
2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        int viewId;
2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        boolean targetBackground;
2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        int alpha;
2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        int colorFilter;
2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        PorterDuff.Mode filterMode;
2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        int level;
2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public final static int TAG = 3;
2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2692dd2197805edb4d9547b143deef2226413218f4cAdam Cohen    private class ReflectionActionWithoutParams extends Action {
2702dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        int viewId;
2712dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        String methodName;
2722dd2197805edb4d9547b143deef2226413218f4cAdam Cohen
2732dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        public final static int TAG = 5;
2742dd2197805edb4d9547b143deef2226413218f4cAdam Cohen
2752dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        ReflectionActionWithoutParams(int viewId, String methodName) {
2762dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            this.viewId = viewId;
2772dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            this.methodName = methodName;
2782dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        }
2792dd2197805edb4d9547b143deef2226413218f4cAdam Cohen
2802dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        ReflectionActionWithoutParams(Parcel in) {
2812dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            this.viewId = in.readInt();
2822dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            this.methodName = in.readString();
2832dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        }
2842dd2197805edb4d9547b143deef2226413218f4cAdam Cohen
2852dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        public void writeToParcel(Parcel out, int flags) {
2862dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            out.writeInt(TAG);
2872dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            out.writeInt(this.viewId);
2882dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            out.writeString(this.methodName);
2892dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        }
2902dd2197805edb4d9547b143deef2226413218f4cAdam Cohen
2912dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        @Override
2922dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        public void apply(View root) {
2932dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            final View view = root.findViewById(viewId);
2942dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            if (view == null) {
2952dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                throw new ActionException("can't find view: 0x" + Integer.toHexString(viewId));
2962dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            }
2972dd2197805edb4d9547b143deef2226413218f4cAdam Cohen
2982dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            Class klass = view.getClass();
2992dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            Method method;
3002dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            try {
3012dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                method = klass.getMethod(this.methodName);
3022dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            } catch (NoSuchMethodException ex) {
3032dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                throw new ActionException("view: " + klass.getName() + " doesn't have method: "
3042dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                        + this.methodName + "()");
3052dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            }
3062dd2197805edb4d9547b143deef2226413218f4cAdam Cohen
3072dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            if (!method.isAnnotationPresent(RemotableViewMethod.class)) {
3082dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                throw new ActionException("view: " + klass.getName()
3092dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                        + " can't use method with RemoteViews: "
3102dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                        + this.methodName + "()");
3112dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            }
3122dd2197805edb4d9547b143deef2226413218f4cAdam Cohen
3132dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            try {
3142dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                //noinspection ConstantIfStatement
3152dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                if (false) {
3162dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                    Log.d("RemoteViews", "view: " + klass.getName() + " calling method: "
3172dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                        + this.methodName + "()");
3182dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                }
3192dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                method.invoke(view);
3202dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            } catch (Exception ex) {
3212dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                throw new ActionException(ex);
3222dd2197805edb4d9547b143deef2226413218f4cAdam Cohen            }
3232dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        }
3242dd2197805edb4d9547b143deef2226413218f4cAdam Cohen    }
3252dd2197805edb4d9547b143deef2226413218f4cAdam Cohen
3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Base class for the reflection actions.
3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private class ReflectionAction extends Action {
3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int TAG = 2;
3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int BOOLEAN = 1;
3339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int BYTE = 2;
3349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int SHORT = 3;
3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int INT = 4;
3369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int LONG = 5;
3379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int FLOAT = 6;
3389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int DOUBLE = 7;
3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int CHAR = 8;
3409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int STRING = 9;
3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int CHAR_SEQUENCE = 10;
3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int URI = 11;
3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        static final int BITMAP = 12;
344d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert        static final int BUNDLE = 13;
345499cb9f516062b654952d282f211bee44c31a3c2Winson Chung        static final int INTENT = 14;
3469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        int viewId;
3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        String methodName;
3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        int type;
3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Object value;
3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        ReflectionAction(int viewId, String methodName, int type, Object value) {
3539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.viewId = viewId;
3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.methodName = methodName;
3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.type = type;
3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.value = value;
3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        ReflectionAction(Parcel in) {
3609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.viewId = in.readInt();
3619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.methodName = in.readString();
3629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            this.type = in.readInt();
363a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy            //noinspection ConstantIfStatement
3649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (false) {
3659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                Log.d("RemoteViews", "read viewId=0x" + Integer.toHexString(this.viewId)
3669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + " methodName=" + this.methodName + " type=" + this.type);
3679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
3689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            switch (this.type) {
3699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case BOOLEAN:
3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = in.readInt() != 0;
3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case BYTE:
3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = in.readByte();
3749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
3759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case SHORT:
3769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = (short)in.readInt();
3779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case INT:
3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = in.readInt();
3809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
3819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case LONG:
3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = in.readLong();
3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case FLOAT:
3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = in.readFloat();
3869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
3879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case DOUBLE:
3889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = in.readDouble();
3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case CHAR:
3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = (char)in.readInt();
3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case STRING:
3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = in.readString();
3959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
3969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case CHAR_SEQUENCE:
3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = TextUtils.CHAR_SEQUENCE_CREATOR.createFromParcel(in);
3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case URI:
4009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = Uri.CREATOR.createFromParcel(in);
4019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case BITMAP:
4039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    this.value = Bitmap.CREATOR.createFromParcel(in);
4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
405d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert                case BUNDLE:
406d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert                    this.value = in.readBundle();
407d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert                    break;
408499cb9f516062b654952d282f211bee44c31a3c2Winson Chung                case INTENT:
409499cb9f516062b654952d282f211bee44c31a3c2Winson Chung                    this.value = Intent.CREATOR.createFromParcel(in);
410499cb9f516062b654952d282f211bee44c31a3c2Winson Chung                    break;
4119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                default:
4129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
4149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void writeToParcel(Parcel out, int flags) {
4179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            out.writeInt(TAG);
4189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            out.writeInt(this.viewId);
4199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            out.writeString(this.methodName);
4209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            out.writeInt(this.type);
421a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy            //noinspection ConstantIfStatement
4229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (false) {
4239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                Log.d("RemoteViews", "write viewId=0x" + Integer.toHexString(this.viewId)
4249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + " methodName=" + this.methodName + " type=" + this.type);
4259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
4269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            switch (this.type) {
4279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case BOOLEAN:
428a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                    out.writeInt((Boolean) this.value ? 1 : 0);
4299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case BYTE:
431a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                    out.writeByte((Byte) this.value);
4329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case SHORT:
434a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                    out.writeInt((Short) this.value);
4359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case INT:
437a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                    out.writeInt((Integer) this.value);
4389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case LONG:
440a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                    out.writeLong((Long) this.value);
4419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case FLOAT:
443a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                    out.writeFloat((Float) this.value);
4449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case DOUBLE:
446a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                    out.writeDouble((Double) this.value);
4479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case CHAR:
4499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    out.writeInt((int)((Character)this.value).charValue());
4509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case STRING:
4529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    out.writeString((String)this.value);
4539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case CHAR_SEQUENCE:
4559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    TextUtils.writeToParcel((CharSequence)this.value, out, flags);
4569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case URI:
4589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    ((Uri)this.value).writeToParcel(out, flags);
4599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case BITMAP:
4619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    ((Bitmap)this.value).writeToParcel(out, flags);
4629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
463d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert                case BUNDLE:
464d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert                    out.writeBundle((Bundle) this.value);
465d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert                    break;
466499cb9f516062b654952d282f211bee44c31a3c2Winson Chung                case INTENT:
467499cb9f516062b654952d282f211bee44c31a3c2Winson Chung                    ((Intent)this.value).writeToParcel(out, flags);
468499cb9f516062b654952d282f211bee44c31a3c2Winson Chung                    break;
4699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                default:
4709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
4719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
4729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
4739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private Class getParameterType() {
4759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            switch (this.type) {
4769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case BOOLEAN:
4779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return boolean.class;
4789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case BYTE:
4799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return byte.class;
4809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case SHORT:
4819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return short.class;
4829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case INT:
4839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return int.class;
4849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case LONG:
4859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return long.class;
4869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case FLOAT:
4879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return float.class;
4889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case DOUBLE:
4899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return double.class;
4909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case CHAR:
4919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return char.class;
4929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case STRING:
4939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return String.class;
4949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case CHAR_SEQUENCE:
4959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return CharSequence.class;
4969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case URI:
4979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return Uri.class;
4989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case BITMAP:
4999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return Bitmap.class;
500d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert                case BUNDLE:
501d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert                    return Bundle.class;
502499cb9f516062b654952d282f211bee44c31a3c2Winson Chung                case INTENT:
503499cb9f516062b654952d282f211bee44c31a3c2Winson Chung                    return Intent.class;
5049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                default:
5059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    return null;
5069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
5109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public void apply(View root) {
5119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            final View view = root.findViewById(viewId);
5129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (view == null) {
5139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                throw new ActionException("can't find view: 0x" + Integer.toHexString(viewId));
5149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Class param = getParameterType();
5179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (param == null) {
5189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                throw new ActionException("bad type: " + this.type);
5199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Class klass = view.getClass();
522a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy            Method method;
5239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            try {
5249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                method = klass.getMethod(this.methodName, getParameterType());
5259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            catch (NoSuchMethodException ex) {
5279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                throw new ActionException("view: " + klass.getName() + " doesn't have method: "
5289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + this.methodName + "(" + param.getName() + ")");
5299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (!method.isAnnotationPresent(RemotableViewMethod.class)) {
5329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                throw new ActionException("view: " + klass.getName()
5339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + " can't use method with RemoteViews: "
5349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + this.methodName + "(" + param.getName() + ")");
5359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            try {
538a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                //noinspection ConstantIfStatement
5399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                if (false) {
5409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    Log.d("RemoteViews", "view: " + klass.getName() + " calling method: "
5419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + this.methodName + "(" + param.getName() + ") with "
5429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        + (this.value == null ? "null" : this.value.getClass().getName()));
5439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                }
5449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                method.invoke(view, this.value);
5459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            catch (Exception ex) {
5479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                throw new ActionException(ex);
5489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5521162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey    /**
5531162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * Equivalent to calling {@link ViewGroup#addView(View)} after inflating the
5541162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * given {@link RemoteViews}, or calling {@link ViewGroup#removeAllViews()}
5551162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * when null. This allows users to build "nested" {@link RemoteViews}.
5561162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     */
5571162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey    private class ViewGroupAction extends Action {
5581162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        public ViewGroupAction(int viewId, RemoteViews nestedViews) {
5591162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            this.viewId = viewId;
5601162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            this.nestedViews = nestedViews;
5611162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        }
5621162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey
5631162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        public ViewGroupAction(Parcel parcel) {
5641162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            viewId = parcel.readInt();
5651162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            nestedViews = parcel.readParcelable(null);
5661162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        }
5671162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey
5681162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        public void writeToParcel(Parcel dest, int flags) {
5691162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            dest.writeInt(TAG);
5701162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            dest.writeInt(viewId);
5711162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            dest.writeParcelable(nestedViews, 0 /* no flags */);
5721162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        }
5731162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey
5741162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        @Override
5751162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        public void apply(View root) {
5761162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            final Context context = root.getContext();
5771162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            final ViewGroup target = (ViewGroup) root.findViewById(viewId);
5781162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            if (nestedViews != null) {
5791162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey                // Inflate nested views and add as children
5801162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey                target.addView(nestedViews.apply(context, target));
5811162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            } else if (target != null) {
5821162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey                // Clear all children when nested views omitted
5831162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey                target.removeAllViews();
5841162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey            }
5851162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        }
5861162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey
5871162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        int viewId;
5881162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        RemoteViews nestedViews;
5891162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey
5901162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        public final static int TAG = 4;
5911162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey    }
5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Create a new RemoteViews object that will display the views contained
5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * in the specified layout file.
5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param packageName Name of the package that contains the layout resource
5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param layoutId The id of the layout resource
5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public RemoteViews(String packageName, int layoutId) {
6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mPackage = packageName;
6029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mLayoutId = layoutId;
6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Reads a RemoteViews object from a parcel.
6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param parcel
6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public RemoteViews(Parcel parcel) {
6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mPackage = parcel.readString();
6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mLayoutId = parcel.readInt();
6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        int count = parcel.readInt();
6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (count > 0) {
6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mActions = new ArrayList<Action>(count);
6169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i=0; i<count; i++) {
6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int tag = parcel.readInt();
6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                switch (tag) {
6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case SetOnClickPendingIntent.TAG:
6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    mActions.add(new SetOnClickPendingIntent(parcel));
6219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
6229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case SetDrawableParameters.TAG:
6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    mActions.add(new SetDrawableParameters(parcel));
6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
6259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                case ReflectionAction.TAG:
6269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    mActions.add(new ReflectionAction(parcel));
6279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    break;
6281162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey                case ViewGroupAction.TAG:
6291162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey                    mActions.add(new ViewGroupAction(parcel));
6301162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey                    break;
6312dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                case ReflectionActionWithoutParams.TAG:
6322dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                    mActions.add(new ReflectionActionWithoutParams(parcel));
6332dd2197805edb4d9547b143deef2226413218f4cAdam Cohen                    break;
6349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                default:
6359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    throw new ActionException("Tag " + tag + " not found");
6369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                }
6379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
6389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6413030193dc179b3010f2dd3bffe9c1dec54da38fcGilles Debunne    @Override
64218e69dfc7235f8a4bfe257f9d1c43539049a22ceJoe Onorato    public RemoteViews clone() {
64318e69dfc7235f8a4bfe257f9d1c43539049a22ceJoe Onorato        final RemoteViews that = new RemoteViews(mPackage, mLayoutId);
64418e69dfc7235f8a4bfe257f9d1c43539049a22ceJoe Onorato        if (mActions != null) {
64518e69dfc7235f8a4bfe257f9d1c43539049a22ceJoe Onorato            that.mActions = (ArrayList<Action>)mActions.clone();
64618e69dfc7235f8a4bfe257f9d1c43539049a22ceJoe Onorato        }
64718e69dfc7235f8a4bfe257f9d1c43539049a22ceJoe Onorato        return that;
64818e69dfc7235f8a4bfe257f9d1c43539049a22ceJoe Onorato    }
64918e69dfc7235f8a4bfe257f9d1c43539049a22ceJoe Onorato
6509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public String getPackage() {
6519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mPackage;
6529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public int getLayoutId() {
6559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return mLayoutId;
6569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Add an action to be executed on the remote side when apply is called.
6609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
6619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param a The action to add
6629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private void addAction(Action a) {
6649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mActions == null) {
6659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            mActions = new ArrayList<Action>();
6669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        mActions.add(a);
6689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6691162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey
6701162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey    /**
6711162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * Equivalent to calling {@link ViewGroup#addView(View)} after inflating the
6721162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * given {@link RemoteViews}. This allows users to build "nested"
6731162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * {@link RemoteViews}. In cases where consumers of {@link RemoteViews} may
6741162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * recycle layouts, use {@link #removeAllViews(int)} to clear any existing
6751162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * children.
6761162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     *
6771162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * @param viewId The id of the parent {@link ViewGroup} to add child into.
6781162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * @param nestedView {@link RemoteViews} that describes the child.
6791162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     */
6801162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey    public void addView(int viewId, RemoteViews nestedView) {
6811162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        addAction(new ViewGroupAction(viewId, nestedView));
6821162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey    }
6831162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey
6841162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey    /**
6851162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * Equivalent to calling {@link ViewGroup#removeAllViews()}.
6861162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     *
6871162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     * @param viewId The id of the parent {@link ViewGroup} to remove all
6881162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     *            children from.
6891162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey     */
6901162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey    public void removeAllViews(int viewId) {
6911162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey        addAction(new ViewGroupAction(viewId, null));
6921162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey    }
6931162fd77a8ff8467c96204c00bcaf941aef6aa85Jeff Sharkey
6949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6952dd2197805edb4d9547b143deef2226413218f4cAdam Cohen     * Equivalent to calling {@link AdapterViewFlipper#showNext()}
6962dd2197805edb4d9547b143deef2226413218f4cAdam Cohen     *
6972dd2197805edb4d9547b143deef2226413218f4cAdam Cohen     * @param viewId The id of the view on which to call {@link AdapterViewFlipper#showNext()}
6982dd2197805edb4d9547b143deef2226413218f4cAdam Cohen     */
6992dd2197805edb4d9547b143deef2226413218f4cAdam Cohen    public void showNext(int viewId) {
7002dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        addAction(new ReflectionActionWithoutParams(viewId, "showNext"));
7012dd2197805edb4d9547b143deef2226413218f4cAdam Cohen    }
7022dd2197805edb4d9547b143deef2226413218f4cAdam Cohen
7032dd2197805edb4d9547b143deef2226413218f4cAdam Cohen    /**
7042dd2197805edb4d9547b143deef2226413218f4cAdam Cohen     * Equivalent to calling {@link AdapterViewFlipper#showPrevious()}
7052dd2197805edb4d9547b143deef2226413218f4cAdam Cohen     *
7062dd2197805edb4d9547b143deef2226413218f4cAdam Cohen     * @param viewId The id of the view on which to call {@link AdapterViewFlipper#showPrevious()}
7072dd2197805edb4d9547b143deef2226413218f4cAdam Cohen     */
7082dd2197805edb4d9547b143deef2226413218f4cAdam Cohen    public void showPrevious(int viewId) {
7092dd2197805edb4d9547b143deef2226413218f4cAdam Cohen        addAction(new ReflectionActionWithoutParams(viewId, "showPrevious"));
7102dd2197805edb4d9547b143deef2226413218f4cAdam Cohen    }
7112dd2197805edb4d9547b143deef2226413218f4cAdam Cohen
7122dd2197805edb4d9547b143deef2226413218f4cAdam Cohen    /**
7139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling View.setVisibility
7149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param viewId The id of the view whose visibility should change
7169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param visibility The new visibility for the view
7179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setViewVisibility(int viewId, int visibility) {
7199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setInt(viewId, "setVisibility", visibility);
7209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling TextView.setText
7249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param viewId The id of the view whose text should change
7269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param text The new text for the view
7279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setTextViewText(int viewId, CharSequence text) {
7299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setCharSequence(viewId, "setText", text);
7309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling ImageView.setImageResource
7349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param viewId The id of the view whose drawable should change
7369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param srcId The new resource id for the drawable
7379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setImageViewResource(int viewId, int srcId) {
7399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setInt(viewId, "setImageResource", srcId);
7409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling ImageView.setImageURI
7449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param viewId The id of the view whose drawable should change
7469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param uri The Uri for the image
7479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setImageViewUri(int viewId, Uri uri) {
7499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setUri(viewId, "setImageURI", uri);
7509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling ImageView.setImageBitmap
7549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param viewId The id of the view whose drawable should change
7569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param bitmap The new Bitmap for the drawable
7579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setImageViewBitmap(int viewId, Bitmap bitmap) {
7599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setBitmap(viewId, "setImageBitmap", bitmap);
7609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling {@link Chronometer#setBase Chronometer.setBase},
7649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link Chronometer#setFormat Chronometer.setFormat},
7659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * and {@link Chronometer#start Chronometer.start()} or
7669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link Chronometer#stop Chronometer.stop()}.
7679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param viewId The id of the view whose text should change
7699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param base The time at which the timer would have read 0:00.  This
7709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *             time should be based off of
7719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *             {@link android.os.SystemClock#elapsedRealtime SystemClock.elapsedRealtime()}.
7729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param format The Chronometer format string, or null to
7739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *               simply display the timer value.
7749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param started True if you want the clock to be started, false if not.
7759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setChronometer(int viewId, long base, String format, boolean started) {
7779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setLong(viewId, "setBase", base);
7789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setString(viewId, "setFormat", format);
7799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setBoolean(viewId, "setStarted", started);
7809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling {@link ProgressBar#setMax ProgressBar.setMax},
7849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link ProgressBar#setProgress ProgressBar.setProgress}, and
7859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link ProgressBar#setIndeterminate ProgressBar.setIndeterminate}
7869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * If indeterminate is true, then the values for max and progress are ignored.
7889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
7899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param viewId The id of the view whose text should change
7909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param max The 100% value for the progress bar
7919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param progress The current value of the progress bar.
7929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param indeterminate True if the progress bar is indeterminate,
7939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *                false if not.
7949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setProgressBar(int viewId, int max, int progress,
7969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            boolean indeterminate) {
7979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setBoolean(viewId, "setIndeterminate", indeterminate);
7989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (!indeterminate) {
7999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            setInt(viewId, "setMax", max);
8009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            setInt(viewId, "setProgress", progress);
8019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
8029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
8039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling
8069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link android.view.View#setOnClickListener(android.view.View.OnClickListener)}
8079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * to launch the provided {@link PendingIntent}.
8089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param viewId The id of the view that will trigger the {@link PendingIntent} when clicked
8109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param pendingIntent The {@link PendingIntent} to send when user clicks
8119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setOnClickPendingIntent(int viewId, PendingIntent pendingIntent) {
8139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new SetOnClickPendingIntent(viewId, pendingIntent));
8149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
8159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @hide
8189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling a combination of {@link Drawable#setAlpha(int)},
8199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link Drawable#setColorFilter(int, android.graphics.PorterDuff.Mode)},
8209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * and/or {@link Drawable#setLevel(int)} on the {@link Drawable} of a given
8219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * view.
8229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p>
8239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * You can omit specific calls by marking their values with null or -1.
8249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param viewId The id of the view that contains the target
8269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            {@link Drawable}
8279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param targetBackground If true, apply these parameters to the
8289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            {@link Drawable} returned by
8299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            {@link android.view.View#getBackground()}. Otherwise, assume
8309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            the target view is an {@link ImageView} and apply them to
8319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            {@link ImageView#getDrawable()}.
8329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param alpha Specify an alpha value for the drawable, or -1 to leave
8339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            unchanged.
8349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param colorFilter Specify a color for a
8359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            {@link android.graphics.ColorFilter} for this drawable, or -1
8369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            to leave unchanged.
8379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param mode Specify a PorterDuff mode for this drawable, or null to leave
8389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            unchanged.
8399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param level Specify the level for the drawable, or -1 to leave
8409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            unchanged.
8419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setDrawableParameters(int viewId, boolean targetBackground, int alpha,
8439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            int colorFilter, PorterDuff.Mode mode, int level) {
8449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new SetDrawableParameters(viewId, targetBackground, alpha,
8459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                colorFilter, mode, level));
8469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
8479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Equivalent to calling {@link android.widget.TextView#setTextColor(int)}.
8509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
8519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param viewId The id of the view whose text should change
8529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param color Sets the text color for all the states (normal, selected,
8539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            focused) to be this color.
8549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setTextColor(int viewId, int color) {
8569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        setInt(viewId, "setTextColor", color);
8579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
8589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
859592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
860499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     * Equivalent to calling {@link android.widget.AbsListView#setRemoteViewsAdapter(Intent)}.
861499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     *
862499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     * @param viewId The id of the view whose text should change
863499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     * @param intent The intent of the service which will be
864499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     *            providing data to the RemoteViewsAdapter
865499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     */
866499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    public void setRemoteAdapter(int viewId, Intent intent) {
867499cb9f516062b654952d282f211bee44c31a3c2Winson Chung        setIntent(viewId, "setRemoteViewsAdapter", intent);
868499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    }
869499cb9f516062b654952d282f211bee44c31a3c2Winson Chung
870499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    /**
871499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     * Equivalent to calling {@link android.widget.AbsListView#smoothScrollToPosition(int, int)}.
872499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     *
873499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     * @param viewId The id of the view whose text should change
874499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     * @param position Scroll to this adapter position
875499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     */
876499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    public void setScrollPosition(int viewId, int position) {
877499cb9f516062b654952d282f211bee44c31a3c2Winson Chung        setInt(viewId, "smoothScrollToPosition", position);
878499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    }
879499cb9f516062b654952d282f211bee44c31a3c2Winson Chung
880499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    /**
881499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     * Equivalent to calling {@link android.widget.AbsListView#smoothScrollToPosition(int, int)}.
882499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     *
883499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     * @param viewId The id of the view whose text should change
88495362595ed4a42aec87b4d166092b30c8139d220Winson Chung     * @param offset Scroll by this adapter position offset
885499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     */
886499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    public void setRelativeScrollPosition(int viewId, int offset) {
887499cb9f516062b654952d282f211bee44c31a3c2Winson Chung        setInt(viewId, "smoothScrollByOffset", offset);
888499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    }
889499cb9f516062b654952d282f211bee44c31a3c2Winson Chung
890499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    /**
891592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one boolean on a view in the layout for this RemoteViews.
892592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
893592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
894592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
895592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
896592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
8979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setBoolean(int viewId, String methodName, boolean value) {
8989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.BOOLEAN, value));
8999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
901592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
902592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one byte on a view in the layout for this RemoteViews.
903592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
904592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
905592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
906592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
907592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
9089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setByte(int viewId, String methodName, byte value) {
9099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.BYTE, value));
9109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
912592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
913592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one short on a view in the layout for this RemoteViews.
914592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
915592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
916592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
917592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
918592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
9199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setShort(int viewId, String methodName, short value) {
9209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.SHORT, value));
9219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
923592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
924592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one int on a view in the layout for this RemoteViews.
925592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
926592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
927592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
928592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
929592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
9309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setInt(int viewId, String methodName, int value) {
9319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.INT, value));
9329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
934592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
935592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one long on a view in the layout for this RemoteViews.
936592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
937592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
938592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
939592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
940592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
9419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setLong(int viewId, String methodName, long value) {
9429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.LONG, value));
9439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
945592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
946592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one float on a view in the layout for this RemoteViews.
947592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
948592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
949592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
950592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
951592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
9529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setFloat(int viewId, String methodName, float value) {
9539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.FLOAT, value));
9549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
956592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
957592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one double on a view in the layout for this RemoteViews.
958592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
959592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
960592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
961592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
962592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
9639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setDouble(int viewId, String methodName, double value) {
9649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.DOUBLE, value));
9659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
967592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
968592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one char on a view in the layout for this RemoteViews.
969592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
970592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
971592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
972592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
973592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
9749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setChar(int viewId, String methodName, char value) {
9759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.CHAR, value));
9769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
978592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
979592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one String on a view in the layout for this RemoteViews.
980592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
981592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
982592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
983592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
984592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
9859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setString(int viewId, String methodName, String value) {
9869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.STRING, value));
9879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
989592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
990592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one CharSequence on a view in the layout for this RemoteViews.
991592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
992592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
993592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
994592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
995592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
9969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setCharSequence(int viewId, String methodName, CharSequence value) {
9979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.CHAR_SEQUENCE, value));
9989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
9999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1000592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
1001592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one Uri on a view in the layout for this RemoteViews.
1002592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
1003592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
1004592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
1005592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
1006592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
10079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setUri(int viewId, String methodName, Uri value) {
10089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.URI, value));
10099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
10109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1011592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato    /**
1012592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * Call a method taking one Bitmap on a view in the layout for this RemoteViews.
1013592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @more
1014592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * <p class="note">The bitmap will be flattened into the parcel if this object is
1015592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * sent across processes, so it may end up using a lot of memory, and may be fairly slow.</p>
1016592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     *
1017592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param viewId The id of the view whose text should change
1018592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param methodName The name of the method to call.
1019592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     * @param value The value to pass to the method.
1020592d0650d5bfc673082c4e58ac8ba2dc3103c842Joe Onorato     */
10219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setBitmap(int viewId, String methodName, Bitmap value) {
10229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.BITMAP, value));
10239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
10249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1026d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert     * Call a method taking one Bundle on a view in the layout for this RemoteViews.
1027d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert     *
1028d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert     * @param viewId The id of the view whose text should change
1029d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert     * @param methodName The name of the method to call.
1030d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert     * @param value The value to pass to the method.
1031d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert     */
1032d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert    public void setBundle(int viewId, String methodName, Bundle value) {
1033d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.BUNDLE, value));
1034d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert    }
1035d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert
1036d755b06805dd3ed4dc6c08ff1750e28543901854Bjorn Bringert    /**
1037499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     *
1038499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     * @param viewId
1039499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     * @param methodName
1040499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     * @param value
1041499cb9f516062b654952d282f211bee44c31a3c2Winson Chung     */
1042499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    public void setIntent(int viewId, String methodName, Intent value) {
1043499cb9f516062b654952d282f211bee44c31a3c2Winson Chung        addAction(new ReflectionAction(viewId, methodName, ReflectionAction.INTENT, value));
1044499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    }
1045499cb9f516062b654952d282f211bee44c31a3c2Winson Chung
1046499cb9f516062b654952d282f211bee44c31a3c2Winson Chung    /**
10479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Inflates the view hierarchy represented by this object and applies
10489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * all of the actions.
10499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p><strong>Caller beware: this may throw</strong>
10519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param context Default context to use
10539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param parent Parent that the resulting view hierarchy will be attached to. This method
10549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * does <strong>not</strong> attach the hierarchy. The caller should do so when appropriate.
10559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return The inflated view hierarchy
10569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public View apply(Context context, ViewGroup parent) {
1058a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy        View result;
10599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Context c = prepareContext(context);
10619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1062a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy        LayoutInflater inflater = (LayoutInflater)
1063a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy                c.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
10649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        inflater = inflater.cloneInContext(c);
10669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        inflater.setFilter(this);
10679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        result = inflater.inflate(mLayoutId, parent, false);
10699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        performApply(result);
10719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return result;
10739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
10749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Applies all of the actions to the provided view.
10779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p><strong>Caller beware: this may throw</strong>
10799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param v The view to apply the actions to.  This should be the result of
10819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the {@link #apply(Context,ViewGroup)} call.
10829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void reapply(Context context, View v) {
10849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        prepareContext(context);
10859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        performApply(v);
10869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
10879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private void performApply(View v) {
10899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mActions != null) {
10909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            final int count = mActions.size();
10919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < count; i++) {
10929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                Action a = mActions.get(i);
10939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                a.apply(v);
10949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
10959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
10969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
10979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private Context prepareContext(Context context) {
1099a54755962ca7725d1e2b6cacbbaece6f1cbf5af4Romain Guy        Context c;
11009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        String packageName = mPackage;
11019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (packageName != null) {
11039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            try {
1104870e09fcd2dfdc12ac318962efd28b0420c562bbRomain Guy                c = context.createPackageContext(packageName, Context.CONTEXT_RESTRICTED);
11059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            } catch (NameNotFoundException e) {
11069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                Log.e(LOG_TAG, "Package name " + packageName + " not found");
11079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                c = context;
11089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
11099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        } else {
11109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            c = context;
11119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
11129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return c;
11149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
11159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /* (non-Javadoc)
11179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Used to restrict the views which can be inflated
11189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
11199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see android.view.LayoutInflater.Filter#onLoadClass(java.lang.Class)
11209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1121e6ac8b9aade9443ab8456c8f7a47cdfba3b70266Gilles Debunne    public boolean onLoadClass(Class clazz) {
11229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return clazz.isAnnotationPresent(RemoteView.class);
11239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
11249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public int describeContents() {
11269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return 0;
11279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
11289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void writeToParcel(Parcel dest, int flags) {
11309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        dest.writeString(mPackage);
11319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        dest.writeInt(mLayoutId);
11329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        int count;
11339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (mActions != null) {
11349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            count = mActions.size();
11359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        } else {
11369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            count = 0;
11379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
11389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        dest.writeInt(count);
11399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        for (int i=0; i<count; i++) {
11409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Action a = mActions.get(i);
11419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            a.writeToParcel(dest, 0);
11429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
11439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
11449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
11469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Parcelable.Creator that instantiates RemoteViews objects
11479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
11489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final Parcelable.Creator<RemoteViews> CREATOR = new Parcelable.Creator<RemoteViews>() {
11499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public RemoteViews createFromParcel(Parcel parcel) {
11509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return new RemoteViews(parcel);
11519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
11529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public RemoteViews[] newArray(int size) {
11549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return new RemoteViews[size];
11559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
11569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    };
11579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
1158