ActionBarSherlock 4.0.2
@ -1,13 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:versionCode="60" android:versionName="4.0.2" package="com.actionbarsherlock">
|
||||||
<manifest
|
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
package="com.actionbarsherlock"
|
|
||||||
android:versionCode="50"
|
|
||||||
android:versionName="4.0.0">
|
|
||||||
|
|
||||||
<uses-sdk
|
<uses-sdk android:minSdkVersion="7" android:targetSdkVersion="15"/>
|
||||||
android:minSdkVersion="7"
|
|
||||||
android:targetSdkVersion="15" />
|
|
||||||
|
|
||||||
</manifest>
|
</manifest>
|
||||||
|
@ -5,11 +5,11 @@ This folder contains the main library which should be linked against as an
|
|||||||
Android library project in your application.
|
Android library project in your application.
|
||||||
|
|
||||||
For more information see the "Including In Your Project" section of the
|
For more information see the "Including In Your Project" section of the
|
||||||
[download page][1].
|
[usage page][1].
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[1]: http://actionbarsherlock.com/download.html
|
[1]: http://actionbarsherlock.com/usage.html
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.actionbarsherlock</groupId>
|
<groupId>com.actionbarsherlock</groupId>
|
||||||
<artifactId>parent</artifactId>
|
<artifactId>parent</artifactId>
|
||||||
<version>4.0.0</version>
|
<version>4.0.2</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
After Width: | Height: | Size: 2.8 KiB |
After Width: | Height: | Size: 2.8 KiB |
After Width: | Height: | Size: 467 B |
After Width: | Height: | Size: 505 B |
After Width: | Height: | Size: 154 B |
After Width: | Height: | Size: 2.8 KiB |
After Width: | Height: | Size: 122 B |
After Width: | Height: | Size: 882 B |
After Width: | Height: | Size: 1003 B |
After Width: | Height: | Size: 332 B |
After Width: | Height: | Size: 355 B |
After Width: | Height: | Size: 151 B |
After Width: | Height: | Size: 2.8 KiB |
After Width: | Height: | Size: 2.8 KiB |
After Width: | Height: | Size: 2.1 KiB |
After Width: | Height: | Size: 2.2 KiB |
After Width: | Height: | Size: 699 B |
After Width: | Height: | Size: 935 B |
After Width: | Height: | Size: 158 B |
After Width: | Height: | Size: 2.7 KiB |
After Width: | Height: | Size: 2.4 KiB |
@ -0,0 +1,20 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Copyright (C) 2008 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.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<item android:state_activated="true" android:drawable="@drawable/abs__list_activated_holo" />
|
||||||
|
<item android:drawable="@android:color/transparent" />
|
||||||
|
</selector>
|
@ -0,0 +1,20 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Copyright (C) 2008 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.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<item android:state_activated="true" android:drawable="@drawable/abs__list_activated_holo" />
|
||||||
|
<item android:drawable="@android:color/transparent" />
|
||||||
|
</selector>
|
@ -14,8 +14,7 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android"
|
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
android:exitFadeDuration="@android:integer/config_mediumAnimTime">
|
|
||||||
<item android:state_pressed="true"
|
<item android:state_pressed="true"
|
||||||
android:drawable="@drawable/abs__btn_cab_done_pressed_holo_dark" />
|
android:drawable="@drawable/abs__btn_cab_done_pressed_holo_dark" />
|
||||||
<item android:state_focused="true" android:state_enabled="true"
|
<item android:state_focused="true" android:state_enabled="true"
|
||||||
|
@ -14,8 +14,7 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android"
|
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
android:exitFadeDuration="@android:integer/config_mediumAnimTime">
|
|
||||||
<item android:state_pressed="true"
|
<item android:state_pressed="true"
|
||||||
android:drawable="@drawable/abs__btn_cab_done_pressed_holo_light" />
|
android:drawable="@drawable/abs__btn_cab_done_pressed_holo_light" />
|
||||||
<item android:state_focused="true" android:state_enabled="true"
|
<item android:state_focused="true" android:state_enabled="true"
|
||||||
|
@ -14,8 +14,7 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android"
|
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
android:exitFadeDuration="@android:integer/config_mediumAnimTime">
|
|
||||||
|
|
||||||
<!-- Even though these two point to the same resource, have two states so the drawable will invalidate itself when coming out of pressed state. -->
|
<!-- Even though these two point to the same resource, have two states so the drawable will invalidate itself when coming out of pressed state. -->
|
||||||
<item android:state_focused="true" android:state_enabled="false" android:state_pressed="true" android:drawable="@drawable/abs__list_selector_disabled_holo_dark" />
|
<item android:state_focused="true" android:state_enabled="false" android:state_pressed="true" android:drawable="@drawable/abs__list_selector_disabled_holo_dark" />
|
||||||
|
@ -14,8 +14,7 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android"
|
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
android:exitFadeDuration="@android:integer/config_mediumAnimTime">
|
|
||||||
|
|
||||||
<!-- Even though these two point to the same resource, have two states so the drawable will invalidate itself when coming out of pressed state. -->
|
<!-- Even though these two point to the same resource, have two states so the drawable will invalidate itself when coming out of pressed state. -->
|
||||||
<item android:state_focused="true" android:state_enabled="false" android:state_pressed="true" android:drawable="@drawable/abs__list_selector_disabled_holo_light" />
|
<item android:state_focused="true" android:state_enabled="false" android:state_pressed="true" android:drawable="@drawable/abs__list_selector_disabled_holo_light" />
|
||||||
|
@ -14,8 +14,7 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android"
|
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
android:exitFadeDuration="@android:integer/config_mediumAnimTime">
|
|
||||||
|
|
||||||
<item android:state_window_focused="false" android:drawable="@android:color/transparent" />
|
<item android:state_window_focused="false" android:drawable="@android:color/transparent" />
|
||||||
|
|
||||||
|
@ -14,8 +14,7 @@
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android"
|
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
android:exitFadeDuration="@android:integer/config_mediumAnimTime">
|
|
||||||
|
|
||||||
<item android:state_window_focused="false" android:drawable="@android:color/transparent" />
|
<item android:state_window_focused="false" android:drawable="@android:color/transparent" />
|
||||||
|
|
||||||
|
@ -4,9 +4,9 @@
|
|||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
You may obtain a copy of the License at
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
Unless required by applicable law or agreed to in writing, software
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
@ -18,6 +18,6 @@
|
|||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:divider="?attr/dividerVertical"
|
android:divider="?attr/actionBarDivider"
|
||||||
android:dividerPadding="12dip"
|
android:dividerPadding="12dip"
|
||||||
android:gravity="center_vertical" />
|
android:gravity="center_vertical" />
|
||||||
|
@ -0,0 +1,70 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
**
|
||||||
|
** Copyright 2011, 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.
|
||||||
|
*/
|
||||||
|
-->
|
||||||
|
<com.actionbarsherlock.internal.widget.IcsLinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:id="@+id/abs__activity_chooser_view_content"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="fill_parent"
|
||||||
|
android:layout_gravity="center"
|
||||||
|
style="?attr/activityChooserViewStyle">
|
||||||
|
|
||||||
|
<FrameLayout
|
||||||
|
android:id="@+id/abs__expand_activities_button"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="fill_parent"
|
||||||
|
android:layout_gravity="center"
|
||||||
|
android:focusable="true"
|
||||||
|
android:addStatesFromChildren="true"
|
||||||
|
android:background="?attr/actionBarItemBackground">
|
||||||
|
|
||||||
|
<ImageView android:id="@+id/abs__image"
|
||||||
|
android:layout_width="56dip"
|
||||||
|
android:layout_height="36dip"
|
||||||
|
android:layout_gravity="center"
|
||||||
|
android:paddingTop="2dip"
|
||||||
|
android:paddingBottom="2dip"
|
||||||
|
android:paddingLeft="12dip"
|
||||||
|
android:paddingRight="12dip"
|
||||||
|
android:scaleType="fitCenter"
|
||||||
|
android:adjustViewBounds="true" />
|
||||||
|
|
||||||
|
</FrameLayout>
|
||||||
|
|
||||||
|
<FrameLayout
|
||||||
|
android:id="@+id/abs__default_activity_button"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="fill_parent"
|
||||||
|
android:layout_gravity="center"
|
||||||
|
android:focusable="true"
|
||||||
|
android:addStatesFromChildren="true"
|
||||||
|
android:background="?attr/actionBarItemBackground">
|
||||||
|
|
||||||
|
<ImageView android:id="@+id/abs__image"
|
||||||
|
android:layout_width="56dip"
|
||||||
|
android:layout_height="36dip"
|
||||||
|
android:layout_gravity="center"
|
||||||
|
android:paddingTop="2dip"
|
||||||
|
android:paddingBottom="2dip"
|
||||||
|
android:paddingLeft="12dip"
|
||||||
|
android:paddingRight="12dip"
|
||||||
|
android:scaleType="fitCenter"
|
||||||
|
android:adjustViewBounds="true" />
|
||||||
|
|
||||||
|
</FrameLayout>
|
||||||
|
|
||||||
|
</com.actionbarsherlock.internal.widget.IcsLinearLayout>
|
@ -0,0 +1,53 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Copyright (C) 2011 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.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:id="@+id/abs__list_item"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="?attr/dropdownListPreferredItemHeight"
|
||||||
|
android:paddingLeft="16dip"
|
||||||
|
android:paddingRight="16dip"
|
||||||
|
android:minWidth="196dip"
|
||||||
|
android:background="?attr/activatedBackgroundIndicator"
|
||||||
|
android:orientation="vertical" >
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:duplicateParentState="true" >
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:id="@+id/abs__icon"
|
||||||
|
android:layout_width="32dip"
|
||||||
|
android:layout_height="32dip"
|
||||||
|
android:layout_gravity="center_vertical"
|
||||||
|
android:layout_marginRight="8dip"
|
||||||
|
android:duplicateParentState="true" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/abs__title"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="center_vertical"
|
||||||
|
android:textAppearance="?attr/textAppearanceLargePopupMenu"
|
||||||
|
android:duplicateParentState="true"
|
||||||
|
android:singleLine="true"
|
||||||
|
android:ellipsize="marquee"
|
||||||
|
android:fadingEdge="horizontal" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
@ -4,9 +4,9 @@
|
|||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
You may obtain a copy of the License at
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
Unless required by applicable law or agreed to in writing, software
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
@ -19,10 +19,10 @@ This is an optimized layout for a screen with the Action Bar enabled.
|
|||||||
-->
|
-->
|
||||||
|
|
||||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
android:orientation="vertical"
|
android:orientation="vertical"
|
||||||
android:fitsSystemWindows="true"
|
android:fitsSystemWindows="true">
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="fill_parent">
|
|
||||||
<com.actionbarsherlock.internal.widget.ActionBarContainer
|
<com.actionbarsherlock.internal.widget.ActionBarContainer
|
||||||
android:id="@+id/abs__action_bar_container"
|
android:id="@+id/abs__action_bar_container"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="fill_parent"
|
||||||
@ -42,7 +42,7 @@ This is an optimized layout for a screen with the Action Bar enabled.
|
|||||||
</com.actionbarsherlock.internal.widget.ActionBarContainer>
|
</com.actionbarsherlock.internal.widget.ActionBarContainer>
|
||||||
<com.actionbarsherlock.internal.nineoldandroids.widget.NineFrameLayout
|
<com.actionbarsherlock.internal.nineoldandroids.widget.NineFrameLayout
|
||||||
android:id="@+id/abs__content"
|
android:id="@+id/abs__content"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="fill_parent"
|
||||||
android:layout_height="0dip"
|
android:layout_height="0dip"
|
||||||
android:layout_weight="1"
|
android:layout_weight="1"
|
||||||
android:foregroundGravity="fill_horizontal|top"
|
android:foregroundGravity="fill_horizontal|top"
|
||||||
|
@ -19,38 +19,41 @@ This is an optimized layout for a screen with
|
|||||||
the Action Bar enabled overlaying application content.
|
the Action Bar enabled overlaying application content.
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
android:fitsSystemWindows="true">
|
android:fitsSystemWindows="true">
|
||||||
<com.actionbarsherlock.internal.nineoldandroids.widget.NineFrameLayout android:id="@+id/abs__content"
|
<com.actionbarsherlock.internal.nineoldandroids.widget.NineFrameLayout android:id="@+id/abs__content"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="fill_parent" />
|
android:layout_height="match_parent" />
|
||||||
<com.actionbarsherlock.internal.widget.ActionBarContainer android:id="@+id/abs__action_bar_container"
|
<com.actionbarsherlock.internal.widget.ActionBarContainer android:id="@+id/abs__action_bar_container"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_alignParentTop="true"
|
||||||
style="?attr/actionBarStyle"
|
style="?attr/actionBarStyle"
|
||||||
android:gravity="top">
|
android:gravity="top">
|
||||||
<com.actionbarsherlock.internal.widget.ActionBarView
|
<com.actionbarsherlock.internal.widget.ActionBarView
|
||||||
android:id="@+id/abs__action_bar"
|
android:id="@+id/abs__action_bar"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
style="?attr/actionBarStyle" />
|
style="?attr/actionBarStyle" />
|
||||||
<com.actionbarsherlock.internal.widget.ActionBarContextView
|
<com.actionbarsherlock.internal.widget.ActionBarContextView
|
||||||
android:id="@+id/abs__action_context_bar"
|
android:id="@+id/abs__action_context_bar"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:visibility="gone"
|
android:visibility="gone"
|
||||||
style="?attr/actionModeStyle" />
|
style="?attr/actionModeStyle" />
|
||||||
</com.actionbarsherlock.internal.widget.ActionBarContainer>
|
</com.actionbarsherlock.internal.widget.ActionBarContainer>
|
||||||
<ImageView android:src="?attr/windowContentOverlay"
|
<ImageView android:src="?attr/windowContentOverlay"
|
||||||
android:scaleType="fitXY"
|
android:scaleType="fitXY"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@id/abs__action_bar_container" />
|
android:layout_below="@id/abs__action_bar_container" />
|
||||||
<com.actionbarsherlock.internal.widget.ActionBarContainer android:id="@+id/abs__split_action_bar"
|
<com.actionbarsherlock.internal.widget.ActionBarContainer android:id="@+id/abs__split_action_bar"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_alignParentBottom="true"
|
android:layout_gravity="bottom"
|
||||||
style="?attr/actionBarSplitStyle"
|
style="?attr/actionBarSplitStyle"
|
||||||
android:visibility="gone"
|
android:visibility="gone"
|
||||||
android:gravity="center"/>
|
android:gravity="center"/>
|
||||||
</RelativeLayout>
|
</FrameLayout>
|
||||||
|
@ -21,6 +21,8 @@ enabled.
|
|||||||
-->
|
-->
|
||||||
|
|
||||||
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
android:fitsSystemWindows="true">
|
android:fitsSystemWindows="true">
|
||||||
<com.actionbarsherlock.internal.nineoldandroids.widget.NineFrameLayout
|
<com.actionbarsherlock.internal.nineoldandroids.widget.NineFrameLayout
|
||||||
android:id="@+id/abs__content"
|
android:id="@+id/abs__content"
|
||||||
|
@ -10,6 +10,10 @@
|
|||||||
<item name="actionBarSize">?android:attr/actionBarSize</item>
|
<item name="actionBarSize">?android:attr/actionBarSize</item>
|
||||||
<!-- Needed for our bug-fix dropdown list navigation layout. :( -->
|
<!-- Needed for our bug-fix dropdown list navigation layout. :( -->
|
||||||
<item name="dropdownListPreferredItemHeight">48dp</item>
|
<item name="dropdownListPreferredItemHeight">48dp</item>
|
||||||
|
<!-- Needed for our ShareActionProvider implementation. -->
|
||||||
|
<item name="android:actionBarWidgetTheme">@style/Theme.Sherlock</item>
|
||||||
|
<!-- For crazy people who use IcsSpinner. -->
|
||||||
|
<item name="dropDownListViewStyle">?android:attr/dropDownListViewStyle</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Theme.Sherlock.NoActionBar">
|
<style name="Theme.Sherlock.NoActionBar">
|
||||||
@ -20,7 +24,7 @@
|
|||||||
<item name="android:windowActionBar">false</item>
|
<item name="android:windowActionBar">false</item>
|
||||||
<item name="android:windowNoTitle">true</item>
|
<item name="android:windowNoTitle">true</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Theme.Sherlock.Dialog" parent="android:Theme.Holo.Dialog">
|
<style name="Theme.Sherlock.Dialog" parent="android:Theme.Holo.Dialog">
|
||||||
</style>
|
</style>
|
||||||
<style name="Theme.Sherlock.Light.Dialog" parent="android:Theme.Holo.Light.Dialog">
|
<style name="Theme.Sherlock.Light.Dialog" parent="android:Theme.Holo.Light.Dialog">
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
<attr name="backgroundSplit" format="reference|color" />
|
<attr name="backgroundSplit" format="reference|color" />
|
||||||
<attr name="height" format="dimension" />
|
<attr name="height" format="dimension" />
|
||||||
<attr name="divider" format="reference" />
|
<attr name="divider" format="reference" />
|
||||||
|
|
||||||
<declare-styleable name="SherlockTheme">
|
<declare-styleable name="SherlockTheme">
|
||||||
<!-- =================== -->
|
<!-- =================== -->
|
||||||
<!-- Action bar styles -->
|
<!-- Action bar styles -->
|
||||||
@ -60,6 +60,8 @@
|
|||||||
<attr name="actionModeSplitBackground" format="reference" />
|
<attr name="actionModeSplitBackground" format="reference" />
|
||||||
<!-- Drawable to use for the close action mode button -->
|
<!-- Drawable to use for the close action mode button -->
|
||||||
<attr name="actionModeCloseDrawable" format="reference" />
|
<attr name="actionModeCloseDrawable" format="reference" />
|
||||||
|
<!-- Drawable to use for the Share action button in WebView selection action modes -->
|
||||||
|
<attr name="actionModeShareDrawable" format="reference" />
|
||||||
|
|
||||||
<!-- PopupWindow style to use for action modes when showing as a window overlay. -->
|
<!-- PopupWindow style to use for action modes when showing as a window overlay. -->
|
||||||
<attr name="actionModePopupWindowStyle" format="reference" />
|
<attr name="actionModePopupWindowStyle" format="reference" />
|
||||||
@ -71,9 +73,9 @@
|
|||||||
|
|
||||||
<!-- Small Button style. -->
|
<!-- Small Button style. -->
|
||||||
<attr name="buttonStyleSmall" format="reference" />
|
<attr name="buttonStyleSmall" format="reference" />
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!-- This Drawable is overlaid over the foreground of the Window's content area, usually
|
<!-- This Drawable is overlaid over the foreground of the Window's content area, usually
|
||||||
to place a shadow below the title. -->
|
to place a shadow below the title. -->
|
||||||
<attr name="windowContentOverlay" format="reference" />
|
<attr name="windowContentOverlay" format="reference" />
|
||||||
@ -83,15 +85,15 @@
|
|||||||
|
|
||||||
<!-- Text color, typeface, size, and style for small text inside of a popup menu. -->
|
<!-- Text color, typeface, size, and style for small text inside of a popup menu. -->
|
||||||
<attr name="textAppearanceSmallPopupMenu" format="reference" />
|
<attr name="textAppearanceSmallPopupMenu" format="reference" />
|
||||||
|
|
||||||
|
|
||||||
<!-- Text color, typeface, size, and style for "small" text. Defaults to secondary text color. -->
|
<!-- Text color, typeface, size, and style for "small" text. Defaults to secondary text color. -->
|
||||||
<attr name="textAppearanceSmall" format="reference" />
|
<attr name="textAppearanceSmall" format="reference" />
|
||||||
|
|
||||||
<attr name="textColorPrimary" format="color" />
|
<attr name="textColorPrimary" format="color" />
|
||||||
<attr name="textColorPrimaryDisableOnly" format="color" />
|
<attr name="textColorPrimaryDisableOnly" format="color" />
|
||||||
<attr name="textColorPrimaryInverse" format="color" />
|
<attr name="textColorPrimaryInverse" format="color" />
|
||||||
|
|
||||||
<attr name="spinnerItemStyle" format="reference" />
|
<attr name="spinnerItemStyle" format="reference" />
|
||||||
<attr name="spinnerDropDownItemStyle" format="reference" />
|
<attr name="spinnerDropDownItemStyle" format="reference" />
|
||||||
|
|
||||||
@ -99,7 +101,7 @@
|
|||||||
<!-- List styles -->
|
<!-- List styles -->
|
||||||
<!-- =========== -->
|
<!-- =========== -->
|
||||||
<eat-comment />
|
<eat-comment />
|
||||||
|
|
||||||
<!-- A smaller, sleeker list item height. -->
|
<!-- A smaller, sleeker list item height. -->
|
||||||
<attr name="listPreferredItemHeightSmall" format="dimension" />
|
<attr name="listPreferredItemHeightSmall" format="dimension" />
|
||||||
|
|
||||||
@ -107,19 +109,19 @@
|
|||||||
<attr name="listPreferredItemPaddingLeft" format="dimension" />
|
<attr name="listPreferredItemPaddingLeft" format="dimension" />
|
||||||
<!-- The preferred padding along the right edge of list items. -->
|
<!-- The preferred padding along the right edge of list items. -->
|
||||||
<attr name="listPreferredItemPaddingRight" format="dimension" />
|
<attr name="listPreferredItemPaddingRight" format="dimension" />
|
||||||
|
|
||||||
<!-- The preferred TextAppearance for the primary text of small list items. -->
|
<!-- The preferred TextAppearance for the primary text of small list items. -->
|
||||||
<attr name="textAppearanceListItemSmall" format="reference" />
|
<attr name="textAppearanceListItemSmall" format="reference" />
|
||||||
|
|
||||||
|
|
||||||
<attr name="windowMinWidthMajor" format="dimension" />
|
<attr name="windowMinWidthMajor" format="dimension" />
|
||||||
<attr name="windowMinWidthMinor" format="dimension" />
|
<attr name="windowMinWidthMinor" format="dimension" />
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!-- Drawable to use for generic vertical dividers. -->
|
<!-- Drawable to use for generic vertical dividers. -->
|
||||||
<attr name="dividerVertical" format="reference" />
|
<attr name="dividerVertical" format="reference" />
|
||||||
|
|
||||||
<attr name="actionDropDownStyle" format="reference" />
|
<attr name="actionDropDownStyle" format="reference" />
|
||||||
<attr name="actionButtonStyle" format="reference" />
|
<attr name="actionButtonStyle" format="reference" />
|
||||||
<attr name="homeAsUpIndicator" format="reference" />
|
<attr name="homeAsUpIndicator" format="reference" />
|
||||||
@ -132,13 +134,22 @@
|
|||||||
<attr name="windowActionBarOverlay" format="boolean"/>
|
<attr name="windowActionBarOverlay" format="boolean"/>
|
||||||
<attr name="windowActionModeOverlay" format="boolean"/>
|
<attr name="windowActionModeOverlay" format="boolean"/>
|
||||||
<attr name="windowSplitActionBar" format="boolean" />
|
<attr name="windowSplitActionBar" format="boolean" />
|
||||||
|
|
||||||
|
|
||||||
|
<attr name="listPopupWindowStyle" format="reference" />
|
||||||
|
|
||||||
|
|
||||||
|
<!-- Default ActivityChooserView style. -->
|
||||||
|
<attr name="activityChooserViewStyle" format="reference" />
|
||||||
|
<!-- Drawable used as a background for activated items. -->
|
||||||
|
<attr name="activatedBackgroundIndicator" format="reference" />
|
||||||
|
|
||||||
<!-- Specified if we are forcing an action item overflow menu. -->
|
<!-- Specified if we are forcing an action item overflow menu. -->
|
||||||
<attr name="absForceOverflow" format="boolean" />
|
<attr name="absForceOverflow" format="boolean" />
|
||||||
|
|
||||||
<attr name="android:windowIsFloating" />
|
<attr name="android:windowIsFloating" />
|
||||||
</declare-styleable>
|
</declare-styleable>
|
||||||
|
|
||||||
|
|
||||||
<!-- Attributes used to style the Action Bar. -->
|
<!-- Attributes used to style the Action Bar. -->
|
||||||
<declare-styleable name="SherlockActionBar">
|
<declare-styleable name="SherlockActionBar">
|
||||||
@ -196,7 +207,7 @@
|
|||||||
system-provided items in the bar. -->
|
system-provided items in the bar. -->
|
||||||
<attr name="itemPadding" format="dimension" />
|
<attr name="itemPadding" format="dimension" />
|
||||||
</declare-styleable>
|
</declare-styleable>
|
||||||
|
|
||||||
|
|
||||||
<declare-styleable name="SherlockActionMode">
|
<declare-styleable name="SherlockActionMode">
|
||||||
<!-- Specifies a style to use for title text. -->
|
<!-- Specifies a style to use for title text. -->
|
||||||
@ -210,7 +221,7 @@
|
|||||||
<!-- Specifies a fixed height for the action mode bar. -->
|
<!-- Specifies a fixed height for the action mode bar. -->
|
||||||
<attr name="height" />
|
<attr name="height" />
|
||||||
</declare-styleable>
|
</declare-styleable>
|
||||||
|
|
||||||
<declare-styleable name="SherlockMenuView">
|
<declare-styleable name="SherlockMenuView">
|
||||||
<!-- Default appearance of menu item text. -->
|
<!-- Default appearance of menu item text. -->
|
||||||
<attr name="itemTextAppearance" format="reference" />
|
<attr name="itemTextAppearance" format="reference" />
|
||||||
@ -229,11 +240,25 @@
|
|||||||
<!-- Whether space should be reserved in layout when an icon is missing. -->
|
<!-- Whether space should be reserved in layout when an icon is missing. -->
|
||||||
<attr name="preserveIconSpacing" format="boolean" />
|
<attr name="preserveIconSpacing" format="boolean" />
|
||||||
</declare-styleable>
|
</declare-styleable>
|
||||||
|
|
||||||
<declare-styleable name="SherlockActionMenuItemView">
|
<declare-styleable name="SherlockActionMenuItemView">
|
||||||
<attr name="android:minWidth" />
|
<attr name="android:minWidth" />
|
||||||
</declare-styleable>
|
</declare-styleable>
|
||||||
|
|
||||||
|
<declare-styleable name="SherlockActivityChooserView">
|
||||||
|
<!-- The maximal number of items initially shown in the activity list. -->
|
||||||
|
<attr name="initialActivityCount" format="string" />
|
||||||
|
<!-- The drawable to show in the button for expanding the activities overflow popup.
|
||||||
|
<strong>Note:</strong> Clients would like to set this drawable
|
||||||
|
as a clue about the action the chosen activity will perform. For
|
||||||
|
example, if share activity is to be chosen the drawable should
|
||||||
|
give a clue that sharing is to be performed.
|
||||||
|
-->
|
||||||
|
<attr name="expandActivityOverflowButtonDrawable" format="reference" />
|
||||||
|
|
||||||
|
<attr name="android:background" />
|
||||||
|
</declare-styleable>
|
||||||
|
|
||||||
<!-- Base attributes that are available to all groups. -->
|
<!-- Base attributes that are available to all groups. -->
|
||||||
<declare-styleable name="SherlockMenuGroup">
|
<declare-styleable name="SherlockMenuGroup">
|
||||||
|
|
||||||
@ -329,7 +354,7 @@
|
|||||||
<attr name="android:actionProviderClass" />
|
<attr name="android:actionProviderClass" />
|
||||||
|
|
||||||
</declare-styleable>
|
</declare-styleable>
|
||||||
|
|
||||||
<declare-styleable name="SherlockSpinner">
|
<declare-styleable name="SherlockSpinner">
|
||||||
<!-- The prompt to display when the spinner's dialog is shown. -->
|
<!-- The prompt to display when the spinner's dialog is shown. -->
|
||||||
<attr name="android:prompt" />
|
<attr name="android:prompt" />
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
** limitations under the License.
|
** limitations under the License.
|
||||||
*/
|
*/
|
||||||
-->
|
-->
|
||||||
<resources>
|
<resources xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<!-- Content description for the action bar "home" affordance. [CHAR LIMIT=NONE] -->
|
<!-- Content description for the action bar "home" affordance. [CHAR LIMIT=NONE] -->
|
||||||
<string name="abs__action_bar_home_description">Navigate home</string>
|
<string name="abs__action_bar_home_description">Navigate home</string>
|
||||||
<!-- Content description for the action bar "up" affordance. [CHAR LIMIT=NONE] -->
|
<!-- Content description for the action bar "up" affordance. [CHAR LIMIT=NONE] -->
|
||||||
@ -26,4 +26,17 @@
|
|||||||
|
|
||||||
<!-- Label for the "Done" button on the far left of action mode toolbars. -->
|
<!-- Label for the "Done" button on the far left of action mode toolbars. -->
|
||||||
<string name="abs__action_mode_done">Done</string>
|
<string name="abs__action_mode_done">Done</string>
|
||||||
|
|
||||||
|
<!-- Title for a button to expand the list of activities in ActivityChooserView [CHAR LIMIT=25] -->
|
||||||
|
<string name="abs__activity_chooser_view_see_all">See all...</string>
|
||||||
|
<!-- Title default for a dialog showing possible activities in ActivityChooserView [CHAR LIMIT=25] -->
|
||||||
|
<string name="abs__activity_chooser_view_dialog_title_default">Select activity</string>
|
||||||
|
<!-- Title for a dialog showing possible activities for sharing in ShareActionProvider [CHAR LIMIT=25] -->
|
||||||
|
<string name="abs__share_action_provider_share_with">Share with...</string>
|
||||||
|
<!-- Description of the shwoing of a popup window with activities to choose from. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="abs__activitychooserview_choose_application">Choose an application</string>
|
||||||
|
<!-- Description of the choose target button in a ShareActionProvider (share UI). [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="abs__shareactionprovider_share_with">Share with</string>
|
||||||
|
<!-- Description of a share target (both in the list of such or the default share button) in a ShareActionProvider (share UI). [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="abs__shareactionprovider_share_with_application">Share with <xliff:g id="application_name" example="Bluetooth">%s</xliff:g></string>
|
||||||
</resources>
|
</resources>
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<resources>
|
<resources>
|
||||||
<style name="Widget">
|
<style name="Widget">
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Sherlock.__Widget.ActionBar" parent="Widget">
|
<style name="Sherlock.__Widget.ActionBar" parent="Widget">
|
||||||
<item name="displayOptions">useLogo|showHome|showTitle</item>
|
<item name="displayOptions">useLogo|showHome|showTitle</item>
|
||||||
<item name="height">?attr/actionBarSize</item>
|
<item name="height">?attr/actionBarSize</item>
|
||||||
@ -71,10 +71,10 @@
|
|||||||
<item name="progressBarPadding">32dip</item>
|
<item name="progressBarPadding">32dip</item>
|
||||||
<item name="itemPadding">8dip</item>
|
<item name="itemPadding">8dip</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Widget.Sherlock.ActionBar.TabView" parent="Widget">
|
<style name="Widget.Sherlock.ActionBar.TabView" parent="Widget">
|
||||||
<item name="android:gravity">center_horizontal</item>
|
<item name="android:gravity">center_horizontal</item>
|
||||||
<item name="android:background">@drawable/abs__tab_indicator_holo</item>
|
<item name="android:background">@drawable/abs__tab_indicator_ab_holo</item>
|
||||||
<item name="android:paddingLeft">16dip</item>
|
<item name="android:paddingLeft">16dip</item>
|
||||||
<item name="android:paddingRight">16dip</item>
|
<item name="android:paddingRight">16dip</item>
|
||||||
</style>
|
</style>
|
||||||
@ -82,7 +82,7 @@
|
|||||||
</style>
|
</style>
|
||||||
<style name="Widget.Sherlock.Light.ActionBar.TabView.Inverse">
|
<style name="Widget.Sherlock.Light.ActionBar.TabView.Inverse">
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Widget.Sherlock.ActionBar.TabBar" parent="Widget">
|
<style name="Widget.Sherlock.ActionBar.TabBar" parent="Widget">
|
||||||
<item name="android:divider">?attr/actionBarDivider</item>
|
<item name="android:divider">?attr/actionBarDivider</item>
|
||||||
<item name="android:showDividers">middle</item>
|
<item name="android:showDividers">middle</item>
|
||||||
@ -92,7 +92,7 @@
|
|||||||
</style>
|
</style>
|
||||||
<style name="Widget.Sherlock.Light.ActionBar.TabBar.Inverse">
|
<style name="Widget.Sherlock.Light.ActionBar.TabBar.Inverse">
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Widget.Sherlock.ActionBar.TabText" parent="Widget">
|
<style name="Widget.Sherlock.ActionBar.TabText" parent="Widget">
|
||||||
<item name="android:textAppearance">@null</item>
|
<item name="android:textAppearance">@null</item>
|
||||||
<item name="android:textColor">?attr/textColorPrimary</item>
|
<item name="android:textColor">?attr/textColorPrimary</item>
|
||||||
@ -111,8 +111,8 @@
|
|||||||
<style name="Widget.Sherlock.ActionButton" parent="Widget">
|
<style name="Widget.Sherlock.ActionButton" parent="Widget">
|
||||||
<item name="android:background">?attr/actionBarItemBackground</item>
|
<item name="android:background">?attr/actionBarItemBackground</item>
|
||||||
<item name="android:minHeight">?attr/actionBarSize</item>
|
<item name="android:minHeight">?attr/actionBarSize</item>
|
||||||
|
|
||||||
<item name="android:minWidth">56dip</item>
|
<item name="android:minWidth">@dimen/abs__action_button_min_width</item>
|
||||||
<item name="android:gravity">center</item>
|
<item name="android:gravity">center</item>
|
||||||
<item name="android:paddingLeft">12dip</item>
|
<item name="android:paddingLeft">12dip</item>
|
||||||
<item name="android:paddingRight">12dip</item>
|
<item name="android:paddingRight">12dip</item>
|
||||||
@ -120,14 +120,14 @@
|
|||||||
</style>
|
</style>
|
||||||
<style name="Widget.Sherlock.Light.ActionButton" parent="Widget.Sherlock.ActionButton">
|
<style name="Widget.Sherlock.Light.ActionButton" parent="Widget.Sherlock.ActionButton">
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Widget.Sherlock.ActionButton.CloseMode">
|
<style name="Widget.Sherlock.ActionButton.CloseMode">
|
||||||
<item name="android:background">@drawable/abs__btn_cab_done_holo_dark</item>
|
<item name="android:background">@drawable/abs__btn_cab_done_holo_dark</item>
|
||||||
</style>
|
</style>
|
||||||
<style name="Widget.Sherlock.Light.ActionButton.CloseMode">
|
<style name="Widget.Sherlock.Light.ActionButton.CloseMode">
|
||||||
<item name="android:background">@drawable/abs__btn_cab_done_holo_light</item>
|
<item name="android:background">@drawable/abs__btn_cab_done_holo_light</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Widget.Sherlock.ActionButton.Overflow">
|
<style name="Widget.Sherlock.ActionButton.Overflow">
|
||||||
<item name="android:src">@drawable/abs__ic_menu_moreoverflow_holo_dark</item>
|
<item name="android:src">@drawable/abs__ic_menu_moreoverflow_holo_dark</item>
|
||||||
<item name="android:background">?attr/actionBarItemBackground</item>
|
<item name="android:background">?attr/actionBarItemBackground</item>
|
||||||
@ -136,7 +136,7 @@
|
|||||||
<style name="Widget.Sherlock.Light.ActionButton.Overflow">
|
<style name="Widget.Sherlock.Light.ActionButton.Overflow">
|
||||||
<item name="android:src">@drawable/abs__ic_menu_moreoverflow_holo_light</item>
|
<item name="android:src">@drawable/abs__ic_menu_moreoverflow_holo_light</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Sherlock.__Widget.ActionMode" parent="Widget">
|
<style name="Sherlock.__Widget.ActionMode" parent="Widget">
|
||||||
<item name="background">?attr/actionModeBackground</item>
|
<item name="background">?attr/actionModeBackground</item>
|
||||||
<item name="backgroundSplit">?attr/actionModeSplitBackground</item>
|
<item name="backgroundSplit">?attr/actionModeSplitBackground</item>
|
||||||
@ -154,22 +154,53 @@
|
|||||||
<item name="titleTextStyle">@style/TextAppearance.Sherlock.Widget.ActionMode.Title.Inverse</item>
|
<item name="titleTextStyle">@style/TextAppearance.Sherlock.Widget.ActionMode.Title.Inverse</item>
|
||||||
<item name="subtitleTextStyle">@style/TextAppearance.Sherlock.Widget.ActionMode.Subtitle.Inverse</item>
|
<item name="subtitleTextStyle">@style/TextAppearance.Sherlock.Widget.ActionMode.Subtitle.Inverse</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
|
|
||||||
<style name="Widget.Sherlock.PopupMenu" parent="Widget">
|
<style name="Widget.Sherlock.ListPopupWindow" parent="Widget">
|
||||||
<item name="android:dropDownSelector">@drawable/abs__list_selector_holo_dark</item>
|
<item name="android:dropDownSelector">@drawable/abs__list_selector_holo_dark</item>
|
||||||
<item name="android:popupBackground">@drawable/abs__menu_dropdown_panel_holo_dark</item>
|
<item name="android:popupBackground">@drawable/abs__menu_dropdown_panel_holo_dark</item>
|
||||||
<item name="android:dropDownVerticalOffset">0dip</item>
|
<item name="android:dropDownVerticalOffset">0dip</item>
|
||||||
<item name="android:dropDownHorizontalOffset">0dip</item>
|
<item name="android:dropDownHorizontalOffset">0dip</item>
|
||||||
<item name="android:dropDownWidth">wrap_content</item>
|
<item name="android:dropDownWidth">wrap_content</item>
|
||||||
</style>
|
</style>
|
||||||
<style name="Widget.Sherlock.Light.PopupMenu" parent="Widget">
|
<style name="Widget.Sherlock.Light.ListPopupWindow" parent="Widget">
|
||||||
<item name="android:dropDownSelector">@drawable/abs__list_selector_holo_light</item>
|
<item name="android:dropDownSelector">@drawable/abs__list_selector_holo_light</item>
|
||||||
<item name="android:popupBackground">@drawable/abs__menu_dropdown_panel_holo_light</item>
|
<item name="android:popupBackground">@drawable/abs__menu_dropdown_panel_holo_light</item>
|
||||||
<item name="android:dropDownVerticalOffset">0dip</item>
|
<item name="android:dropDownVerticalOffset">0dip</item>
|
||||||
<item name="android:dropDownHorizontalOffset">0dip</item>
|
<item name="android:dropDownHorizontalOffset">0dip</item>
|
||||||
<item name="android:dropDownWidth">wrap_content</item>
|
<item name="android:dropDownWidth">wrap_content</item>
|
||||||
</style>
|
</style>
|
||||||
|
<style name="Widget.Sherlock.PopupMenu" parent="Widget.Sherlock.ListPopupWindow">
|
||||||
|
</style>
|
||||||
|
<style name="Widget.Sherlock.Light.PopupMenu" parent="Widget.Sherlock.Light.ListPopupWindow">
|
||||||
|
</style>
|
||||||
|
|
||||||
|
|
||||||
|
<style name="Sherlock.__Widget.ActivityChooserView" parent="Widget">
|
||||||
|
<item name="android:gravity">center</item>
|
||||||
|
<item name="android:background">@drawable/abs__ab_share_pack_holo_dark</item>
|
||||||
|
<item name="android:divider">?attr/dividerVertical</item>
|
||||||
|
<item name="android:showDividers">middle</item>
|
||||||
|
<item name="android:dividerPadding">6dip</item>
|
||||||
|
</style>
|
||||||
|
<style name="Widget.Sherlock.ActivityChooserView" parent="Sherlock.__Widget.ActivityChooserView">
|
||||||
|
</style>
|
||||||
|
<style name="Widget.Sherlock.Light.ActivityChooserView" parent="Widget.Sherlock.ActivityChooserView">
|
||||||
|
<item name="android:background">@drawable/abs__ab_share_pack_holo_light</item>
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<style name="Widget.Sherlock.Button.Small" parent="Widget">
|
||||||
|
<item name="android:textAppearance">?attr/textAppearanceSmall</item>
|
||||||
|
<item name="android:textColor">@color/abs__primary_text_holo_dark</item>
|
||||||
|
<item name="android:minHeight">48dip</item>
|
||||||
|
<item name="android:minWidth">48dip</item>
|
||||||
|
</style>
|
||||||
|
<style name="Widget.Sherlock.Light.Button.Small" parent="Widget">
|
||||||
|
<item name="android:textAppearance">?attr/textAppearanceSmall</item>
|
||||||
|
<item name="android:textColor">@color/abs__primary_text_holo_light</item>
|
||||||
|
<item name="android:minHeight">48dip</item>
|
||||||
|
<item name="android:minWidth">48dip</item>
|
||||||
|
</style>
|
||||||
|
|
||||||
|
|
||||||
<style name="Sherlock.__Widget.Holo.Spinner" parent="Widget">
|
<style name="Sherlock.__Widget.Holo.Spinner" parent="Widget">
|
||||||
@ -190,7 +221,7 @@
|
|||||||
<item name="android:dropDownSelector">@drawable/abs__list_selector_holo_light</item>
|
<item name="android:dropDownSelector">@drawable/abs__list_selector_holo_light</item>
|
||||||
<item name="android:popupBackground">@drawable/abs__menu_dropdown_panel_holo_light</item>
|
<item name="android:popupBackground">@drawable/abs__menu_dropdown_panel_holo_light</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Sherlock.__Widget.Holo.ListView" parent="android:Widget.ListView">
|
<style name="Sherlock.__Widget.Holo.ListView" parent="android:Widget.ListView">
|
||||||
<item name="android:divider">@drawable/abs__list_divider_holo_dark</item>
|
<item name="android:divider">@drawable/abs__list_divider_holo_dark</item>
|
||||||
<item name="android:listSelector">@drawable/abs__list_selector_holo_dark</item>
|
<item name="android:listSelector">@drawable/abs__list_selector_holo_dark</item>
|
||||||
@ -306,7 +337,7 @@
|
|||||||
<item name="android:textSize">@dimen/abs__action_bar_subtitle_text_size</item>
|
<item name="android:textSize">@dimen/abs__action_bar_subtitle_text_size</item>
|
||||||
<item name="android:textColor">?android:attr/textColorPrimaryInverse</item>
|
<item name="android:textColor">?android:attr/textColorPrimaryInverse</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="TextAppearance.Sherlock.Widget.PopupMenu" parent="Widget">
|
<style name="TextAppearance.Sherlock.Widget.PopupMenu" parent="Widget">
|
||||||
<item name="android:textColor">?attr/textColorPrimary</item>
|
<item name="android:textColor">?attr/textColorPrimary</item>
|
||||||
</style>
|
</style>
|
||||||
@ -320,19 +351,19 @@
|
|||||||
</style>
|
</style>
|
||||||
<style name="TextAppearance.Sherlock.Light.Widget.PopupMenu.Small" parent="TextAppearance.Sherlock.Widget.PopupMenu.Small">
|
<style name="TextAppearance.Sherlock.Light.Widget.PopupMenu.Small" parent="TextAppearance.Sherlock.Widget.PopupMenu.Small">
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="TextAppearance.Sherlock.Widget.TextView.SpinnerItem" parent="Widget">
|
<style name="TextAppearance.Sherlock.Widget.TextView.SpinnerItem" parent="Widget">
|
||||||
<item name="android:textColor">?textColorPrimary</item>
|
<item name="android:textColor">?textColorPrimary</item>
|
||||||
<item name="android:textSize">16sp</item>
|
<item name="android:textSize">16sp</item>
|
||||||
<item name="android:textStyle">normal</item>
|
<item name="android:textStyle">normal</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="TextAppearance.Sherlock.Widget.DropDownItem" parent="Widget">
|
<style name="TextAppearance.Sherlock.Widget.DropDownItem" parent="Widget">
|
||||||
<item name="android:textColor">?textColorPrimaryDisableOnly</item>
|
<item name="android:textColor">?textColorPrimaryDisableOnly</item>
|
||||||
<item name="android:textSize">16sp</item>
|
<item name="android:textSize">16sp</item>
|
||||||
<item name="android:textStyle">normal</item>
|
<item name="android:textStyle">normal</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="TextAppearance.Sherlock.DialogWindowTitle" parent="Widget">
|
<style name="TextAppearance.Sherlock.DialogWindowTitle" parent="Widget">
|
||||||
<item name="android:textSize">22sp</item>
|
<item name="android:textSize">22sp</item>
|
||||||
<item name="android:textColor">@color/abs__holo_blue_light</item>
|
<item name="android:textColor">@color/abs__holo_blue_light</item>
|
||||||
@ -341,4 +372,13 @@
|
|||||||
<item name="android:textSize">22sp</item>
|
<item name="android:textSize">22sp</item>
|
||||||
<item name="android:textColor">@color/abs__holo_blue_light</item>
|
<item name="android:textColor">@color/abs__holo_blue_light</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
|
<style name="Sherlock.__TextAppearance.Small" parent="Widget">
|
||||||
|
<item name="android:textSize">14sp</item>
|
||||||
|
<item name="android:textColor">?android:attr/textColorSecondary</item>
|
||||||
|
</style>
|
||||||
|
<style name="TextAppearance.Sherlock.Small" parent="Sherlock.__TextAppearance.Small">
|
||||||
|
</style>
|
||||||
|
<style name="TextAppearance.Sherlock.Light.Small" parent="TextAppearance.Sherlock.Small">
|
||||||
|
</style>
|
||||||
</resources>
|
</resources>
|
||||||
|
@ -36,6 +36,12 @@
|
|||||||
<item name="actionMenuTextColor">?attr/textColorPrimary</item>
|
<item name="actionMenuTextColor">?attr/textColorPrimary</item>
|
||||||
<item name="actionBarDivider">?attr/dividerVertical</item>
|
<item name="actionBarDivider">?attr/dividerVertical</item>
|
||||||
<item name="actionBarItemBackground">@drawable/abs__item_background_holo_dark</item>
|
<item name="actionBarItemBackground">@drawable/abs__item_background_holo_dark</item>
|
||||||
|
|
||||||
|
<item name="buttonStyleSmall">@style/Widget.Sherlock.Button.Small</item>
|
||||||
|
|
||||||
|
<item name="activatedBackgroundIndicator">@drawable/abs__activated_background_holo_dark</item>
|
||||||
|
<item name="actionModeShareDrawable">@drawable/abs__ic_menu_share_holo_dark</item>
|
||||||
|
<item name="activityChooserViewStyle">@style/Widget.Sherlock.ActivityChooserView</item>
|
||||||
|
|
||||||
<item name="homeAsUpIndicator">@drawable/abs__ic_ab_back_holo_dark</item>
|
<item name="homeAsUpIndicator">@drawable/abs__ic_ab_back_holo_dark</item>
|
||||||
|
|
||||||
@ -50,11 +56,13 @@
|
|||||||
|
|
||||||
<!-- Internal --><item name="dropdownListPreferredItemHeight">48dip</item>
|
<!-- Internal --><item name="dropdownListPreferredItemHeight">48dip</item>
|
||||||
<item name="dropDownListViewStyle">@style/Widget.Sherlock.ListView.DropDown</item>
|
<item name="dropDownListViewStyle">@style/Widget.Sherlock.ListView.DropDown</item>
|
||||||
|
|
||||||
|
<item name="textAppearanceSmall">@style/TextAppearance.Sherlock.Small</item>
|
||||||
<item name="textAppearanceLargePopupMenu">@style/TextAppearance.Sherlock.Widget.PopupMenu.Large</item>
|
<item name="textAppearanceLargePopupMenu">@style/TextAppearance.Sherlock.Widget.PopupMenu.Large</item>
|
||||||
<item name="textAppearanceSmallPopupMenu">@style/TextAppearance.Sherlock.Widget.PopupMenu.Small</item>
|
<item name="textAppearanceSmallPopupMenu">@style/TextAppearance.Sherlock.Widget.PopupMenu.Small</item>
|
||||||
|
|
||||||
<item name="popupMenuStyle">@style/Widget.Sherlock.PopupMenu</item>
|
<item name="popupMenuStyle">@style/Widget.Sherlock.PopupMenu</item>
|
||||||
|
<!-- Internal --><item name="listPopupWindowStyle">@style/Widget.Sherlock.ListPopupWindow</item>
|
||||||
|
|
||||||
<item name="windowActionBar">true</item>
|
<item name="windowActionBar">true</item>
|
||||||
<item name="windowActionModeOverlay">false</item>
|
<item name="windowActionModeOverlay">false</item>
|
||||||
@ -84,6 +92,12 @@
|
|||||||
<item name="actionMenuTextColor">?attr/textColorPrimary</item>
|
<item name="actionMenuTextColor">?attr/textColorPrimary</item>
|
||||||
<item name="actionBarDivider">?attr/dividerVertical</item>
|
<item name="actionBarDivider">?attr/dividerVertical</item>
|
||||||
<item name="actionBarItemBackground">@drawable/abs__item_background_holo_light</item>
|
<item name="actionBarItemBackground">@drawable/abs__item_background_holo_light</item>
|
||||||
|
|
||||||
|
<item name="buttonStyleSmall">@style/Widget.Sherlock.Light.Button.Small</item>
|
||||||
|
|
||||||
|
<item name="activatedBackgroundIndicator">@drawable/abs__activated_background_holo_light</item>
|
||||||
|
<item name="actionModeShareDrawable">@drawable/abs__ic_menu_share_holo_light</item>
|
||||||
|
<item name="activityChooserViewStyle">@style/Widget.Sherlock.Light.ActivityChooserView</item>
|
||||||
|
|
||||||
<item name="homeAsUpIndicator">@drawable/abs__ic_ab_back_holo_light</item>
|
<item name="homeAsUpIndicator">@drawable/abs__ic_ab_back_holo_light</item>
|
||||||
|
|
||||||
@ -98,11 +112,13 @@
|
|||||||
|
|
||||||
<!-- Internal --><item name="dropdownListPreferredItemHeight">48dip</item>
|
<!-- Internal --><item name="dropdownListPreferredItemHeight">48dip</item>
|
||||||
<item name="dropDownListViewStyle">@style/Widget.Sherlock.Light.ListView.DropDown</item>
|
<item name="dropDownListViewStyle">@style/Widget.Sherlock.Light.ListView.DropDown</item>
|
||||||
|
|
||||||
|
<item name="textAppearanceSmall">@style/TextAppearance.Sherlock.Light.Small</item>
|
||||||
<item name="textAppearanceLargePopupMenu">@style/TextAppearance.Sherlock.Light.Widget.PopupMenu.Large</item>
|
<item name="textAppearanceLargePopupMenu">@style/TextAppearance.Sherlock.Light.Widget.PopupMenu.Large</item>
|
||||||
<item name="textAppearanceSmallPopupMenu">@style/TextAppearance.Sherlock.Light.Widget.PopupMenu.Small</item>
|
<item name="textAppearanceSmallPopupMenu">@style/TextAppearance.Sherlock.Light.Widget.PopupMenu.Small</item>
|
||||||
|
|
||||||
<item name="popupMenuStyle">@style/Widget.Sherlock.Light.PopupMenu</item>
|
<item name="popupMenuStyle">@style/Widget.Sherlock.Light.PopupMenu</item>
|
||||||
|
<!-- Internal --><item name="listPopupWindowStyle">@style/Widget.Sherlock.Light.ListPopupWindow</item>
|
||||||
|
|
||||||
<item name="windowActionBar">true</item>
|
<item name="windowActionBar">true</item>
|
||||||
<item name="windowActionModeOverlay">false</item>
|
<item name="windowActionModeOverlay">false</item>
|
||||||
@ -125,10 +141,12 @@
|
|||||||
<item name="actionBarTabTextStyle">@style/Widget.Sherlock.Light.ActionBar.TabText.Inverse</item>
|
<item name="actionBarTabTextStyle">@style/Widget.Sherlock.Light.ActionBar.TabText.Inverse</item>
|
||||||
<item name="actionBarDivider">@drawable/abs__list_divider_holo_dark</item>
|
<item name="actionBarDivider">@drawable/abs__list_divider_holo_dark</item>
|
||||||
<item name="actionBarItemBackground">@drawable/abs__item_background_holo_dark</item>
|
<item name="actionBarItemBackground">@drawable/abs__item_background_holo_dark</item>
|
||||||
<item name="actionMenuTextColor">?android:attr/textColorPrimaryInverse</item>
|
<item name="actionMenuTextColor">?attr/textColorPrimaryInverse</item>
|
||||||
<item name="actionModeStyle">@style/Widget.Sherlock.Light.ActionMode.Inverse</item>
|
<item name="actionModeStyle">@style/Widget.Sherlock.Light.ActionMode.Inverse</item>
|
||||||
<item name="actionModeCloseButtonStyle">@style/Widget.Sherlock.ActionButton.CloseMode</item>
|
<item name="actionModeCloseButtonStyle">@style/Widget.Sherlock.ActionButton.CloseMode</item>
|
||||||
<item name="actionModePopupWindowStyle">@style/Widget.Sherlock.PopupWindow.ActionMode</item>
|
<item name="actionModePopupWindowStyle">@style/Widget.Sherlock.PopupWindow.ActionMode</item>
|
||||||
|
|
||||||
|
<item name="actionModeShareDrawable">@drawable/abs__ic_menu_share_holo_dark</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
|
|
||||||
|
@ -37,7 +37,6 @@ import com.actionbarsherlock.view.MenuItem;
|
|||||||
* counterpart and you should refer to its documentation for instruction.</p>
|
* counterpart and you should refer to its documentation for instruction.</p>
|
||||||
*
|
*
|
||||||
* @author Jake Wharton <jakewharton@gmail.com>
|
* @author Jake Wharton <jakewharton@gmail.com>
|
||||||
* @version 4.0.0
|
|
||||||
*/
|
*/
|
||||||
public abstract class ActionBarSherlock {
|
public abstract class ActionBarSherlock {
|
||||||
protected static final String TAG = "ActionBarSherlock";
|
protected static final String TAG = "ActionBarSherlock";
|
||||||
|
@ -34,7 +34,9 @@ public class SherlockDialogFragment extends DialogFragment {
|
|||||||
if (DEBUG) Log.d(TAG, "[onCreateOptionsMenu] menu: " + menu + ", inflater: " + inflater);
|
if (DEBUG) Log.d(TAG, "[onCreateOptionsMenu] menu: " + menu + ", inflater: " + inflater);
|
||||||
|
|
||||||
if (menu instanceof MenuMule) {
|
if (menu instanceof MenuMule) {
|
||||||
onCreateOptionsMenu(((MenuMule)menu).unwrap(), mActivity.getSupportMenuInflater());
|
MenuMule mule = (MenuMule)menu;
|
||||||
|
mule.mDispatchShow = true;
|
||||||
|
onCreateOptionsMenu(mule.unwrap(), mActivity.getSupportMenuInflater());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,7 +49,9 @@ public class SherlockDialogFragment extends DialogFragment {
|
|||||||
if (DEBUG) Log.d(TAG, "[onPrepareOptionsMenu] menu: " + menu);
|
if (DEBUG) Log.d(TAG, "[onPrepareOptionsMenu] menu: " + menu);
|
||||||
|
|
||||||
if (menu instanceof MenuMule) {
|
if (menu instanceof MenuMule) {
|
||||||
onPrepareOptionsMenu(((MenuMule)menu).unwrap());
|
MenuMule mule = (MenuMule)menu;
|
||||||
|
mule.mDispatchShow = true;
|
||||||
|
onPrepareOptionsMenu(mule.unwrap());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,7 +34,9 @@ public class SherlockFragment extends Fragment {
|
|||||||
if (DEBUG) Log.d(TAG, "[onCreateOptionsMenu] menu: " + menu + ", inflater: " + inflater);
|
if (DEBUG) Log.d(TAG, "[onCreateOptionsMenu] menu: " + menu + ", inflater: " + inflater);
|
||||||
|
|
||||||
if (menu instanceof MenuMule) {
|
if (menu instanceof MenuMule) {
|
||||||
onCreateOptionsMenu(((MenuMule)menu).unwrap(), mActivity.getSupportMenuInflater());
|
MenuMule mule = (MenuMule)menu;
|
||||||
|
mule.mDispatchShow = true;
|
||||||
|
onCreateOptionsMenu(mule.unwrap(), mActivity.getSupportMenuInflater());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,7 +49,9 @@ public class SherlockFragment extends Fragment {
|
|||||||
if (DEBUG) Log.d(TAG, "[onPrepareOptionsMenu] menu: " + menu);
|
if (DEBUG) Log.d(TAG, "[onPrepareOptionsMenu] menu: " + menu);
|
||||||
|
|
||||||
if (menu instanceof MenuMule) {
|
if (menu instanceof MenuMule) {
|
||||||
onPrepareOptionsMenu(((MenuMule)menu).unwrap());
|
MenuMule mule = (MenuMule)menu;
|
||||||
|
mule.mDispatchShow = true;
|
||||||
|
onPrepareOptionsMenu(mule.unwrap());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
package com.actionbarsherlock.app;
|
package com.actionbarsherlock.app;
|
||||||
|
|
||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.support.v4.app.FragmentActivity;
|
import android.support.v4.app.FragmentActivity;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
@ -30,7 +29,6 @@ public abstract class SherlockFragmentActivity extends FragmentActivity implemen
|
|||||||
private boolean mIgnoreNativeCreate = false;
|
private boolean mIgnoreNativeCreate = false;
|
||||||
private boolean mIgnoreNativePrepare = false;
|
private boolean mIgnoreNativePrepare = false;
|
||||||
private boolean mIgnoreNativeSelected = false;
|
private boolean mIgnoreNativeSelected = false;
|
||||||
private Boolean mOverrideNativeCreate = null;
|
|
||||||
|
|
||||||
protected final ActionBarSherlock getSherlock() {
|
protected final ActionBarSherlock getSherlock() {
|
||||||
if (mSherlock == null) {
|
if (mSherlock == null) {
|
||||||
@ -138,7 +136,7 @@ public abstract class SherlockFragmentActivity extends FragmentActivity implemen
|
|||||||
getSherlock().dispatchInvalidateOptionsMenu();
|
getSherlock().dispatchInvalidateOptionsMenu();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void supportInvalidateOptionsMenu() {
|
public void supportInvalidateOptionsMenu() {
|
||||||
if (DEBUG) Log.d(TAG, "[supportInvalidateOptionsMenu]");
|
if (DEBUG) Log.d(TAG, "[supportInvalidateOptionsMenu]");
|
||||||
|
|
||||||
invalidateOptionsMenu();
|
invalidateOptionsMenu();
|
||||||
@ -161,7 +159,7 @@ public abstract class SherlockFragmentActivity extends FragmentActivity implemen
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final boolean onCreateOptionsMenu(android.view.Menu menu) {
|
public final boolean onCreateOptionsMenu(android.view.Menu menu) {
|
||||||
return (mOverrideNativeCreate != null) ? mOverrideNativeCreate.booleanValue() : true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -229,19 +227,17 @@ public abstract class SherlockFragmentActivity extends FragmentActivity implemen
|
|||||||
|
|
||||||
if (featureId == Window.FEATURE_OPTIONS_PANEL) {
|
if (featureId == Window.FEATURE_OPTIONS_PANEL) {
|
||||||
boolean result = onCreateOptionsMenu(menu);
|
boolean result = onCreateOptionsMenu(menu);
|
||||||
|
if (DEBUG) Log.d(TAG, "[onCreatePanelMenu] activity create result: " + result);
|
||||||
|
|
||||||
//Dispatch to parent panel creation for fragment dispatching
|
//Dispatch to parent panel creation for fragment dispatching
|
||||||
if (DEBUG) Log.d(TAG, "[onCreatePanelMenu] dispatching to native with mule");
|
if (DEBUG) Log.d(TAG, "[onCreatePanelMenu] dispatching to native with mule");
|
||||||
mOverrideNativeCreate = result;
|
MenuMule mule = new MenuMule(menu);
|
||||||
boolean fragResult = super.onCreatePanelMenu(featureId, new MenuMule(menu));
|
super.onCreatePanelMenu(featureId, mule);
|
||||||
mOverrideNativeCreate = null;
|
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.HONEYCOMB) {
|
if (DEBUG) Log.d(TAG, "[onCreatePanelMenu] fragments create result: " + mule.mDispatchShow);
|
||||||
result |= menu.hasVisibleItems();
|
result |= mule.mDispatchShow;
|
||||||
} else {
|
|
||||||
result |= fragResult;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if (DEBUG) Log.d(TAG, "[onCreatePanelMenu] returning " + result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -257,11 +253,18 @@ public abstract class SherlockFragmentActivity extends FragmentActivity implemen
|
|||||||
|
|
||||||
if (featureId == Window.FEATURE_OPTIONS_PANEL) {
|
if (featureId == Window.FEATURE_OPTIONS_PANEL) {
|
||||||
boolean result = onPrepareOptionsMenu(menu);
|
boolean result = onPrepareOptionsMenu(menu);
|
||||||
|
if (DEBUG) Log.d(TAG, "[onPreparePanel] activity prepare result: " + result);
|
||||||
|
|
||||||
//Dispatch to parent panel preparation for fragment dispatching
|
//Dispatch to parent panel preparation for fragment dispatching
|
||||||
if (DEBUG) Log.d(TAG, "[onPreparePanel] dispatching to native with mule");
|
if (DEBUG) Log.d(TAG, "[onPreparePanel] dispatching to native with mule");
|
||||||
super.onPreparePanel(featureId, view, new MenuMule(menu));
|
MenuMule mule = new MenuMule(menu);
|
||||||
|
super.onPreparePanel(featureId, view, mule);
|
||||||
|
|
||||||
|
if (DEBUG) Log.d(TAG, "[onPreparePanel] fragments prepare result: " + mule.mDispatchShow);
|
||||||
|
result |= mule.mDispatchShow;
|
||||||
|
|
||||||
|
result &= menu.hasVisibleItems();
|
||||||
|
if (DEBUG) Log.d(TAG, "[onPreparePanel] returning " + result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -276,13 +279,13 @@ public abstract class SherlockFragmentActivity extends FragmentActivity implemen
|
|||||||
if (DEBUG) Log.d(TAG, "[onMenuItemSelected] featureId: " + featureId + ", item: " + item);
|
if (DEBUG) Log.d(TAG, "[onMenuItemSelected] featureId: " + featureId + ", item: " + item);
|
||||||
|
|
||||||
if (featureId == Window.FEATURE_OPTIONS_PANEL) {
|
if (featureId == Window.FEATURE_OPTIONS_PANEL) {
|
||||||
boolean result = onOptionsItemSelected(item);
|
if (onOptionsItemSelected(item)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
//Dispatch to parent panel selection for fragment dispatching
|
//Dispatch to parent panel selection for fragment dispatching
|
||||||
if (DEBUG) Log.d(TAG, "[onMenuItemSelected] dispatching to native with mule");
|
if (DEBUG) Log.d(TAG, "[onMenuItemSelected] dispatching to native with mule");
|
||||||
result |= super.onMenuItemSelected(featureId, new MenuItemMule(item));
|
return super.onMenuItemSelected(featureId, new MenuItemMule(item));
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -34,7 +34,9 @@ public class SherlockListFragment extends ListFragment {
|
|||||||
if (DEBUG) Log.d(TAG, "[onCreateOptionsMenu] menu: " + menu + ", inflater: " + inflater);
|
if (DEBUG) Log.d(TAG, "[onCreateOptionsMenu] menu: " + menu + ", inflater: " + inflater);
|
||||||
|
|
||||||
if (menu instanceof MenuMule) {
|
if (menu instanceof MenuMule) {
|
||||||
onCreateOptionsMenu(((MenuMule)menu).unwrap(), mActivity.getSupportMenuInflater());
|
MenuMule mule = (MenuMule)menu;
|
||||||
|
mule.mDispatchShow = true;
|
||||||
|
onCreateOptionsMenu(mule.unwrap(), mActivity.getSupportMenuInflater());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,7 +49,9 @@ public class SherlockListFragment extends ListFragment {
|
|||||||
if (DEBUG) Log.d(TAG, "[onPrepareOptionsMenu] menu: " + menu);
|
if (DEBUG) Log.d(TAG, "[onPrepareOptionsMenu] menu: " + menu);
|
||||||
|
|
||||||
if (menu instanceof MenuMule) {
|
if (menu instanceof MenuMule) {
|
||||||
onPrepareOptionsMenu(((MenuMule)menu).unwrap());
|
MenuMule mule = (MenuMule)menu;
|
||||||
|
mule.mDispatchShow = true;
|
||||||
|
onPrepareOptionsMenu(mule.unwrap());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,6 +71,8 @@ public class ActionBarSherlockCompat extends ActionBarSherlock implements MenuBu
|
|||||||
private MenuBuilder mMenu;
|
private MenuBuilder mMenu;
|
||||||
/** Map between native options items and sherlock items. */
|
/** Map between native options items and sherlock items. */
|
||||||
protected HashMap<android.view.MenuItem, MenuItemImpl> mNativeItemMap;
|
protected HashMap<android.view.MenuItem, MenuItemImpl> mNativeItemMap;
|
||||||
|
/** Indication of a long-press on the hardware menu key. */
|
||||||
|
private boolean mMenuKeyIsLongPress = false;
|
||||||
|
|
||||||
/** Parent view of the window decoration (action bar, mode, etc.). */
|
/** Parent view of the window decoration (action bar, mode, etc.). */
|
||||||
private ViewGroup mDecor;
|
private ViewGroup mDecor;
|
||||||
@ -318,6 +320,10 @@ public class ActionBarSherlockCompat extends ActionBarSherlock implements MenuBu
|
|||||||
public boolean dispatchPrepareOptionsMenu(android.view.Menu menu) {
|
public boolean dispatchPrepareOptionsMenu(android.view.Menu menu) {
|
||||||
if (DEBUG) Log.d(TAG, "[dispatchPrepareOptionsMenu] android.view.Menu: " + menu);
|
if (DEBUG) Log.d(TAG, "[dispatchPrepareOptionsMenu] android.view.Menu: " + menu);
|
||||||
|
|
||||||
|
if (mActionMode != null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
mMenuIsPrepared = false;
|
mMenuIsPrepared = false;
|
||||||
if (!preparePanel()) {
|
if (!preparePanel()) {
|
||||||
return false;
|
return false;
|
||||||
@ -416,20 +422,27 @@ public class ActionBarSherlockCompat extends ActionBarSherlock implements MenuBu
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (keyCode == KeyEvent.KEYCODE_MENU && event.getAction() == KeyEvent.ACTION_UP && isReservingOverflow()) {
|
boolean result = false;
|
||||||
if (mActionMode == null) {
|
if (keyCode == KeyEvent.KEYCODE_MENU && isReservingOverflow()) {
|
||||||
if (wActionBar.isOverflowMenuShowing()) {
|
if (event.getAction() == KeyEvent.ACTION_DOWN && event.isLongPress()) {
|
||||||
wActionBar.hideOverflowMenu();
|
mMenuKeyIsLongPress = true;
|
||||||
} else {
|
} else if (event.getAction() == KeyEvent.ACTION_UP) {
|
||||||
wActionBar.showOverflowMenu();
|
if (!mMenuKeyIsLongPress) {
|
||||||
|
if (mActionMode == null) {
|
||||||
|
if (wActionBar.isOverflowMenuShowing()) {
|
||||||
|
wActionBar.hideOverflowMenu();
|
||||||
|
} else {
|
||||||
|
wActionBar.showOverflowMenu();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
result = true;
|
||||||
}
|
}
|
||||||
|
mMenuKeyIsLongPress = false;
|
||||||
}
|
}
|
||||||
if (DEBUG) Log.d(TAG, "[dispatchKeyEvent] returning true");
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (DEBUG) Log.d(TAG, "[dispatchKeyEvent] returning false");
|
if (DEBUG) Log.d(TAG, "[dispatchKeyEvent] returning " + result);
|
||||||
return false;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -964,7 +977,7 @@ public class ActionBarSherlockCompat extends ActionBarSherlock implements MenuBu
|
|||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
//Invalidate if the panel menu hasn't been created before this.
|
//Invalidate if the panel menu hasn't been created before this.
|
||||||
if (mMenu == null) {
|
if (!mActivity.isFinishing() && mMenu == null) {
|
||||||
dispatchInvalidateOptionsMenu();
|
dispatchInvalidateOptionsMenu();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -314,5 +314,15 @@ public class ActionBarSherlockNative extends ActionBarSherlock {
|
|||||||
public MenuInflater getMenuInflater() {
|
public MenuInflater getMenuInflater() {
|
||||||
return ActionBarSherlockNative.this.getMenuInflater();
|
return ActionBarSherlockNative.this.getMenuInflater();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setTag(Object tag) {
|
||||||
|
mActionMode.setTag(tag);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object getTag() {
|
||||||
|
return mActionMode.getTag();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -335,6 +335,12 @@ public class ActionBarWrapper extends ActionBar implements android.app.ActionBar
|
|||||||
@Override
|
@Override
|
||||||
public void onTabSelected(android.app.ActionBar.Tab tab, android.app.FragmentTransaction ft) {
|
public void onTabSelected(android.app.ActionBar.Tab tab, android.app.FragmentTransaction ft) {
|
||||||
if (mListener != null) {
|
if (mListener != null) {
|
||||||
|
|
||||||
|
if (mFragmentTransaction == null && mActivity instanceof SherlockFragmentActivity) {
|
||||||
|
mFragmentTransaction = ((SherlockFragmentActivity)mActivity).getSupportFragmentManager().beginTransaction()
|
||||||
|
.disallowAddToBackStack();
|
||||||
|
}
|
||||||
|
|
||||||
mListener.onTabSelected(this, mFragmentTransaction);
|
mListener.onTabSelected(this, mFragmentTransaction);
|
||||||
|
|
||||||
if (mFragmentTransaction != null) {
|
if (mFragmentTransaction != null) {
|
||||||
|
@ -947,7 +947,7 @@ public final class AnimatorSet extends Animator {
|
|||||||
public Node clone() {
|
public Node clone() {
|
||||||
try {
|
try {
|
||||||
Node node = (Node) super.clone();
|
Node node = (Node) super.clone();
|
||||||
node.animation = (Animator) animation.clone();
|
node.animation = animation.clone();
|
||||||
return node;
|
return node;
|
||||||
} catch (CloneNotSupportedException e) {
|
} catch (CloneNotSupportedException e) {
|
||||||
throw new AssertionError();
|
throw new AssertionError();
|
||||||
|
@ -256,7 +256,7 @@ public class PropertyValuesHolder implements Cloneable {
|
|||||||
else {
|
else {
|
||||||
PropertyValuesHolder pvh = new PropertyValuesHolder(propertyName);
|
PropertyValuesHolder pvh = new PropertyValuesHolder(propertyName);
|
||||||
pvh.mKeyframeSet = keyframeSet;
|
pvh.mKeyframeSet = keyframeSet;
|
||||||
pvh.mValueType = ((Keyframe)values[0]).getType();
|
pvh.mValueType = values[0].getType();
|
||||||
return pvh;
|
return pvh;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -336,9 +336,9 @@ public class PropertyValuesHolder implements Cloneable {
|
|||||||
public void setKeyframes(Keyframe... values) {
|
public void setKeyframes(Keyframe... values) {
|
||||||
int numKeyframes = values.length;
|
int numKeyframes = values.length;
|
||||||
Keyframe keyframes[] = new Keyframe[Math.max(numKeyframes,2)];
|
Keyframe keyframes[] = new Keyframe[Math.max(numKeyframes,2)];
|
||||||
mValueType = ((Keyframe)values[0]).getType();
|
mValueType = values[0].getType();
|
||||||
for (int i = 0; i < numKeyframes; ++i) {
|
for (int i = 0; i < numKeyframes; ++i) {
|
||||||
keyframes[i] = (Keyframe)values[i];
|
keyframes[i] = values[i];
|
||||||
}
|
}
|
||||||
mKeyframeSet = new KeyframeSet(keyframes);
|
mKeyframeSet = new KeyframeSet(keyframes);
|
||||||
}
|
}
|
||||||
|
@ -458,7 +458,7 @@ public class ValueAnimator extends Animator {
|
|||||||
mValues = values;
|
mValues = values;
|
||||||
mValuesMap = new HashMap<String, PropertyValuesHolder>(numValues);
|
mValuesMap = new HashMap<String, PropertyValuesHolder>(numValues);
|
||||||
for (int i = 0; i < numValues; ++i) {
|
for (int i = 0; i < numValues; ++i) {
|
||||||
PropertyValuesHolder valuesHolder = (PropertyValuesHolder) values[i];
|
PropertyValuesHolder valuesHolder = values[i];
|
||||||
mValuesMap.put(valuesHolder.getPropertyName(), valuesHolder);
|
mValuesMap.put(valuesHolder.getPropertyName(), valuesHolder);
|
||||||
}
|
}
|
||||||
// New property/values/target should cause re-initialization prior to starting
|
// New property/values/target should cause re-initialization prior to starting
|
||||||
|
@ -0,0 +1,41 @@
|
|||||||
|
package com.actionbarsherlock.internal.nineoldandroids.widget;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.widget.HorizontalScrollView;
|
||||||
|
import com.actionbarsherlock.internal.nineoldandroids.view.animation.AnimatorProxy;
|
||||||
|
|
||||||
|
public class NineHorizontalScrollView extends HorizontalScrollView {
|
||||||
|
private final AnimatorProxy mProxy;
|
||||||
|
|
||||||
|
public NineHorizontalScrollView(Context context) {
|
||||||
|
super(context);
|
||||||
|
mProxy = AnimatorProxy.NEEDS_PROXY ? AnimatorProxy.wrap(this) : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setVisibility(int visibility) {
|
||||||
|
if (mProxy != null) {
|
||||||
|
if (visibility == GONE) {
|
||||||
|
clearAnimation();
|
||||||
|
} else if (visibility == VISIBLE) {
|
||||||
|
setAnimation(mProxy);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
super.setVisibility(visibility);
|
||||||
|
}
|
||||||
|
|
||||||
|
public float getAlpha() {
|
||||||
|
if (AnimatorProxy.NEEDS_PROXY) {
|
||||||
|
return mProxy.getAlpha();
|
||||||
|
} else {
|
||||||
|
return super.getAlpha();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setAlpha(float alpha) {
|
||||||
|
if (AnimatorProxy.NEEDS_PROXY) {
|
||||||
|
mProxy.setAlpha(alpha);
|
||||||
|
} else {
|
||||||
|
super.setAlpha(alpha);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -130,7 +130,13 @@ public class ActionMenuPresenter extends BaseMenuPresenter
|
|||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.ICE_CREAM_SANDWICH) {
|
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.ICE_CREAM_SANDWICH) {
|
||||||
return (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB);
|
return (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB);
|
||||||
} else {
|
} else {
|
||||||
return !ViewConfiguration.get(context).hasPermanentMenuKey();
|
return !HasPermanentMenuKey.get(context);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class HasPermanentMenuKey {
|
||||||
|
public static boolean get(Context context) {
|
||||||
|
return ViewConfiguration.get(context).hasPermanentMenuKey();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -299,7 +305,7 @@ public class ActionMenuPresenter extends BaseMenuPresenter
|
|||||||
*/
|
*/
|
||||||
public boolean showOverflowMenu() {
|
public boolean showOverflowMenu() {
|
||||||
if (mReserveOverflow && !isOverflowMenuShowing() && mMenu != null && mMenuView != null &&
|
if (mReserveOverflow && !isOverflowMenuShowing() && mMenu != null && mMenuView != null &&
|
||||||
mPostedOpenRunnable == null) {
|
mPostedOpenRunnable == null && !mMenu.getNonActionItems().isEmpty()) {
|
||||||
OverflowPopup popup = new OverflowPopup(mContext, mMenu, mOverflowButton, true);
|
OverflowPopup popup = new OverflowPopup(mContext, mMenu, mOverflowButton, true);
|
||||||
mPostedOpenRunnable = new OpenOverflowRunnable(popup);
|
mPostedOpenRunnable = new OpenOverflowRunnable(popup);
|
||||||
// Post this for later; we might still need a layout for the anchor to be right.
|
// Post this for later; we might still need a layout for the anchor to be right.
|
||||||
|
@ -417,9 +417,9 @@ public class ActionMenuView extends IcsLinearLayout implements MenuBuilder.ItemI
|
|||||||
final int size = v.getMeasuredWidth() + p.leftMargin + p.rightMargin;
|
final int size = v.getMeasuredWidth() + p.leftMargin + p.rightMargin;
|
||||||
//UNUSED nonOverflowWidth += size;
|
//UNUSED nonOverflowWidth += size;
|
||||||
widthRemaining -= size;
|
widthRemaining -= size;
|
||||||
if (hasDividerBeforeChildAt(i)) {
|
//if (hasDividerBeforeChildAt(i)) {
|
||||||
//UNUSED nonOverflowWidth += dividerWidth;
|
//UNUSED nonOverflowWidth += dividerWidth;
|
||||||
}
|
//}
|
||||||
nonOverflowCount++;
|
nonOverflowCount++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,11 +9,12 @@ import com.actionbarsherlock.view.ActionProvider;
|
|||||||
import com.actionbarsherlock.view.MenuItem;
|
import com.actionbarsherlock.view.MenuItem;
|
||||||
import com.actionbarsherlock.view.SubMenu;
|
import com.actionbarsherlock.view.SubMenu;
|
||||||
|
|
||||||
public class MenuItemWrapper implements MenuItem, android.view.MenuItem.OnMenuItemClickListener, android.view.MenuItem.OnActionExpandListener {
|
public class MenuItemWrapper implements MenuItem, android.view.MenuItem.OnMenuItemClickListener {
|
||||||
private final android.view.MenuItem mNativeItem;
|
private final android.view.MenuItem mNativeItem;
|
||||||
private SubMenu mSubMenu = null;
|
private SubMenu mSubMenu = null;
|
||||||
private OnMenuItemClickListener mMenuItemClickListener = null;
|
private OnMenuItemClickListener mMenuItemClickListener = null;
|
||||||
private OnActionExpandListener mActionExpandListener = null;
|
private OnActionExpandListener mActionExpandListener = null;
|
||||||
|
private android.view.MenuItem.OnActionExpandListener mNativeActionExpandListener = null;
|
||||||
|
|
||||||
|
|
||||||
public MenuItemWrapper(android.view.MenuItem nativeItem) {
|
public MenuItemWrapper(android.view.MenuItem nativeItem) {
|
||||||
@ -262,24 +263,30 @@ public class MenuItemWrapper implements MenuItem, android.view.MenuItem.OnMenuIt
|
|||||||
@Override
|
@Override
|
||||||
public MenuItem setOnActionExpandListener(OnActionExpandListener listener) {
|
public MenuItem setOnActionExpandListener(OnActionExpandListener listener) {
|
||||||
mActionExpandListener = listener;
|
mActionExpandListener = listener;
|
||||||
//Register ourselves as the listener to proxy
|
|
||||||
mNativeItem.setOnActionExpandListener(this);
|
if (mNativeActionExpandListener == null) {
|
||||||
|
mNativeActionExpandListener = new android.view.MenuItem.OnActionExpandListener() {
|
||||||
|
@Override
|
||||||
|
public boolean onMenuItemActionExpand(android.view.MenuItem menuItem) {
|
||||||
|
if (mActionExpandListener != null) {
|
||||||
|
return mActionExpandListener.onMenuItemActionExpand(MenuItemWrapper.this);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onMenuItemActionCollapse(android.view.MenuItem menuItem) {
|
||||||
|
if (mActionExpandListener != null) {
|
||||||
|
return mActionExpandListener.onMenuItemActionCollapse(MenuItemWrapper.this);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
//Register our inner-class as the listener to proxy method calls
|
||||||
|
mNativeItem.setOnActionExpandListener(mNativeActionExpandListener);
|
||||||
|
}
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onMenuItemActionCollapse(android.view.MenuItem item) {
|
|
||||||
if (mActionExpandListener != null) {
|
|
||||||
return mActionExpandListener.onMenuItemActionCollapse(this);
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onMenuItemActionExpand(android.view.MenuItem item) {
|
|
||||||
if (mActionExpandListener != null) {
|
|
||||||
return mActionExpandListener.onMenuItemActionExpand(this);
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -15,6 +15,7 @@ public class MenuMule implements Menu {
|
|||||||
|
|
||||||
|
|
||||||
private final com.actionbarsherlock.view.Menu mMenu;
|
private final com.actionbarsherlock.view.Menu mMenu;
|
||||||
|
public boolean mDispatchShow = false;
|
||||||
|
|
||||||
public MenuMule(com.actionbarsherlock.view.Menu menu) {
|
public MenuMule(com.actionbarsherlock.view.Menu menu) {
|
||||||
mMenu = menu;
|
mMenu = menu;
|
||||||
|
@ -132,7 +132,7 @@ public class ActionBarView extends AbsActionBarView {
|
|||||||
private SpinnerAdapter mSpinnerAdapter;
|
private SpinnerAdapter mSpinnerAdapter;
|
||||||
private OnNavigationListener mCallback;
|
private OnNavigationListener mCallback;
|
||||||
|
|
||||||
private Runnable mTabSelector;
|
//UNUSED private Runnable mTabSelector;
|
||||||
|
|
||||||
private ExpandedActionViewMenuPresenter mExpandedMenuPresenter;
|
private ExpandedActionViewMenuPresenter mExpandedMenuPresenter;
|
||||||
View mExpandedActionView;
|
View mExpandedActionView;
|
||||||
@ -250,7 +250,7 @@ public class ActionBarView extends AbsActionBarView {
|
|||||||
|
|
||||||
final int customNavId = a.getResourceId(R.styleable.SherlockActionBar_customNavigationLayout, 0);
|
final int customNavId = a.getResourceId(R.styleable.SherlockActionBar_customNavigationLayout, 0);
|
||||||
if (customNavId != 0) {
|
if (customNavId != 0) {
|
||||||
mCustomNavView = (View) inflater.inflate(customNavId, this, false);
|
mCustomNavView = inflater.inflate(customNavId, this, false);
|
||||||
mNavigationMode = ActionBar.NAVIGATION_MODE_STANDARD;
|
mNavigationMode = ActionBar.NAVIGATION_MODE_STANDARD;
|
||||||
setDisplayOptions(mDisplayOptions | ActionBar.DISPLAY_SHOW_CUSTOM);
|
setDisplayOptions(mDisplayOptions | ActionBar.DISPLAY_SHOW_CUSTOM);
|
||||||
}
|
}
|
||||||
@ -383,7 +383,7 @@ public class ActionBarView extends AbsActionBarView {
|
|||||||
@Override
|
@Override
|
||||||
public void onDetachedFromWindow() {
|
public void onDetachedFromWindow() {
|
||||||
super.onDetachedFromWindow();
|
super.onDetachedFromWindow();
|
||||||
removeCallbacks(mTabSelector);
|
//UNUSED removeCallbacks(mTabSelector);
|
||||||
if (mActionMenuPresenter != null) {
|
if (mActionMenuPresenter != null) {
|
||||||
mActionMenuPresenter.hideOverflowMenu();
|
mActionMenuPresenter.hideOverflowMenu();
|
||||||
mActionMenuPresenter.hideSubMenus();
|
mActionMenuPresenter.hideSubMenus();
|
||||||
@ -825,7 +825,7 @@ public class ActionBarView extends AbsActionBarView {
|
|||||||
this, false);
|
this, false);
|
||||||
mTitleView = (TextView) mTitleLayout.findViewById(R.id.abs__action_bar_title);
|
mTitleView = (TextView) mTitleLayout.findViewById(R.id.abs__action_bar_title);
|
||||||
mSubtitleView = (TextView) mTitleLayout.findViewById(R.id.abs__action_bar_subtitle);
|
mSubtitleView = (TextView) mTitleLayout.findViewById(R.id.abs__action_bar_subtitle);
|
||||||
mTitleUpView = (View) mTitleLayout.findViewById(R.id.abs__up);
|
mTitleUpView = mTitleLayout.findViewById(R.id.abs__up);
|
||||||
|
|
||||||
mTitleLayout.setOnClickListener(mUpClickListener);
|
mTitleLayout.setOnClickListener(mUpClickListener);
|
||||||
|
|
||||||
|
@ -18,6 +18,10 @@ public class CapitalizingTextView extends TextView {
|
|||||||
|
|
||||||
private boolean mAllCaps;
|
private boolean mAllCaps;
|
||||||
|
|
||||||
|
public CapitalizingTextView(Context context, AttributeSet attrs) {
|
||||||
|
this(context, attrs, 0);
|
||||||
|
}
|
||||||
|
|
||||||
public CapitalizingTextView(Context context, AttributeSet attrs, int defStyle) {
|
public CapitalizingTextView(Context context, AttributeSet attrs, int defStyle) {
|
||||||
super(context, attrs, defStyle);
|
super(context, attrs, defStyle);
|
||||||
|
|
||||||
|
@ -10,7 +10,10 @@ import com.actionbarsherlock.internal.nineoldandroids.widget.NineLinearLayout;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* A simple extension of a regular linear layout that supports the divider API
|
* A simple extension of a regular linear layout that supports the divider API
|
||||||
* of Android 4.0+.
|
* of Android 4.0+. The dividers are added adjacent to the children by changing
|
||||||
|
* their layout params. If you need to rely on the margins which fall in the
|
||||||
|
* same orientation as the layout you should wrap the child in a simple
|
||||||
|
* {@link android.widget.FrameLayout} so it can receive the margin.
|
||||||
*/
|
*/
|
||||||
public class IcsLinearLayout extends NineLinearLayout {
|
public class IcsLinearLayout extends NineLinearLayout {
|
||||||
private static final int[] LinearLayout = new int[] {
|
private static final int[] LinearLayout = new int[] {
|
||||||
@ -42,6 +45,7 @@ public class IcsLinearLayout extends NineLinearLayout {
|
|||||||
|
|
||||||
private Drawable mDivider;
|
private Drawable mDivider;
|
||||||
private int mDividerWidth;
|
private int mDividerWidth;
|
||||||
|
private int mDividerHeight;
|
||||||
private int mShowDividers;
|
private int mShowDividers;
|
||||||
private int mDividerPadding;
|
private int mDividerPadding;
|
||||||
|
|
||||||
@ -58,6 +62,29 @@ public class IcsLinearLayout extends NineLinearLayout {
|
|||||||
a.recycle();
|
a.recycle();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set how dividers should be shown between items in this layout
|
||||||
|
*
|
||||||
|
* @param showDividers One or more of {@link #SHOW_DIVIDER_BEGINNING},
|
||||||
|
* {@link #SHOW_DIVIDER_MIDDLE}, or {@link #SHOW_DIVIDER_END},
|
||||||
|
* or {@link #SHOW_DIVIDER_NONE} to show no dividers.
|
||||||
|
*/
|
||||||
|
public void setShowDividers(int showDividers) {
|
||||||
|
if (showDividers != mShowDividers) {
|
||||||
|
requestLayout();
|
||||||
|
invalidate(); //XXX This is required if you are toggling a divider off
|
||||||
|
}
|
||||||
|
mShowDividers = showDividers;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return A flag set indicating how dividers should be shown around items.
|
||||||
|
* @see #setShowDividers(int)
|
||||||
|
*/
|
||||||
|
public int getShowDividers() {
|
||||||
|
return mShowDividers;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set a drawable to be used as a divider between items.
|
* Set a drawable to be used as a divider between items.
|
||||||
* @param divider Drawable that will divide each item.
|
* @param divider Drawable that will divide each item.
|
||||||
@ -70,13 +97,39 @@ public class IcsLinearLayout extends NineLinearLayout {
|
|||||||
mDivider = divider;
|
mDivider = divider;
|
||||||
if (divider != null) {
|
if (divider != null) {
|
||||||
mDividerWidth = divider.getIntrinsicWidth();
|
mDividerWidth = divider.getIntrinsicWidth();
|
||||||
|
mDividerHeight = divider.getIntrinsicHeight();
|
||||||
} else {
|
} else {
|
||||||
mDividerWidth = 0;
|
mDividerWidth = 0;
|
||||||
|
mDividerHeight = 0;
|
||||||
}
|
}
|
||||||
setWillNotDraw(divider == null);
|
setWillNotDraw(divider == null);
|
||||||
requestLayout();
|
requestLayout();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set padding displayed on both ends of dividers.
|
||||||
|
*
|
||||||
|
* @param padding Padding value in pixels that will be applied to each end
|
||||||
|
*
|
||||||
|
* @see #setShowDividers(int)
|
||||||
|
* @see #setDividerDrawable(Drawable)
|
||||||
|
* @see #getDividerPadding()
|
||||||
|
*/
|
||||||
|
public void setDividerPadding(int padding) {
|
||||||
|
mDividerPadding = padding;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the padding size used to inset dividers in pixels
|
||||||
|
*
|
||||||
|
* @see #setShowDividers(int)
|
||||||
|
* @see #setDividerDrawable(Drawable)
|
||||||
|
* @see #setDividerPadding(int)
|
||||||
|
*/
|
||||||
|
public int getDividerPadding() {
|
||||||
|
return mDividerPadding;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the width of the current divider drawable.
|
* Get the width of the current divider drawable.
|
||||||
*
|
*
|
||||||
@ -89,9 +142,27 @@ public class IcsLinearLayout extends NineLinearLayout {
|
|||||||
@Override
|
@Override
|
||||||
protected void measureChildWithMargins(View child, int parentWidthMeasureSpec, int widthUsed, int parentHeightMeasureSpec, int heightUsed) {
|
protected void measureChildWithMargins(View child, int parentWidthMeasureSpec, int widthUsed, int parentHeightMeasureSpec, int heightUsed) {
|
||||||
final int index = indexOfChild(child);
|
final int index = indexOfChild(child);
|
||||||
|
final int orientation = getOrientation();
|
||||||
|
final LayoutParams params = (LayoutParams) child.getLayoutParams();
|
||||||
if (hasDividerBeforeChildAt(index)) {
|
if (hasDividerBeforeChildAt(index)) {
|
||||||
//Account for the divider by pushing everything left
|
if (orientation == VERTICAL) {
|
||||||
((LayoutParams)child.getLayoutParams()).leftMargin = mDividerWidth;
|
//Account for the divider by pushing everything up
|
||||||
|
params.topMargin = mDividerHeight;
|
||||||
|
} else {
|
||||||
|
//Account for the divider by pushing everything left
|
||||||
|
params.leftMargin = mDividerWidth;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
final int count = getChildCount();
|
||||||
|
if (index == count - 1) {
|
||||||
|
if (hasDividerBeforeChildAt(count)) {
|
||||||
|
if (orientation == VERTICAL) {
|
||||||
|
params.bottomMargin = mDividerHeight;
|
||||||
|
} else {
|
||||||
|
params.rightMargin = mDividerWidth;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
super.measureChildWithMargins(child, parentWidthMeasureSpec, widthUsed, parentHeightMeasureSpec, heightUsed);
|
super.measureChildWithMargins(child, parentWidthMeasureSpec, widthUsed, parentHeightMeasureSpec, heightUsed);
|
||||||
}
|
}
|
||||||
@ -99,32 +170,73 @@ public class IcsLinearLayout extends NineLinearLayout {
|
|||||||
@Override
|
@Override
|
||||||
protected void onDraw(Canvas canvas) {
|
protected void onDraw(Canvas canvas) {
|
||||||
if (mDivider != null) {
|
if (mDivider != null) {
|
||||||
final int count = getChildCount();
|
if (getOrientation() == VERTICAL) {
|
||||||
for (int i = 0; i < count; i++) {
|
drawDividersVertical(canvas);
|
||||||
final View child = getChildAt(i);
|
} else {
|
||||||
if (child != null && child.getVisibility() != GONE) {
|
drawDividersHorizontal(canvas);
|
||||||
if (hasDividerBeforeChildAt(i)) {
|
|
||||||
final LayoutParams lp = (LayoutParams) child.getLayoutParams();
|
|
||||||
final int left = child.getLeft() - lp.leftMargin;
|
|
||||||
drawVerticalDivider(canvas, left);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
super.onDraw(canvas);
|
||||||
|
}
|
||||||
|
|
||||||
if (hasDividerBeforeChildAt(count)) {
|
void drawDividersVertical(Canvas canvas) {
|
||||||
final View child = getChildAt(count - 1);
|
final int count = getChildCount();
|
||||||
int right = 0;
|
for (int i = 0; i < count; i++) {
|
||||||
if (child == null) {
|
final View child = getChildAt(i);
|
||||||
right = getWidth() - getPaddingRight() - mDividerWidth;
|
|
||||||
} else {
|
if (child != null && child.getVisibility() != GONE) {
|
||||||
|
if (hasDividerBeforeChildAt(i)) {
|
||||||
final LayoutParams lp = (LayoutParams) child.getLayoutParams();
|
final LayoutParams lp = (LayoutParams) child.getLayoutParams();
|
||||||
right = child.getRight() + lp.rightMargin;
|
final int top = child.getTop() - lp.topMargin/* - mDividerHeight*/;
|
||||||
|
drawHorizontalDivider(canvas, top);
|
||||||
}
|
}
|
||||||
drawVerticalDivider(canvas, right);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
super.onDraw(canvas);
|
if (hasDividerBeforeChildAt(count)) {
|
||||||
|
final View child = getChildAt(count - 1);
|
||||||
|
int bottom = 0;
|
||||||
|
if (child == null) {
|
||||||
|
bottom = getHeight() - getPaddingBottom() - mDividerHeight;
|
||||||
|
} else {
|
||||||
|
final LayoutParams lp = (LayoutParams) child.getLayoutParams();
|
||||||
|
bottom = child.getBottom()/* + lp.bottomMargin*/;
|
||||||
|
}
|
||||||
|
drawHorizontalDivider(canvas, bottom);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void drawDividersHorizontal(Canvas canvas) {
|
||||||
|
final int count = getChildCount();
|
||||||
|
for (int i = 0; i < count; i++) {
|
||||||
|
final View child = getChildAt(i);
|
||||||
|
|
||||||
|
if (child != null && child.getVisibility() != GONE) {
|
||||||
|
if (hasDividerBeforeChildAt(i)) {
|
||||||
|
final LayoutParams lp = (LayoutParams) child.getLayoutParams();
|
||||||
|
final int left = child.getLeft() - lp.leftMargin/* - mDividerWidth*/;
|
||||||
|
drawVerticalDivider(canvas, left);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hasDividerBeforeChildAt(count)) {
|
||||||
|
final View child = getChildAt(count - 1);
|
||||||
|
int right = 0;
|
||||||
|
if (child == null) {
|
||||||
|
right = getWidth() - getPaddingRight() - mDividerWidth;
|
||||||
|
} else {
|
||||||
|
final LayoutParams lp = (LayoutParams) child.getLayoutParams();
|
||||||
|
right = child.getRight()/* + lp.rightMargin*/;
|
||||||
|
}
|
||||||
|
drawVerticalDivider(canvas, right);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void drawHorizontalDivider(Canvas canvas, int top) {
|
||||||
|
mDivider.setBounds(getPaddingLeft() + mDividerPadding, top,
|
||||||
|
getWidth() - getPaddingRight() - mDividerPadding, top + mDividerHeight);
|
||||||
|
mDivider.draw(canvas);
|
||||||
}
|
}
|
||||||
|
|
||||||
void drawVerticalDivider(Canvas canvas, int left) {
|
void drawVerticalDivider(Canvas canvas, int left) {
|
||||||
|
@ -74,6 +74,10 @@ public class IcsListPopupWindow {
|
|||||||
public static final int POSITION_PROMPT_ABOVE = 0;
|
public static final int POSITION_PROMPT_ABOVE = 0;
|
||||||
public static final int POSITION_PROMPT_BELOW = 1;
|
public static final int POSITION_PROMPT_BELOW = 1;
|
||||||
|
|
||||||
|
public IcsListPopupWindow(Context context) {
|
||||||
|
this(context, null, R.attr.listPopupWindowStyle);
|
||||||
|
}
|
||||||
|
|
||||||
public IcsListPopupWindow(Context context, AttributeSet attrs, int defStyleAttr) {
|
public IcsListPopupWindow(Context context, AttributeSet attrs, int defStyleAttr) {
|
||||||
mContext = context;
|
mContext = context;
|
||||||
mPopup = new PopupWindow(context, attrs, defStyleAttr);
|
mPopup = new PopupWindow(context, attrs, defStyleAttr);
|
||||||
|
@ -78,6 +78,10 @@ public class IcsSpinner extends IcsAbsSpinner implements OnClickListener {
|
|||||||
|
|
||||||
private Rect mTempRect = new Rect();
|
private Rect mTempRect = new Rect();
|
||||||
|
|
||||||
|
public IcsSpinner(Context context, AttributeSet attrs) {
|
||||||
|
this(context, attrs, R.attr.actionDropDownStyle);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Construct a new spinner with the given context's theme, the supplied attribute set,
|
* Construct a new spinner with the given context's theme, the supplied attribute set,
|
||||||
* and default style.
|
* and default style.
|
||||||
|
@ -29,7 +29,6 @@ import android.view.ViewParent;
|
|||||||
import android.view.animation.DecelerateInterpolator;
|
import android.view.animation.DecelerateInterpolator;
|
||||||
import android.view.animation.Interpolator;
|
import android.view.animation.Interpolator;
|
||||||
import android.widget.BaseAdapter;
|
import android.widget.BaseAdapter;
|
||||||
import android.widget.HorizontalScrollView;
|
|
||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import android.widget.ListView;
|
import android.widget.ListView;
|
||||||
@ -37,12 +36,13 @@ import com.actionbarsherlock.R;
|
|||||||
import com.actionbarsherlock.app.ActionBar;
|
import com.actionbarsherlock.app.ActionBar;
|
||||||
import com.actionbarsherlock.internal.nineoldandroids.animation.Animator;
|
import com.actionbarsherlock.internal.nineoldandroids.animation.Animator;
|
||||||
import com.actionbarsherlock.internal.nineoldandroids.animation.ObjectAnimator;
|
import com.actionbarsherlock.internal.nineoldandroids.animation.ObjectAnimator;
|
||||||
|
import com.actionbarsherlock.internal.nineoldandroids.widget.NineHorizontalScrollView;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This widget implements the dynamic action bar tab behavior that can change
|
* This widget implements the dynamic action bar tab behavior that can change
|
||||||
* across different configurations or circumstances.
|
* across different configurations or circumstances.
|
||||||
*/
|
*/
|
||||||
public class ScrollingTabContainerView extends HorizontalScrollView
|
public class ScrollingTabContainerView extends NineHorizontalScrollView
|
||||||
implements IcsAdapterView.OnItemSelectedListener {
|
implements IcsAdapterView.OnItemSelectedListener {
|
||||||
//UNUSED private static final String TAG = "ScrollingTabContainerView";
|
//UNUSED private static final String TAG = "ScrollingTabContainerView";
|
||||||
Runnable mTabSelector;
|
Runnable mTabSelector;
|
||||||
|
@ -0,0 +1,818 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2011 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.actionbarsherlock.widget;
|
||||||
|
|
||||||
|
import android.os.Build;
|
||||||
|
import com.actionbarsherlock.R;
|
||||||
|
import com.actionbarsherlock.internal.widget.IcsLinearLayout;
|
||||||
|
import com.actionbarsherlock.internal.widget.IcsListPopupWindow;
|
||||||
|
import com.actionbarsherlock.view.ActionProvider;
|
||||||
|
import com.actionbarsherlock.widget.ActivityChooserModel.ActivityChooserModelClient;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
|
import android.content.pm.ResolveInfo;
|
||||||
|
import android.content.res.Resources;
|
||||||
|
import android.content.res.TypedArray;
|
||||||
|
import android.database.DataSetObserver;
|
||||||
|
import android.graphics.drawable.Drawable;
|
||||||
|
import android.util.AttributeSet;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.ViewGroup;
|
||||||
|
import android.view.ViewTreeObserver;
|
||||||
|
import android.view.ViewTreeObserver.OnGlobalLayoutListener;
|
||||||
|
import android.widget.AdapterView;
|
||||||
|
import android.widget.BaseAdapter;
|
||||||
|
import android.widget.FrameLayout;
|
||||||
|
import android.widget.ImageView;
|
||||||
|
import android.widget.PopupWindow;
|
||||||
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class is a view for choosing an activity for handling a given {@link Intent}.
|
||||||
|
* <p>
|
||||||
|
* The view is composed of two adjacent buttons:
|
||||||
|
* <ul>
|
||||||
|
* <li>
|
||||||
|
* The left button is an immediate action and allows one click activity choosing.
|
||||||
|
* Tapping this button immediately executes the intent without requiring any further
|
||||||
|
* user input. Long press on this button shows a popup for changing the default
|
||||||
|
* activity.
|
||||||
|
* </li>
|
||||||
|
* <li>
|
||||||
|
* The right button is an overflow action and provides an optimized menu
|
||||||
|
* of additional activities. Tapping this button shows a popup anchored to this
|
||||||
|
* view, listing the most frequently used activities. This list is initially
|
||||||
|
* limited to a small number of items in frequency used order. The last item,
|
||||||
|
* "Show all..." serves as an affordance to display all available activities.
|
||||||
|
* </li>
|
||||||
|
* </ul>
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @hide
|
||||||
|
*/
|
||||||
|
class ActivityChooserView extends ViewGroup implements ActivityChooserModelClient {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An adapter for displaying the activities in an {@link AdapterView}.
|
||||||
|
*/
|
||||||
|
private final ActivityChooserViewAdapter mAdapter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Implementation of various interfaces to avoid publishing them in the APIs.
|
||||||
|
*/
|
||||||
|
private final Callbacks mCallbacks;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The content of this view.
|
||||||
|
*/
|
||||||
|
private final IcsLinearLayout mActivityChooserContent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Stores the background drawable to allow hiding and latter showing.
|
||||||
|
*/
|
||||||
|
private final Drawable mActivityChooserContentBackground;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The expand activities action button;
|
||||||
|
*/
|
||||||
|
private final FrameLayout mExpandActivityOverflowButton;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The image for the expand activities action button;
|
||||||
|
*/
|
||||||
|
private final ImageView mExpandActivityOverflowButtonImage;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The default activities action button;
|
||||||
|
*/
|
||||||
|
private final FrameLayout mDefaultActivityButton;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The image for the default activities action button;
|
||||||
|
*/
|
||||||
|
private final ImageView mDefaultActivityButtonImage;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The maximal width of the list popup.
|
||||||
|
*/
|
||||||
|
private final int mListPopupMaxWidth;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The ActionProvider hosting this view, if applicable.
|
||||||
|
*/
|
||||||
|
ActionProvider mProvider;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Observer for the model data.
|
||||||
|
*/
|
||||||
|
private final DataSetObserver mModelDataSetOberver = new DataSetObserver() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChanged() {
|
||||||
|
super.onChanged();
|
||||||
|
mAdapter.notifyDataSetChanged();
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public void onInvalidated() {
|
||||||
|
super.onInvalidated();
|
||||||
|
mAdapter.notifyDataSetInvalidated();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private final OnGlobalLayoutListener mOnGlobalLayoutListener = new OnGlobalLayoutListener() {
|
||||||
|
@Override
|
||||||
|
public void onGlobalLayout() {
|
||||||
|
if (isShowingPopup()) {
|
||||||
|
if (!isShown()) {
|
||||||
|
getListPopupWindow().dismiss();
|
||||||
|
} else {
|
||||||
|
getListPopupWindow().show();
|
||||||
|
if (mProvider != null) {
|
||||||
|
mProvider.subUiVisibilityChanged(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Popup window for showing the activity overflow list.
|
||||||
|
*/
|
||||||
|
private IcsListPopupWindow mListPopupWindow;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Listener for the dismissal of the popup/alert.
|
||||||
|
*/
|
||||||
|
private PopupWindow.OnDismissListener mOnDismissListener;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Flag whether a default activity currently being selected.
|
||||||
|
*/
|
||||||
|
private boolean mIsSelectingDefaultActivity;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The count of activities in the popup.
|
||||||
|
*/
|
||||||
|
private int mInitialActivityCount = ActivityChooserViewAdapter.MAX_ACTIVITY_COUNT_DEFAULT;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Flag whether this view is attached to a window.
|
||||||
|
*/
|
||||||
|
private boolean mIsAttachedToWindow;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* String resource for formatting content description of the default target.
|
||||||
|
*/
|
||||||
|
private int mDefaultActionButtonContentDescription;
|
||||||
|
|
||||||
|
private final Context mContext;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new instance.
|
||||||
|
*
|
||||||
|
* @param context The application environment.
|
||||||
|
*/
|
||||||
|
public ActivityChooserView(Context context) {
|
||||||
|
this(context, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new instance.
|
||||||
|
*
|
||||||
|
* @param context The application environment.
|
||||||
|
* @param attrs A collection of attributes.
|
||||||
|
*/
|
||||||
|
public ActivityChooserView(Context context, AttributeSet attrs) {
|
||||||
|
this(context, attrs, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new instance.
|
||||||
|
*
|
||||||
|
* @param context The application environment.
|
||||||
|
* @param attrs A collection of attributes.
|
||||||
|
* @param defStyle The default style to apply to this view.
|
||||||
|
*/
|
||||||
|
public ActivityChooserView(Context context, AttributeSet attrs, int defStyle) {
|
||||||
|
super(context, attrs, defStyle);
|
||||||
|
mContext = context;
|
||||||
|
|
||||||
|
TypedArray attributesArray = context.obtainStyledAttributes(attrs,
|
||||||
|
R.styleable.SherlockActivityChooserView, defStyle, 0);
|
||||||
|
|
||||||
|
mInitialActivityCount = attributesArray.getInt(
|
||||||
|
R.styleable.SherlockActivityChooserView_initialActivityCount,
|
||||||
|
ActivityChooserViewAdapter.MAX_ACTIVITY_COUNT_DEFAULT);
|
||||||
|
|
||||||
|
Drawable expandActivityOverflowButtonDrawable = attributesArray.getDrawable(
|
||||||
|
R.styleable.SherlockActivityChooserView_expandActivityOverflowButtonDrawable);
|
||||||
|
|
||||||
|
attributesArray.recycle();
|
||||||
|
|
||||||
|
LayoutInflater inflater = LayoutInflater.from(mContext);
|
||||||
|
inflater.inflate(R.layout.abs__activity_chooser_view, this, true);
|
||||||
|
|
||||||
|
mCallbacks = new Callbacks();
|
||||||
|
|
||||||
|
mActivityChooserContent = (IcsLinearLayout) findViewById(R.id.abs__activity_chooser_view_content);
|
||||||
|
mActivityChooserContentBackground = mActivityChooserContent.getBackground();
|
||||||
|
|
||||||
|
mDefaultActivityButton = (FrameLayout) findViewById(R.id.abs__default_activity_button);
|
||||||
|
mDefaultActivityButton.setOnClickListener(mCallbacks);
|
||||||
|
mDefaultActivityButton.setOnLongClickListener(mCallbacks);
|
||||||
|
mDefaultActivityButtonImage = (ImageView) mDefaultActivityButton.findViewById(R.id.abs__image);
|
||||||
|
|
||||||
|
mExpandActivityOverflowButton = (FrameLayout) findViewById(R.id.abs__expand_activities_button);
|
||||||
|
mExpandActivityOverflowButton.setOnClickListener(mCallbacks);
|
||||||
|
mExpandActivityOverflowButtonImage =
|
||||||
|
(ImageView) mExpandActivityOverflowButton.findViewById(R.id.abs__image);
|
||||||
|
mExpandActivityOverflowButtonImage.setImageDrawable(expandActivityOverflowButtonDrawable);
|
||||||
|
|
||||||
|
mAdapter = new ActivityChooserViewAdapter();
|
||||||
|
mAdapter.registerDataSetObserver(new DataSetObserver() {
|
||||||
|
@Override
|
||||||
|
public void onChanged() {
|
||||||
|
super.onChanged();
|
||||||
|
updateAppearance();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
Resources resources = context.getResources();
|
||||||
|
mListPopupMaxWidth = Math.max(resources.getDisplayMetrics().widthPixels / 2,
|
||||||
|
resources.getDimensionPixelSize(R.dimen.abs__config_prefDialogWidth));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public void setActivityChooserModel(ActivityChooserModel dataModel) {
|
||||||
|
mAdapter.setDataModel(dataModel);
|
||||||
|
if (isShowingPopup()) {
|
||||||
|
dismissPopup();
|
||||||
|
showPopup();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the background for the button that expands the activity
|
||||||
|
* overflow list.
|
||||||
|
*
|
||||||
|
* <strong>Note:</strong> Clients would like to set this drawable
|
||||||
|
* as a clue about the action the chosen activity will perform. For
|
||||||
|
* example, if a share activity is to be chosen the drawable should
|
||||||
|
* give a clue that sharing is to be performed.
|
||||||
|
*
|
||||||
|
* @param drawable The drawable.
|
||||||
|
*/
|
||||||
|
public void setExpandActivityOverflowButtonDrawable(Drawable drawable) {
|
||||||
|
mExpandActivityOverflowButtonImage.setImageDrawable(drawable);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the content description for the button that expands the activity
|
||||||
|
* overflow list.
|
||||||
|
*
|
||||||
|
* description as a clue about the action performed by the button.
|
||||||
|
* For example, if a share activity is to be chosen the content
|
||||||
|
* description should be something like "Share with".
|
||||||
|
*
|
||||||
|
* @param resourceId The content description resource id.
|
||||||
|
*/
|
||||||
|
public void setExpandActivityOverflowButtonContentDescription(int resourceId) {
|
||||||
|
CharSequence contentDescription = mContext.getString(resourceId);
|
||||||
|
mExpandActivityOverflowButtonImage.setContentDescription(contentDescription);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the provider hosting this view, if applicable.
|
||||||
|
* @hide Internal use only
|
||||||
|
*/
|
||||||
|
public void setProvider(ActionProvider provider) {
|
||||||
|
mProvider = provider;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Shows the popup window with activities.
|
||||||
|
*
|
||||||
|
* @return True if the popup was shown, false if already showing.
|
||||||
|
*/
|
||||||
|
public boolean showPopup() {
|
||||||
|
if (isShowingPopup() || !mIsAttachedToWindow) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
mIsSelectingDefaultActivity = false;
|
||||||
|
showPopupUnchecked(mInitialActivityCount);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Shows the popup no matter if it was already showing.
|
||||||
|
*
|
||||||
|
* @param maxActivityCount The max number of activities to display.
|
||||||
|
*/
|
||||||
|
private void showPopupUnchecked(int maxActivityCount) {
|
||||||
|
if (mAdapter.getDataModel() == null) {
|
||||||
|
throw new IllegalStateException("No data model. Did you call #setDataModel?");
|
||||||
|
}
|
||||||
|
|
||||||
|
getViewTreeObserver().addOnGlobalLayoutListener(mOnGlobalLayoutListener);
|
||||||
|
|
||||||
|
final boolean defaultActivityButtonShown =
|
||||||
|
mDefaultActivityButton.getVisibility() == VISIBLE;
|
||||||
|
|
||||||
|
final int activityCount = mAdapter.getActivityCount();
|
||||||
|
final int maxActivityCountOffset = defaultActivityButtonShown ? 1 : 0;
|
||||||
|
if (maxActivityCount != ActivityChooserViewAdapter.MAX_ACTIVITY_COUNT_UNLIMITED
|
||||||
|
&& activityCount > maxActivityCount + maxActivityCountOffset) {
|
||||||
|
mAdapter.setShowFooterView(true);
|
||||||
|
mAdapter.setMaxActivityCount(maxActivityCount - 1);
|
||||||
|
} else {
|
||||||
|
mAdapter.setShowFooterView(false);
|
||||||
|
mAdapter.setMaxActivityCount(maxActivityCount);
|
||||||
|
}
|
||||||
|
|
||||||
|
IcsListPopupWindow popupWindow = getListPopupWindow();
|
||||||
|
if (!popupWindow.isShowing()) {
|
||||||
|
if (mIsSelectingDefaultActivity || !defaultActivityButtonShown) {
|
||||||
|
mAdapter.setShowDefaultActivity(true, defaultActivityButtonShown);
|
||||||
|
} else {
|
||||||
|
mAdapter.setShowDefaultActivity(false, false);
|
||||||
|
}
|
||||||
|
final int contentWidth = Math.min(mAdapter.measureContentWidth(), mListPopupMaxWidth);
|
||||||
|
popupWindow.setContentWidth(contentWidth);
|
||||||
|
popupWindow.show();
|
||||||
|
if (mProvider != null) {
|
||||||
|
mProvider.subUiVisibilityChanged(true);
|
||||||
|
}
|
||||||
|
popupWindow.getListView().setContentDescription(mContext.getString(
|
||||||
|
R.string.abs__activitychooserview_choose_application));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Dismisses the popup window with activities.
|
||||||
|
*
|
||||||
|
* @return True if dismissed, false if already dismissed.
|
||||||
|
*/
|
||||||
|
public boolean dismissPopup() {
|
||||||
|
if (isShowingPopup()) {
|
||||||
|
getListPopupWindow().dismiss();
|
||||||
|
ViewTreeObserver viewTreeObserver = getViewTreeObserver();
|
||||||
|
if (viewTreeObserver.isAlive()) {
|
||||||
|
viewTreeObserver.removeGlobalOnLayoutListener(mOnGlobalLayoutListener);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets whether the popup window with activities is shown.
|
||||||
|
*
|
||||||
|
* @return True if the popup is shown.
|
||||||
|
*/
|
||||||
|
public boolean isShowingPopup() {
|
||||||
|
return getListPopupWindow().isShowing();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onAttachedToWindow() {
|
||||||
|
super.onAttachedToWindow();
|
||||||
|
ActivityChooserModel dataModel = mAdapter.getDataModel();
|
||||||
|
if (dataModel != null) {
|
||||||
|
dataModel.registerObserver(mModelDataSetOberver);
|
||||||
|
}
|
||||||
|
mIsAttachedToWindow = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onDetachedFromWindow() {
|
||||||
|
super.onDetachedFromWindow();
|
||||||
|
ActivityChooserModel dataModel = mAdapter.getDataModel();
|
||||||
|
if (dataModel != null) {
|
||||||
|
dataModel.unregisterObserver(mModelDataSetOberver);
|
||||||
|
}
|
||||||
|
ViewTreeObserver viewTreeObserver = getViewTreeObserver();
|
||||||
|
if (viewTreeObserver.isAlive()) {
|
||||||
|
viewTreeObserver.removeGlobalOnLayoutListener(mOnGlobalLayoutListener);
|
||||||
|
}
|
||||||
|
mIsAttachedToWindow = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
|
||||||
|
View child = mActivityChooserContent;
|
||||||
|
// If the default action is not visible we want to be as tall as the
|
||||||
|
// ActionBar so if this widget is used in the latter it will look as
|
||||||
|
// a normal action button.
|
||||||
|
if (mDefaultActivityButton.getVisibility() != VISIBLE) {
|
||||||
|
heightMeasureSpec = MeasureSpec.makeMeasureSpec(MeasureSpec.getSize(heightMeasureSpec),
|
||||||
|
MeasureSpec.EXACTLY);
|
||||||
|
}
|
||||||
|
measureChild(child, widthMeasureSpec, heightMeasureSpec);
|
||||||
|
setMeasuredDimension(child.getMeasuredWidth(), child.getMeasuredHeight());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
|
||||||
|
mActivityChooserContent.layout(0, 0, right - left, bottom - top);
|
||||||
|
if (getListPopupWindow().isShowing()) {
|
||||||
|
showPopupUnchecked(mAdapter.getMaxActivityCount());
|
||||||
|
} else {
|
||||||
|
dismissPopup();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public ActivityChooserModel getDataModel() {
|
||||||
|
return mAdapter.getDataModel();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets a listener to receive a callback when the popup is dismissed.
|
||||||
|
*
|
||||||
|
* @param listener The listener to be notified.
|
||||||
|
*/
|
||||||
|
public void setOnDismissListener(PopupWindow.OnDismissListener listener) {
|
||||||
|
mOnDismissListener = listener;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the initial count of items shown in the activities popup
|
||||||
|
* i.e. the items before the popup is expanded. This is an upper
|
||||||
|
* bound since it is not guaranteed that such number of intent
|
||||||
|
* handlers exist.
|
||||||
|
*
|
||||||
|
* @param itemCount The initial popup item count.
|
||||||
|
*/
|
||||||
|
public void setInitialActivityCount(int itemCount) {
|
||||||
|
mInitialActivityCount = itemCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets a content description of the default action button. This
|
||||||
|
* resource should be a string taking one formatting argument and
|
||||||
|
* will be used for formatting the content description of the button
|
||||||
|
* dynamically as the default target changes. For example, a resource
|
||||||
|
* pointing to the string "share with %1$s" will result in a content
|
||||||
|
* description "share with Bluetooth" for the Bluetooth activity.
|
||||||
|
*
|
||||||
|
* @param resourceId The resource id.
|
||||||
|
*/
|
||||||
|
public void setDefaultActionButtonContentDescription(int resourceId) {
|
||||||
|
mDefaultActionButtonContentDescription = resourceId;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the list popup window which is lazily initialized.
|
||||||
|
*
|
||||||
|
* @return The popup.
|
||||||
|
*/
|
||||||
|
private IcsListPopupWindow getListPopupWindow() {
|
||||||
|
if (mListPopupWindow == null) {
|
||||||
|
mListPopupWindow = new IcsListPopupWindow(getContext());
|
||||||
|
mListPopupWindow.setAdapter(mAdapter);
|
||||||
|
mListPopupWindow.setAnchorView(ActivityChooserView.this);
|
||||||
|
mListPopupWindow.setModal(true);
|
||||||
|
mListPopupWindow.setOnItemClickListener(mCallbacks);
|
||||||
|
mListPopupWindow.setOnDismissListener(mCallbacks);
|
||||||
|
}
|
||||||
|
return mListPopupWindow;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Updates the buttons state.
|
||||||
|
*/
|
||||||
|
private void updateAppearance() {
|
||||||
|
// Expand overflow button.
|
||||||
|
if (mAdapter.getCount() > 0) {
|
||||||
|
mExpandActivityOverflowButton.setEnabled(true);
|
||||||
|
} else {
|
||||||
|
mExpandActivityOverflowButton.setEnabled(false);
|
||||||
|
}
|
||||||
|
// Default activity button.
|
||||||
|
final int activityCount = mAdapter.getActivityCount();
|
||||||
|
final int historySize = mAdapter.getHistorySize();
|
||||||
|
if (activityCount > 0 && historySize > 0) {
|
||||||
|
mDefaultActivityButton.setVisibility(VISIBLE);
|
||||||
|
ResolveInfo activity = mAdapter.getDefaultActivity();
|
||||||
|
PackageManager packageManager = mContext.getPackageManager();
|
||||||
|
mDefaultActivityButtonImage.setImageDrawable(activity.loadIcon(packageManager));
|
||||||
|
if (mDefaultActionButtonContentDescription != 0) {
|
||||||
|
CharSequence label = activity.loadLabel(packageManager);
|
||||||
|
String contentDescription = mContext.getString(
|
||||||
|
mDefaultActionButtonContentDescription, label);
|
||||||
|
mDefaultActivityButton.setContentDescription(contentDescription);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
mDefaultActivityButton.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
|
// Activity chooser content.
|
||||||
|
if (mDefaultActivityButton.getVisibility() == VISIBLE) {
|
||||||
|
mActivityChooserContent.setBackgroundDrawable(mActivityChooserContentBackground);
|
||||||
|
} else {
|
||||||
|
mActivityChooserContent.setBackgroundDrawable(null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface implementation to avoid publishing them in the APIs.
|
||||||
|
*/
|
||||||
|
private class Callbacks implements AdapterView.OnItemClickListener,
|
||||||
|
View.OnClickListener, View.OnLongClickListener, PopupWindow.OnDismissListener {
|
||||||
|
|
||||||
|
// AdapterView#OnItemClickListener
|
||||||
|
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
|
||||||
|
ActivityChooserViewAdapter adapter = (ActivityChooserViewAdapter) parent.getAdapter();
|
||||||
|
final int itemViewType = adapter.getItemViewType(position);
|
||||||
|
switch (itemViewType) {
|
||||||
|
case ActivityChooserViewAdapter.ITEM_VIEW_TYPE_FOOTER: {
|
||||||
|
showPopupUnchecked(ActivityChooserViewAdapter.MAX_ACTIVITY_COUNT_UNLIMITED);
|
||||||
|
} break;
|
||||||
|
case ActivityChooserViewAdapter.ITEM_VIEW_TYPE_ACTIVITY: {
|
||||||
|
dismissPopup();
|
||||||
|
if (mIsSelectingDefaultActivity) {
|
||||||
|
// The item at position zero is the default already.
|
||||||
|
if (position > 0) {
|
||||||
|
mAdapter.getDataModel().setDefaultActivity(position);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// If the default target is not shown in the list, the first
|
||||||
|
// item in the model is default action => adjust index
|
||||||
|
position = mAdapter.getShowDefaultActivity() ? position : position + 1;
|
||||||
|
Intent launchIntent = mAdapter.getDataModel().chooseActivity(position);
|
||||||
|
if (launchIntent != null) {
|
||||||
|
mContext.startActivity(launchIntent);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} break;
|
||||||
|
default:
|
||||||
|
throw new IllegalArgumentException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// View.OnClickListener
|
||||||
|
public void onClick(View view) {
|
||||||
|
if (view == mDefaultActivityButton) {
|
||||||
|
dismissPopup();
|
||||||
|
ResolveInfo defaultActivity = mAdapter.getDefaultActivity();
|
||||||
|
final int index = mAdapter.getDataModel().getActivityIndex(defaultActivity);
|
||||||
|
Intent launchIntent = mAdapter.getDataModel().chooseActivity(index);
|
||||||
|
if (launchIntent != null) {
|
||||||
|
mContext.startActivity(launchIntent);
|
||||||
|
}
|
||||||
|
} else if (view == mExpandActivityOverflowButton) {
|
||||||
|
mIsSelectingDefaultActivity = false;
|
||||||
|
showPopupUnchecked(mInitialActivityCount);
|
||||||
|
} else {
|
||||||
|
throw new IllegalArgumentException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// OnLongClickListener#onLongClick
|
||||||
|
@Override
|
||||||
|
public boolean onLongClick(View view) {
|
||||||
|
if (view == mDefaultActivityButton) {
|
||||||
|
if (mAdapter.getCount() > 0) {
|
||||||
|
mIsSelectingDefaultActivity = true;
|
||||||
|
showPopupUnchecked(mInitialActivityCount);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
throw new IllegalArgumentException();
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// PopUpWindow.OnDismissListener#onDismiss
|
||||||
|
public void onDismiss() {
|
||||||
|
notifyOnDismissListener();
|
||||||
|
if (mProvider != null) {
|
||||||
|
mProvider.subUiVisibilityChanged(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void notifyOnDismissListener() {
|
||||||
|
if (mOnDismissListener != null) {
|
||||||
|
mOnDismissListener.onDismiss();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class SetActivated {
|
||||||
|
public static void invoke(View view, boolean activated) {
|
||||||
|
view.setActivated(activated);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final boolean IS_HONEYCOMB = Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adapter for backing the list of activities shown in the popup.
|
||||||
|
*/
|
||||||
|
private class ActivityChooserViewAdapter extends BaseAdapter {
|
||||||
|
|
||||||
|
public static final int MAX_ACTIVITY_COUNT_UNLIMITED = Integer.MAX_VALUE;
|
||||||
|
|
||||||
|
public static final int MAX_ACTIVITY_COUNT_DEFAULT = 4;
|
||||||
|
|
||||||
|
private static final int ITEM_VIEW_TYPE_ACTIVITY = 0;
|
||||||
|
|
||||||
|
private static final int ITEM_VIEW_TYPE_FOOTER = 1;
|
||||||
|
|
||||||
|
private static final int ITEM_VIEW_TYPE_COUNT = 3;
|
||||||
|
|
||||||
|
private ActivityChooserModel mDataModel;
|
||||||
|
|
||||||
|
private int mMaxActivityCount = MAX_ACTIVITY_COUNT_DEFAULT;
|
||||||
|
|
||||||
|
private boolean mShowDefaultActivity;
|
||||||
|
|
||||||
|
private boolean mHighlightDefaultActivity;
|
||||||
|
|
||||||
|
private boolean mShowFooterView;
|
||||||
|
|
||||||
|
public void setDataModel(ActivityChooserModel dataModel) {
|
||||||
|
ActivityChooserModel oldDataModel = mAdapter.getDataModel();
|
||||||
|
if (oldDataModel != null && isShown()) {
|
||||||
|
oldDataModel.unregisterObserver(mModelDataSetOberver);
|
||||||
|
}
|
||||||
|
mDataModel = dataModel;
|
||||||
|
if (dataModel != null && isShown()) {
|
||||||
|
dataModel.registerObserver(mModelDataSetOberver);
|
||||||
|
}
|
||||||
|
notifyDataSetChanged();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getItemViewType(int position) {
|
||||||
|
if (mShowFooterView && position == getCount() - 1) {
|
||||||
|
return ITEM_VIEW_TYPE_FOOTER;
|
||||||
|
} else {
|
||||||
|
return ITEM_VIEW_TYPE_ACTIVITY;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getViewTypeCount() {
|
||||||
|
return ITEM_VIEW_TYPE_COUNT;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getCount() {
|
||||||
|
int count = 0;
|
||||||
|
int activityCount = mDataModel.getActivityCount();
|
||||||
|
if (!mShowDefaultActivity && mDataModel.getDefaultActivity() != null) {
|
||||||
|
activityCount--;
|
||||||
|
}
|
||||||
|
count = Math.min(activityCount, mMaxActivityCount);
|
||||||
|
if (mShowFooterView) {
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Object getItem(int position) {
|
||||||
|
final int itemViewType = getItemViewType(position);
|
||||||
|
switch (itemViewType) {
|
||||||
|
case ITEM_VIEW_TYPE_FOOTER:
|
||||||
|
return null;
|
||||||
|
case ITEM_VIEW_TYPE_ACTIVITY:
|
||||||
|
if (!mShowDefaultActivity && mDataModel.getDefaultActivity() != null) {
|
||||||
|
position++;
|
||||||
|
}
|
||||||
|
return mDataModel.getActivity(position);
|
||||||
|
default:
|
||||||
|
throw new IllegalArgumentException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getItemId(int position) {
|
||||||
|
return position;
|
||||||
|
}
|
||||||
|
|
||||||
|
public View getView(int position, View convertView, ViewGroup parent) {
|
||||||
|
final int itemViewType = getItemViewType(position);
|
||||||
|
switch (itemViewType) {
|
||||||
|
case ITEM_VIEW_TYPE_FOOTER:
|
||||||
|
if (convertView == null || convertView.getId() != ITEM_VIEW_TYPE_FOOTER) {
|
||||||
|
convertView = LayoutInflater.from(getContext()).inflate(
|
||||||
|
R.layout.abs__activity_chooser_view_list_item, parent, false);
|
||||||
|
convertView.setId(ITEM_VIEW_TYPE_FOOTER);
|
||||||
|
TextView titleView = (TextView) convertView.findViewById(R.id.abs__title);
|
||||||
|
titleView.setText(mContext.getString(
|
||||||
|
R.string.abs__activity_chooser_view_see_all));
|
||||||
|
}
|
||||||
|
return convertView;
|
||||||
|
case ITEM_VIEW_TYPE_ACTIVITY:
|
||||||
|
if (convertView == null || convertView.getId() != R.id.abs__list_item) {
|
||||||
|
convertView = LayoutInflater.from(getContext()).inflate(
|
||||||
|
R.layout.abs__activity_chooser_view_list_item, parent, false);
|
||||||
|
}
|
||||||
|
PackageManager packageManager = mContext.getPackageManager();
|
||||||
|
// Set the icon
|
||||||
|
ImageView iconView = (ImageView) convertView.findViewById(R.id.abs__icon);
|
||||||
|
ResolveInfo activity = (ResolveInfo) getItem(position);
|
||||||
|
iconView.setImageDrawable(activity.loadIcon(packageManager));
|
||||||
|
// Set the title.
|
||||||
|
TextView titleView = (TextView) convertView.findViewById(R.id.abs__title);
|
||||||
|
titleView.setText(activity.loadLabel(packageManager));
|
||||||
|
if (IS_HONEYCOMB) {
|
||||||
|
// Highlight the default.
|
||||||
|
if (mShowDefaultActivity && position == 0 && mHighlightDefaultActivity) {
|
||||||
|
SetActivated.invoke(convertView, true);
|
||||||
|
} else {
|
||||||
|
SetActivated.invoke(convertView, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return convertView;
|
||||||
|
default:
|
||||||
|
throw new IllegalArgumentException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public int measureContentWidth() {
|
||||||
|
// The user may have specified some of the target not to be shown but we
|
||||||
|
// want to measure all of them since after expansion they should fit.
|
||||||
|
final int oldMaxActivityCount = mMaxActivityCount;
|
||||||
|
mMaxActivityCount = MAX_ACTIVITY_COUNT_UNLIMITED;
|
||||||
|
|
||||||
|
int contentWidth = 0;
|
||||||
|
View itemView = null;
|
||||||
|
|
||||||
|
final int widthMeasureSpec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED);
|
||||||
|
final int heightMeasureSpec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED);
|
||||||
|
final int count = getCount();
|
||||||
|
|
||||||
|
for (int i = 0; i < count; i++) {
|
||||||
|
itemView = getView(i, itemView, null);
|
||||||
|
itemView.measure(widthMeasureSpec, heightMeasureSpec);
|
||||||
|
contentWidth = Math.max(contentWidth, itemView.getMeasuredWidth());
|
||||||
|
}
|
||||||
|
|
||||||
|
mMaxActivityCount = oldMaxActivityCount;
|
||||||
|
|
||||||
|
return contentWidth;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setMaxActivityCount(int maxActivityCount) {
|
||||||
|
if (mMaxActivityCount != maxActivityCount) {
|
||||||
|
mMaxActivityCount = maxActivityCount;
|
||||||
|
notifyDataSetChanged();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public ResolveInfo getDefaultActivity() {
|
||||||
|
return mDataModel.getDefaultActivity();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setShowFooterView(boolean showFooterView) {
|
||||||
|
if (mShowFooterView != showFooterView) {
|
||||||
|
mShowFooterView = showFooterView;
|
||||||
|
notifyDataSetChanged();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getActivityCount() {
|
||||||
|
return mDataModel.getActivityCount();
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getHistorySize() {
|
||||||
|
return mDataModel.getHistorySize();
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getMaxActivityCount() {
|
||||||
|
return mMaxActivityCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ActivityChooserModel getDataModel() {
|
||||||
|
return mDataModel;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setShowDefaultActivity(boolean showDefaultActivity,
|
||||||
|
boolean highlightDefaultActivity) {
|
||||||
|
if (mShowDefaultActivity != showDefaultActivity
|
||||||
|
|| mHighlightDefaultActivity != highlightDefaultActivity) {
|
||||||
|
mShowDefaultActivity = showDefaultActivity;
|
||||||
|
mHighlightDefaultActivity = highlightDefaultActivity;
|
||||||
|
notifyDataSetChanged();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean getShowDefaultActivity() {
|
||||||
|
return mShowDefaultActivity;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,316 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2011 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.actionbarsherlock.widget;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
|
import android.content.pm.ResolveInfo;
|
||||||
|
import android.graphics.drawable.Drawable;
|
||||||
|
import android.util.TypedValue;
|
||||||
|
import android.view.View;
|
||||||
|
|
||||||
|
import com.actionbarsherlock.R;
|
||||||
|
import com.actionbarsherlock.view.ActionProvider;
|
||||||
|
import com.actionbarsherlock.view.Menu;
|
||||||
|
import com.actionbarsherlock.view.MenuItem;
|
||||||
|
import com.actionbarsherlock.view.MenuItem.OnMenuItemClickListener;
|
||||||
|
import com.actionbarsherlock.view.SubMenu;
|
||||||
|
import com.actionbarsherlock.widget.ActivityChooserModel.OnChooseActivityListener;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is a provider for a share action. It is responsible for creating views
|
||||||
|
* that enable data sharing and also to show a sub menu with sharing activities
|
||||||
|
* if the hosting item is placed on the overflow menu.
|
||||||
|
* <p>
|
||||||
|
* Here is how to use the action provider with custom backing file in a {@link MenuItem}:
|
||||||
|
* </p>
|
||||||
|
* <p>
|
||||||
|
* <pre>
|
||||||
|
* <code>
|
||||||
|
* // In Activity#onCreateOptionsMenu
|
||||||
|
* public boolean onCreateOptionsMenu(Menu menu) {
|
||||||
|
* // Get the menu item.
|
||||||
|
* MenuItem menuItem = menu.findItem(R.id.my_menu_item);
|
||||||
|
* // Get the provider and hold onto it to set/change the share intent.
|
||||||
|
* mShareActionProvider = (ShareActionProvider) menuItem.getActionProvider();
|
||||||
|
* // Set history different from the default before getting the action
|
||||||
|
* // view since a call to {@link MenuItem#getActionView() MenuItem.getActionView()} calls
|
||||||
|
* // {@link ActionProvider#onCreateActionView()} which uses the backing file name. Omit this
|
||||||
|
* // line if using the default share history file is desired.
|
||||||
|
* mShareActionProvider.setShareHistoryFileName("custom_share_history.xml");
|
||||||
|
* . . .
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* // Somewhere in the application.
|
||||||
|
* public void doShare(Intent shareIntent) {
|
||||||
|
* // When you want to share set the share intent.
|
||||||
|
* mShareActionProvider.setShareIntent(shareIntent);
|
||||||
|
* }
|
||||||
|
* </pre>
|
||||||
|
* </code>
|
||||||
|
* </p>
|
||||||
|
* <p>
|
||||||
|
* <strong>Note:</strong> While the sample snippet demonstrates how to use this provider
|
||||||
|
* in the context of a menu item, the use of the provider is not limited to menu items.
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @see ActionProvider
|
||||||
|
*/
|
||||||
|
public class ShareActionProvider extends ActionProvider {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Listener for the event of selecting a share target.
|
||||||
|
*/
|
||||||
|
public interface OnShareTargetSelectedListener {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called when a share target has been selected. The client can
|
||||||
|
* decide whether to handle the intent or rely on the default
|
||||||
|
* behavior which is launching it.
|
||||||
|
* <p>
|
||||||
|
* <strong>Note:</strong> Modifying the intent is not permitted and
|
||||||
|
* any changes to the latter will be ignored.
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @param source The source of the notification.
|
||||||
|
* @param intent The intent for launching the chosen share target.
|
||||||
|
* @return Whether the client has handled the intent.
|
||||||
|
*/
|
||||||
|
public boolean onShareTargetSelected(ShareActionProvider source, Intent intent);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The default for the maximal number of activities shown in the sub-menu.
|
||||||
|
*/
|
||||||
|
private static final int DEFAULT_INITIAL_ACTIVITY_COUNT = 4;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The the maximum number activities shown in the sub-menu.
|
||||||
|
*/
|
||||||
|
private int mMaxShownActivityCount = DEFAULT_INITIAL_ACTIVITY_COUNT;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Listener for handling menu item clicks.
|
||||||
|
*/
|
||||||
|
private final ShareMenuItemOnMenuItemClickListener mOnMenuItemClickListener =
|
||||||
|
new ShareMenuItemOnMenuItemClickListener();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The default name for storing share history.
|
||||||
|
*/
|
||||||
|
public static final String DEFAULT_SHARE_HISTORY_FILE_NAME = "share_history.xml";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Context for accessing resources.
|
||||||
|
*/
|
||||||
|
private final Context mContext;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The name of the file with share history data.
|
||||||
|
*/
|
||||||
|
private String mShareHistoryFileName = DEFAULT_SHARE_HISTORY_FILE_NAME;
|
||||||
|
|
||||||
|
private OnShareTargetSelectedListener mOnShareTargetSelectedListener;
|
||||||
|
|
||||||
|
private OnChooseActivityListener mOnChooseActivityListener;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new instance.
|
||||||
|
*
|
||||||
|
* @param context Context for accessing resources.
|
||||||
|
*/
|
||||||
|
public ShareActionProvider(Context context) {
|
||||||
|
super(context);
|
||||||
|
mContext = context;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets a listener to be notified when a share target has been selected.
|
||||||
|
* The listener can optionally decide to handle the selection and
|
||||||
|
* not rely on the default behavior which is to launch the activity.
|
||||||
|
* <p>
|
||||||
|
* <strong>Note:</strong> If you choose the backing share history file
|
||||||
|
* you will still be notified in this callback.
|
||||||
|
* </p>
|
||||||
|
* @param listener The listener.
|
||||||
|
*/
|
||||||
|
public void setOnShareTargetSelectedListener(OnShareTargetSelectedListener listener) {
|
||||||
|
mOnShareTargetSelectedListener = listener;
|
||||||
|
setActivityChooserPolicyIfNeeded();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public View onCreateActionView() {
|
||||||
|
// Create the view and set its data model.
|
||||||
|
ActivityChooserModel dataModel = ActivityChooserModel.get(mContext, mShareHistoryFileName);
|
||||||
|
ActivityChooserView activityChooserView = new ActivityChooserView(mContext);
|
||||||
|
activityChooserView.setActivityChooserModel(dataModel);
|
||||||
|
|
||||||
|
// Lookup and set the expand action icon.
|
||||||
|
TypedValue outTypedValue = new TypedValue();
|
||||||
|
mContext.getTheme().resolveAttribute(R.attr.actionModeShareDrawable, outTypedValue, true);
|
||||||
|
Drawable drawable = mContext.getResources().getDrawable(outTypedValue.resourceId);
|
||||||
|
activityChooserView.setExpandActivityOverflowButtonDrawable(drawable);
|
||||||
|
activityChooserView.setProvider(this);
|
||||||
|
|
||||||
|
// Set content description.
|
||||||
|
activityChooserView.setDefaultActionButtonContentDescription(
|
||||||
|
R.string.abs__shareactionprovider_share_with_application);
|
||||||
|
activityChooserView.setExpandActivityOverflowButtonContentDescription(
|
||||||
|
R.string.abs__shareactionprovider_share_with);
|
||||||
|
|
||||||
|
return activityChooserView;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public boolean hasSubMenu() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void onPrepareSubMenu(SubMenu subMenu) {
|
||||||
|
// Clear since the order of items may change.
|
||||||
|
subMenu.clear();
|
||||||
|
|
||||||
|
ActivityChooserModel dataModel = ActivityChooserModel.get(mContext, mShareHistoryFileName);
|
||||||
|
PackageManager packageManager = mContext.getPackageManager();
|
||||||
|
|
||||||
|
final int expandedActivityCount = dataModel.getActivityCount();
|
||||||
|
final int collapsedActivityCount = Math.min(expandedActivityCount, mMaxShownActivityCount);
|
||||||
|
|
||||||
|
// Populate the sub-menu with a sub set of the activities.
|
||||||
|
for (int i = 0; i < collapsedActivityCount; i++) {
|
||||||
|
ResolveInfo activity = dataModel.getActivity(i);
|
||||||
|
subMenu.add(0, i, i, activity.loadLabel(packageManager))
|
||||||
|
.setIcon(activity.loadIcon(packageManager))
|
||||||
|
.setOnMenuItemClickListener(mOnMenuItemClickListener);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (collapsedActivityCount < expandedActivityCount) {
|
||||||
|
// Add a sub-menu for showing all activities as a list item.
|
||||||
|
SubMenu expandedSubMenu = subMenu.addSubMenu(Menu.NONE, collapsedActivityCount,
|
||||||
|
collapsedActivityCount,
|
||||||
|
mContext.getString(R.string.abs__activity_chooser_view_see_all));
|
||||||
|
for (int i = 0; i < expandedActivityCount; i++) {
|
||||||
|
ResolveInfo activity = dataModel.getActivity(i);
|
||||||
|
expandedSubMenu.add(0, i, i, activity.loadLabel(packageManager))
|
||||||
|
.setIcon(activity.loadIcon(packageManager))
|
||||||
|
.setOnMenuItemClickListener(mOnMenuItemClickListener);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the file name of a file for persisting the share history which
|
||||||
|
* history will be used for ordering share targets. This file will be used
|
||||||
|
* for all view created by {@link #onCreateActionView()}. Defaults to
|
||||||
|
* {@link #DEFAULT_SHARE_HISTORY_FILE_NAME}. Set to <code>null</code>
|
||||||
|
* if share history should not be persisted between sessions.
|
||||||
|
* <p>
|
||||||
|
* <strong>Note:</strong> The history file name can be set any time, however
|
||||||
|
* only the action views created by {@link #onCreateActionView()} after setting
|
||||||
|
* the file name will be backed by the provided file.
|
||||||
|
* <p>
|
||||||
|
*
|
||||||
|
* @param shareHistoryFile The share history file name.
|
||||||
|
*/
|
||||||
|
public void setShareHistoryFileName(String shareHistoryFile) {
|
||||||
|
mShareHistoryFileName = shareHistoryFile;
|
||||||
|
setActivityChooserPolicyIfNeeded();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets an intent with information about the share action. Here is a
|
||||||
|
* sample for constructing a share intent:
|
||||||
|
* <p>
|
||||||
|
* <pre>
|
||||||
|
* <code>
|
||||||
|
* Intent shareIntent = new Intent(Intent.ACTION_SEND);
|
||||||
|
* shareIntent.setType("image/*");
|
||||||
|
* Uri uri = Uri.fromFile(new File(getFilesDir(), "foo.jpg"));
|
||||||
|
* shareIntent.putExtra(Intent.EXTRA_STREAM, uri.toString());
|
||||||
|
* </pre>
|
||||||
|
* </code>
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @param shareIntent The share intent.
|
||||||
|
*
|
||||||
|
* @see Intent#ACTION_SEND
|
||||||
|
* @see Intent#ACTION_SEND_MULTIPLE
|
||||||
|
*/
|
||||||
|
public void setShareIntent(Intent shareIntent) {
|
||||||
|
ActivityChooserModel dataModel = ActivityChooserModel.get(mContext,
|
||||||
|
mShareHistoryFileName);
|
||||||
|
dataModel.setIntent(shareIntent);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reusable listener for handling share item clicks.
|
||||||
|
*/
|
||||||
|
private class ShareMenuItemOnMenuItemClickListener implements OnMenuItemClickListener {
|
||||||
|
@Override
|
||||||
|
public boolean onMenuItemClick(MenuItem item) {
|
||||||
|
ActivityChooserModel dataModel = ActivityChooserModel.get(mContext,
|
||||||
|
mShareHistoryFileName);
|
||||||
|
final int itemId = item.getItemId();
|
||||||
|
Intent launchIntent = dataModel.chooseActivity(itemId);
|
||||||
|
if (launchIntent != null) {
|
||||||
|
mContext.startActivity(launchIntent);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the activity chooser policy of the model backed by the current
|
||||||
|
* share history file if needed which is if there is a registered callback.
|
||||||
|
*/
|
||||||
|
private void setActivityChooserPolicyIfNeeded() {
|
||||||
|
if (mOnShareTargetSelectedListener == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (mOnChooseActivityListener == null) {
|
||||||
|
mOnChooseActivityListener = new ShareAcitivityChooserModelPolicy();
|
||||||
|
}
|
||||||
|
ActivityChooserModel dataModel = ActivityChooserModel.get(mContext, mShareHistoryFileName);
|
||||||
|
dataModel.setOnChooseActivityListener(mOnChooseActivityListener);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Policy that delegates to the {@link OnShareTargetSelectedListener}, if such.
|
||||||
|
*/
|
||||||
|
private class ShareAcitivityChooserModelPolicy implements OnChooseActivityListener {
|
||||||
|
@Override
|
||||||
|
public boolean onChooseActivity(ActivityChooserModel host, Intent intent) {
|
||||||
|
if (mOnShareTargetSelectedListener != null) {
|
||||||
|
return mOnShareTargetSelectedListener.onShareTargetSelected(
|
||||||
|
ShareActionProvider.this, intent);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|