/** * Copyright (C) 2015 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.settingslib.drawer; import android.content.Intent; import android.graphics.drawable.Icon; import android.os.Bundle; import android.os.Parcel; import android.os.Parcelable; import android.os.UserHandle; import android.text.TextUtils; import android.widget.RemoteViews; import java.util.ArrayList; /** * Description of a single dashboard tile that the user can select. */ public class Tile implements Parcelable { /** * Title of the tile that is shown to the user. * @attr ref android.R.styleable#PreferenceHeader_title */ public CharSequence title; /** * Optional summary describing what this tile controls. * @attr ref android.R.styleable#PreferenceHeader_summary */ public CharSequence summary; /** * Optional icon to show for this tile. * @attr ref android.R.styleable#PreferenceHeader_icon */ public Icon icon; /** * Whether the icon can be tinted. This should be set to true for monochrome (single-color) * icons that can be tinted to match the design. */ public boolean isIconTintable; /** * Intent to launch when the preference is selected. */ public Intent intent; /** * Optional list of user handles which the intent should be launched on. */ public ArrayList userHandle = new ArrayList<>(); /** * Optional additional data for use by subclasses of the activity */ public Bundle extras; /** * Category in which the tile should be placed. */ public String category; /** * Priority of the intent filter that created this tile, used for display ordering. */ public int priority; /** * The metaData from the activity that defines this tile. */ public Bundle metaData; /** * Optional key to use for this tile. */ public String key; /** * Optional remote view which will be displayed instead of the regular title-summary item. */ public RemoteViews remoteViews; public Tile() { // Empty } @Override public int describeContents() { return 0; } @Override public void writeToParcel(Parcel dest, int flags) { TextUtils.writeToParcel(title, dest, flags); TextUtils.writeToParcel(summary, dest, flags); if (icon != null) { dest.writeByte((byte) 1); icon.writeToParcel(dest, flags); } else { dest.writeByte((byte) 0); } if (intent != null) { dest.writeByte((byte) 1); intent.writeToParcel(dest, flags); } else { dest.writeByte((byte) 0); } final int N = userHandle.size(); dest.writeInt(N); for (int i = 0; i < N; i++) { userHandle.get(i).writeToParcel(dest, flags); } dest.writeBundle(extras); dest.writeString(category); dest.writeInt(priority); dest.writeBundle(metaData); dest.writeString(key); dest.writeParcelable(remoteViews, flags); dest.writeBoolean(isIconTintable); } public void readFromParcel(Parcel in) { title = TextUtils.CHAR_SEQUENCE_CREATOR.createFromParcel(in); summary = TextUtils.CHAR_SEQUENCE_CREATOR.createFromParcel(in); if (in.readByte() != 0) { icon = Icon.CREATOR.createFromParcel(in); } if (in.readByte() != 0) { intent = Intent.CREATOR.createFromParcel(in); } final int N = in.readInt(); for (int i = 0; i < N; i++) { userHandle.add(UserHandle.CREATOR.createFromParcel(in)); } extras = in.readBundle(); category = in.readString(); priority = in.readInt(); metaData = in.readBundle(); key = in.readString(); remoteViews = in.readParcelable(RemoteViews.class.getClassLoader()); isIconTintable = in.readBoolean(); } Tile(Parcel in) { readFromParcel(in); } public static final Creator CREATOR = new Creator() { public Tile createFromParcel(Parcel source) { return new Tile(source); } public Tile[] newArray(int size) { return new Tile[size]; } }; }