ActionBar.java revision a66c7b04567a584d73bc4dba2711f5d815e4932d
133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell/*
233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * Copyright (C) 2010 The Android Open Source Project
333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell *
433b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * Licensed under the Apache License, Version 2.0 (the "License");
533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * you may not use this file except in compliance with the License.
633b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * You may obtain a copy of the License at
733b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell *
833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell *      http://www.apache.org/licenses/LICENSE-2.0
933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell *
1033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * Unless required by applicable law or agreed to in writing, software
1133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * distributed under the License is distributed on an "AS IS" BASIS,
1233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * See the License for the specific language governing permissions and
1433b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * limitations under the License.
1533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell */
1633b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
1733b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powellpackage android.app;
1833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
1933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powellimport android.graphics.drawable.Drawable;
2033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powellimport android.view.View;
21a408291e22def5755559f42cde913706a6d628c0Adam Powellimport android.widget.SpinnerAdapter;
2233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
2333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell/**
2433b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * This is the public interface to the contextual ActionBar.
2533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * The ActionBar acts as a replacement for the title bar in Activities.
2633b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * It provides facilities for creating toolbar actions as well as
2733b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell * methods of navigating around an application.
2833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell */
2933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powellpublic abstract class ActionBar {
30a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell    /**
31a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Standard navigation mode. Consists of either a logo or icon
32a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * and title text with an optional subtitle. Clicking any of these elements
33a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * will dispatch onActionItemSelected to the registered Callback with
34a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * a MenuItem with item ID android.R.id.home.
35a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     */
36a408291e22def5755559f42cde913706a6d628c0Adam Powell    public static final int NAVIGATION_MODE_STANDARD = 0;
3733b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
3833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
3933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * Dropdown list navigation mode. Instead of static title text this mode
4033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * presents a dropdown menu for navigation within the activity.
4133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
4233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public static final int NAVIGATION_MODE_DROPDOWN_LIST = 1;
4333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
4433b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
4533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * Tab navigation mode. Instead of static title text this mode
4633b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * presents a series of tabs for navigation within the activity.
4733b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
4833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public static final int NAVIGATION_MODE_TABS = 2;
4933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
5033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
5133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * Custom navigation mode. This navigation mode is set implicitly whenever
524dc643eb6749afe5211198c920e739475590f92cWink Saville     * a custom navigation view is set. See {@link #setCustomNavigationMode(View)}.
5333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
5433b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public static final int NAVIGATION_MODE_CUSTOM = 3;
5533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
5633b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
5733b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * Use logo instead of icon if available. This flag will cause appropriate
5833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * navigation modes to use a wider logo in place of the standard icon.
5933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
6033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public static final int DISPLAY_USE_LOGO = 0x1;
6133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
6233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
6333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * Hide 'home' elements in this action bar, leaving more space for other
6433b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * navigation elements. This includes logo and icon.
6533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
6633b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public static final int DISPLAY_HIDE_HOME = 0x2;
6789e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell
6833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
69a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Set the action bar into custom navigation mode, supplying a view
70a408291e22def5755559f42cde913706a6d628c0Adam Powell     * for custom navigation.
7133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     *
7233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * Custom navigation views appear between the application icon and
7333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * any action buttons and may use any space available there. Common
74a408291e22def5755559f42cde913706a6d628c0Adam Powell     * use cases for custom navigation views might include an auto-suggesting
75a408291e22def5755559f42cde913706a6d628c0Adam Powell     * address bar for a browser or other navigation mechanisms that do not
76a408291e22def5755559f42cde913706a6d628c0Adam Powell     * translate well to provided navigation modes.
7733b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     *
7833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * @param view Custom navigation view to place in the ActionBar.
7933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
80a408291e22def5755559f42cde913706a6d628c0Adam Powell    public abstract void setCustomNavigationMode(View view);
8133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
8233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
83a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Set the action bar into dropdown navigation mode and supply an adapter
84a408291e22def5755559f42cde913706a6d628c0Adam Powell     * that will provide views for navigation choices.
8533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     *
86a408291e22def5755559f42cde913706a6d628c0Adam Powell     * @param adapter An adapter that will provide views both to display
87a408291e22def5755559f42cde913706a6d628c0Adam Powell     *                the current navigation selection and populate views
88a408291e22def5755559f42cde913706a6d628c0Adam Powell     *                within the dropdown navigation menu.
8989e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell     * @param callback A NavigationCallback that will receive events when the user
9089e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell     *                 selects a navigation item.
9133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
9289e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell    public abstract void setDropdownNavigationMode(SpinnerAdapter adapter,
9389e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell            NavigationCallback callback);
94a408291e22def5755559f42cde913706a6d628c0Adam Powell
9533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
96178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     * Set the action bar into dropdown navigation mode and supply an adapter that will
97178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     * provide views for navigation choices.
98178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     *
99178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     * @param adapter An adapter that will provide views both to display the current
100178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     *                navigation selection and populate views within the dropdown
101178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     *                navigation menu.
102178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     * @param callback A NavigationCallback that will receive events when the user
103178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     *                 selects a navigation item.
104178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     * @param defaultSelectedPosition Position within the provided adapter that should be
105178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     *                                selected from the outset.
106178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     */
107178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell    public abstract void setDropdownNavigationMode(SpinnerAdapter adapter,
108178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell            NavigationCallback callback, int defaultSelectedPosition);
109178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell
110178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell    /**
111178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     * Set the selected navigation item in dropdown or tabbed navigation modes.
112178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     *
113178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     * @param position Position of the item to select.
114178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     */
115178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell    public abstract void setSelectedNavigationItem(int position);
116178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell
117178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell    /**
118178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     * Get the position of the selected navigation item in dropdown or tabbed navigation modes.
119178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     *
120178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     * @return Position of the selected item.
121178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell     */
122178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell    public abstract int getSelectedNavigationItem();
123178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell
124178097727fab0f41810b1ffd4baf84ff8ed32c42Adam Powell    /**
125a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Set the action bar into standard navigation mode, supplying a title and subtitle.
12633b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     *
127a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Standard navigation mode is default. The title is automatically set to the
128a408291e22def5755559f42cde913706a6d628c0Adam Powell     * name of your Activity. Subtitles are displayed underneath the title, usually
129a408291e22def5755559f42cde913706a6d628c0Adam Powell     * in a smaller font or otherwise less prominently than the title. Subtitles are
130a408291e22def5755559f42cde913706a6d628c0Adam Powell     * good for extended descriptions of activity state.
131a408291e22def5755559f42cde913706a6d628c0Adam Powell     *
132a408291e22def5755559f42cde913706a6d628c0Adam Powell     * @param title The action bar's title. null is treated as an empty string.
1330e94b5151d817e600a888448a662208b29b5ef46Adam Powell     * @param subtitle The action bar's subtitle. null will remove the subtitle entirely.
134a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
135a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode()
136a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(CharSequence)
137a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(int)
138a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(int, int)
13933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
140a408291e22def5755559f42cde913706a6d628c0Adam Powell    public abstract void setStandardNavigationMode(CharSequence title, CharSequence subtitle);
141a408291e22def5755559f42cde913706a6d628c0Adam Powell
14233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
143a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Set the action bar into standard navigation mode, supplying a title and subtitle.
144a408291e22def5755559f42cde913706a6d628c0Adam Powell     *
145a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Standard navigation mode is default. The title is automatically set to the
146a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * name of your Activity. Subtitles are displayed underneath the title, usually
147a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * in a smaller font or otherwise less prominently than the title. Subtitles are
148a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * good for extended descriptions of activity state.
149a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
150a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @param titleResId Resource ID of a title string
151a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @param subtitleResId Resource ID of a subtitle string
152a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
153a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode()
154a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(CharSequence)
155a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(CharSequence, CharSequence)
156a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(int)
157a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     */
158a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell    public abstract void setStandardNavigationMode(int titleResId, int subtitleResId);
159a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell
160a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell    /**
161a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * Set the action bar into standard navigation mode, supplying a title and subtitle.
162a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
163a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * Standard navigation mode is default. The title is automatically set to the
1640e94b5151d817e600a888448a662208b29b5ef46Adam Powell     * name of your Activity on startup if an action bar is present.
16533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     *
166a408291e22def5755559f42cde913706a6d628c0Adam Powell     * @param title The action bar's title. null is treated as an empty string.
167a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
168a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode()
169a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(CharSequence, CharSequence)
170a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(int)
171a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(int, int)
17233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
173a408291e22def5755559f42cde913706a6d628c0Adam Powell    public abstract void setStandardNavigationMode(CharSequence title);
174a408291e22def5755559f42cde913706a6d628c0Adam Powell
17533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
176a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * Set the action bar into standard navigation mode, supplying a title and subtitle.
177a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
178a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * Standard navigation mode is default. The title is automatically set to the
179a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * name of your Activity on startup if an action bar is present.
180a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
181a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @param titleResId Resource ID of a title string
182a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
183a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode()
184a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(CharSequence)
185a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(CharSequence, CharSequence)
186a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setStandardNavigationMode(int, int)
187a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     */
188a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell    public abstract void setStandardNavigationMode(int titleResId);
189a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell
190a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell    /**
1910e94b5151d817e600a888448a662208b29b5ef46Adam Powell     * Set the action bar into standard navigation mode, using the currently set title
1920e94b5151d817e600a888448a662208b29b5ef46Adam Powell     * and/or subtitle.
1930e94b5151d817e600a888448a662208b29b5ef46Adam Powell     *
1940e94b5151d817e600a888448a662208b29b5ef46Adam Powell     * Standard navigation mode is default. The title is automatically set to the name of
1950e94b5151d817e600a888448a662208b29b5ef46Adam Powell     * your Activity on startup if an action bar is present.
1960e94b5151d817e600a888448a662208b29b5ef46Adam Powell     */
1970e94b5151d817e600a888448a662208b29b5ef46Adam Powell    public abstract void setStandardNavigationMode();
1980e94b5151d817e600a888448a662208b29b5ef46Adam Powell
1990e94b5151d817e600a888448a662208b29b5ef46Adam Powell    /**
2000e94b5151d817e600a888448a662208b29b5ef46Adam Powell     * Set the action bar's title. This will only be displayed in standard navigation mode.
2010e94b5151d817e600a888448a662208b29b5ef46Adam Powell     *
2020e94b5151d817e600a888448a662208b29b5ef46Adam Powell     * @param title Title to set
203a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
204a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setTitle(int)
2050e94b5151d817e600a888448a662208b29b5ef46Adam Powell     */
2060e94b5151d817e600a888448a662208b29b5ef46Adam Powell    public abstract void setTitle(CharSequence title);
2070e94b5151d817e600a888448a662208b29b5ef46Adam Powell
2080e94b5151d817e600a888448a662208b29b5ef46Adam Powell    /**
209a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * Set the action bar's title. This will only be displayed in standard navigation mode.
210a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
211a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @param resId Resource ID of title string to set
212a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
213a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setTitle(CharSequence)
214a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     */
215a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell    public abstract void setTitle(int resId);
216a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell
217a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell    /**
2180e94b5151d817e600a888448a662208b29b5ef46Adam Powell     * Set the action bar's subtitle. This will only be displayed in standard navigation mode.
2190e94b5151d817e600a888448a662208b29b5ef46Adam Powell     * Set to null to disable the subtitle entirely.
2200e94b5151d817e600a888448a662208b29b5ef46Adam Powell     *
2210e94b5151d817e600a888448a662208b29b5ef46Adam Powell     * @param subtitle Subtitle to set
222a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
223a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setSubtitle(int)
2240e94b5151d817e600a888448a662208b29b5ef46Adam Powell     */
2250e94b5151d817e600a888448a662208b29b5ef46Adam Powell    public abstract void setSubtitle(CharSequence subtitle);
2260e94b5151d817e600a888448a662208b29b5ef46Adam Powell
2270e94b5151d817e600a888448a662208b29b5ef46Adam Powell    /**
228a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * Set the action bar's subtitle. This will only be displayed in standard navigation mode.
229a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
230a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @param resId Resource ID of subtitle string to set
231a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     *
232a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     * @see #setSubtitle(CharSequence)
233a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell     */
234a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell    public abstract void setSubtitle(int resId);
235a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell
236a66c7b04567a584d73bc4dba2711f5d815e4932dAdam Powell    /**
237a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * Set display options. This changes all display option bits at once. To change
238a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * a limited subset of display options, see {@link #setDisplayOptions(int, int)}.
23933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     *
24033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * @param options A combination of the bits defined by the DISPLAY_ constants
24133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     *                defined in ActionBar.
24233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
24333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public abstract void setDisplayOptions(int options);
24433b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
24533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
246a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * Set selected display options. Only the options specified by mask will be changed.
247a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * To change all display option bits at once, see {@link #setDisplayOptions(int)}.
248a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     *
249a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * <p>Example: setDisplayOptions(0, DISPLAY_HIDE_HOME) will disable the
250a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * {@link #DISPLAY_HIDE_HOME} option.
251a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * setDisplayOptions(DISPLAY_HIDE_HOME, DISPLAY_HIDE_HOME | DISPLAY_USE_LOGO)
252a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * will enable {@link #DISPLAY_HIDE_HOME} and disable {@link #DISPLAY_USE_LOGO}.
253a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     *
254a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * @param options A combination of the bits defined by the DISPLAY_ constants
255a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     *                defined in ActionBar.
256a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     * @param mask A bit mask declaring which display options should be changed.
257a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell     */
258a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell    public abstract void setDisplayOptions(int options, int mask);
259a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell
260a1700783b52c3f4e6b52ea425cdce93c74936586Adam Powell    /**
26133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * Set the ActionBar's background.
26233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     *
26333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * @param d Background drawable
26433b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
26533b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public abstract void setBackgroundDrawable(Drawable d);
26633b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
26733b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
26833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * @return The current custom navigation view.
26933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
27033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public abstract View getCustomNavigationView();
27133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
27233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
273a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Returns the current ActionBar title in standard mode.
274a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Returns null if {@link #getNavigationMode()} would not return
275a408291e22def5755559f42cde913706a6d628c0Adam Powell     * {@link #NAVIGATION_MODE_STANDARD}.
276a408291e22def5755559f42cde913706a6d628c0Adam Powell     *
277a408291e22def5755559f42cde913706a6d628c0Adam Powell     * @return The current ActionBar title or null.
27833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
27933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public abstract CharSequence getTitle();
28033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
28133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
282a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Returns the current ActionBar subtitle in standard mode.
283a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Returns null if {@link #getNavigationMode()} would not return
284a408291e22def5755559f42cde913706a6d628c0Adam Powell     * {@link #NAVIGATION_MODE_STANDARD}.
285a408291e22def5755559f42cde913706a6d628c0Adam Powell     *
286a408291e22def5755559f42cde913706a6d628c0Adam Powell     * @return The current ActionBar subtitle or null.
28733b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
28833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public abstract CharSequence getSubtitle();
28933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
29033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
291a408291e22def5755559f42cde913706a6d628c0Adam Powell     * Returns the current navigation mode. The result will be one of:
292a408291e22def5755559f42cde913706a6d628c0Adam Powell     * <ul>
293a408291e22def5755559f42cde913706a6d628c0Adam Powell     * <li>{@link #NAVIGATION_MODE_STANDARD}</li>
294a408291e22def5755559f42cde913706a6d628c0Adam Powell     * <li>{@link #NAVIGATION_MODE_DROPDOWN_LIST}</li>
295a408291e22def5755559f42cde913706a6d628c0Adam Powell     * <li>{@link #NAVIGATION_MODE_TABS}</li>
296a408291e22def5755559f42cde913706a6d628c0Adam Powell     * <li>{@link #NAVIGATION_MODE_CUSTOM}</li>
297a408291e22def5755559f42cde913706a6d628c0Adam Powell     * </ul>
298a408291e22def5755559f42cde913706a6d628c0Adam Powell     *
29933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * @return The current navigation mode.
300a408291e22def5755559f42cde913706a6d628c0Adam Powell     *
301661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #setStandardNavigationMode()
302a408291e22def5755559f42cde913706a6d628c0Adam Powell     * @see #setStandardNavigationMode(CharSequence)
303a408291e22def5755559f42cde913706a6d628c0Adam Powell     * @see #setStandardNavigationMode(CharSequence, CharSequence)
304a408291e22def5755559f42cde913706a6d628c0Adam Powell     * @see #setDropdownNavigationMode(SpinnerAdapter)
305661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #setTabNavigationMode()
306a408291e22def5755559f42cde913706a6d628c0Adam Powell     * @see #setCustomNavigationMode(View)
30733b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
30833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public abstract int getNavigationMode();
30933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell
31033b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    /**
31133b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     * @return The current set of display options.
31233b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell     */
31333b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    public abstract int getDisplayOptions();
314661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
315661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    /**
316661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * Set the action bar into tabbed navigation mode.
317661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     *
318661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #addTab(Tab)
319661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #insertTab(Tab, int)
320661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #removeTab(Tab)
321661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #removeTabAt(int)
322661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     */
323661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    public abstract void setTabNavigationMode();
324661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
325661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    /**
326661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * Set the action bar into tabbed navigation mode.
327661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     *
328661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @param containerViewId Id of the container view where tab content fragments should appear.
329661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     *
330661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #addTab(Tab)
331661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #insertTab(Tab, int)
332661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #removeTab(Tab)
333661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #removeTabAt(int)
334661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     */
335661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    public abstract void setTabNavigationMode(int containerViewId);
336661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
337661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    /**
338661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * Create and return a new {@link Tab}.
339661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * This tab will not be included in the action bar until it is added.
340661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     *
341661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @return A new Tab
342661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     *
343661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #addTab(Tab)
344661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @see #insertTab(Tab, int)
345661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     */
346661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    public abstract Tab newTab();
347661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
348661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    /**
349661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * Add a tab for use in tabbed navigation mode. The tab will be added at the end of the list.
350661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     *
351661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @param tab Tab to add
352661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     */
353661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    public abstract void addTab(Tab tab);
354661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
355661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    /**
356661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * Insert a tab for use in tabbed navigation mode. The tab will be inserted at
357661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * <code>position</code>.
358661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     *
359661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @param tab The tab to add
360661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @param position The new position of the tab
361661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     */
362661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    public abstract void insertTab(Tab tab, int position);
363661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
364661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    /**
365661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * Remove a tab from the action bar.
366661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     *
367661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @param tab The tab to remove
368661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     */
369661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    public abstract void removeTab(Tab tab);
370661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
371661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    /**
372661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * Remove a tab from the action bar.
373661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     *
374661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @param position Position of the tab to remove
375661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     */
376661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    public abstract void removeTabAt(int position);
377661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
378661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    /**
379661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * Select the specified tab. If it is not a child of this action bar it will be added.
380661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     *
381661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * @param tab Tab to select
382661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     */
383661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    public abstract void selectTab(Tab tab);
384661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
385661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    /**
38689e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell     * Callback interface for ActionBar navigation events.
38789e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell     */
38889e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell    public interface NavigationCallback {
38989e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell        /**
39089e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell         * This method is called whenever a navigation item in your action bar
39189e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell         * is selected.
39289e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell         *
39389e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell         * @param itemPosition Position of the item clicked.
39489e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell         * @param itemId ID of the item clicked.
39589e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell         * @return True if the event was handled, false otherwise.
39689e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell         */
39789e0645b4157961e8c465eb9c819f965fdb453d8Adam Powell        public boolean onNavigationItemSelected(int itemPosition, long itemId);
39833b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell    }
399661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
400661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    /**
401661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * A tab in the action bar.
402661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     *
403661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     * <p>Tabs manage the hiding and showing of {@link Fragment}s.
404661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell     */
405661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    public static abstract class Tab {
406661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        /**
407661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * An invalid position for a tab.
408661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         *
409661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * @see #getPosition()
410661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         */
411661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        public static final int INVALID_POSITION = -1;
412661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
413661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        /**
414661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * Return the current position of this tab in the action bar.
415661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         *
416661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * @return Current position, or {@link #INVALID_POSITION} if this tab is not currently in
417661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         *         the action bar.
418661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         */
419661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        public abstract int getPosition();
420661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
421661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        /**
422661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * Return the icon associated with this tab.
423661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         *
424661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * @return The tab's icon
425661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         */
426661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        public abstract Drawable getIcon();
427661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
428661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        /**
429661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * Return the text of this tab.
430661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         *
431661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * @return The tab's text
432661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         */
433661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        public abstract CharSequence getText();
434661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
435661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        /**
436661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * Set the icon displayed on this tab.
437661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         *
438661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * @param icon The drawable to use as an icon
439661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         */
440661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        public abstract void setIcon(Drawable icon);
441661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
442661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        /**
443661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * Set the text displayed on this tab. Text may be truncated if there is not
444661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * room to display the entire string.
445661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         *
446661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * @param text The text to display
447661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         */
448661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        public abstract void setText(CharSequence text);
449661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
450661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        /**
451661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * Returns the fragment that will be shown when this tab is selected.
452661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         *
453661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * @return Fragment associated with this tab
454661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         */
455661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        public abstract Fragment getFragment();
456661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
457661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        /**
458661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * Set the fragment that will be shown when this tab is selected.
459661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         *
460661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * @param fragment Fragment to associate with this tab
461661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         */
462661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        public abstract void setFragment(Fragment fragment);
463661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell
464661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        /**
465661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         * Select this tab. Only valid if the tab has been added to the action bar.
466661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell         */
467661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell        public abstract void select();
468661c908e4e26c99adc2cab7558a02129eaee059dAdam Powell    }
46933b974393b6fadcefc896ec4a0f9b66724f61e9fAdam Powell}
470