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