我刚刚将我的一个应用调整为新的v22.1.1支持& appcompat库,有关详细信息,请参阅here和here。当我进行一些测试时,我正在使用ActionModes使用了一些东西。
当您使用startSupportActionMode()
调用启动ActionMode时,如果您使用现已弃用的ActionBarActivity基类或新的AppCompatActivity基类 - {无关紧要 - { {1}}未被调用。
在以前的版本中,包括v21.0.3& v22.0.0,在最初使用onPrepareActionMode()
创建ActionMode时自动调用onPrepareActionMode()
。
我在2.2,4.4.2和5.0设备上进行了测试,因此它似乎与版本无关。
有人知道,如果这是预期的行为,那是在v22.1.1中引入的,还是一个错误?
我发现了这个issue,但这里没有很多反馈......
编辑2015年5月11日:
正如Android issue tracker 159527中所述,此问题不仅会影响appcompat和支持库的v22.1.x,还会影响5.1 Android实现。
目前有两种可能的临时解决方案,一般是:
startSupportActionMode()
和'快速而肮脏'的(当你实例化你的ActionMode时):
@Override
public ActionMode startSupportActionMode(final ActionMode.Callback callback) {
// Fix for bug https://code.google.com/p/android/issues/detail?id=159527
final ActionMode mode = super.startSupportActionMode(callback);
if (mode != null) {
mode.invalidate();
}
return mode;
}
如果您不使用appcompat(final ActionMode actionMode = startSupportActionMode(new MyActionMode());
if(actionMode != null) {
actionMode.invalidate();
}
/ ActionBarActivity
),则需要将AppCompatActivity
替换为startSupportActionMode()
。
不幸的是,目前还不清楚这是否是新的行为或错误。根据{{3}}它是一个错误/回归,但谁知道...
答案 0 :(得分:1)
我创建了一个演示并且工作正常,每次显示动作模式时都会调用onPrepareActionMode。始终在onCreateActionMode之后调用,但是 如果模式无效,则可以多次调用。 [ 我请求任何人进行小编辑。 我需要状态栏颜色与工具栏相同但动态, 你可以看到不必要的Drawyer Layout用于实现这种效果,但是如果我删除了drawyer布局,状态栏颜色不会根据工具栏颜色而改变。 在实用程序中,您可以看到默认情况下默认主题颜色为红色,工具栏最初为红色,但状态栏不会,仅当我删除绘图布局时。 我需要使用样式来做这件事。 ] 创建资源布局并将其命名为> action_mode_activity
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/my_drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true">
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
android:orientation="vertical"
app:insetForeground="#4000">
<include
android:id="@+id/toolbar"
layout="@layout/toolbar" />
<EditText
android:id="@+id/editTextCopy"
android:layout_width="fill_parent"
android:layout_height="40dp"
android:layout_marginTop="19dp"
android:ems="10"
android:inputType="textMultiLine"
android:text="Long click to share!">
<requestFocus />
</EditText>
</LinearLayout>
</android.support.v4.widget.DrawerLayout>
创建一个名为ActionModeActivity的活动名称
import android.os.Build;
import android.os.Bundle;
import android.support.v7.app.ActionBar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.ActionMode;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;
import com.example.deepakpawar.demolearning.R;
import com.example.deepakpawar.demolearning.demo.load.recycler.Utils;
/**
* Created by Deepak Pawar on 9/24/2015.
*/
public class ActionModeActivity extends AppCompatActivity implements View.OnLongClickListener, ActionMode.Callback {
EditText editTextCopy;
android.view.ActionMode mActionMode;
private Toolbar toolbar;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Utils.onActivityCreateSetTheme(this);
setContentView(R.layout.action_mode_activity);
// 1. Get the editText
editTextCopy = (EditText) findViewById(R.id.editTextCopy);
// 2. add long-click listener
editTextCopy.setOnLongClickListener(this);
toolbar = (Toolbar) findViewById(R.id.toolbar);
if (toolbar != null) {
setSupportActionBar(toolbar);
ActionBar actionBar = getSupportActionBar();
actionBar.setDisplayHomeAsUpEnabled(true);
actionBar.setHomeButtonEnabled(true);
actionBar.setTitle("Android Students");
}
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
getWindow().getDecorView().setSystemUiVisibility(
View.SYSTEM_UI_FLAG_LAYOUT_STABLE
| View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);
}
}
@Override
public boolean onLongClick(View view) {
// if actionmode is null "not started"
if (mActionMode != null) {
return false;
}
// Start the CAB
mActionMode = this.startActionMode(this);
view.setSelected(true);
return true;
}
// 4. Called when the action mode is created; startActionMode() was called
@Override
public boolean onCreateActionMode(android.view.ActionMode mode, Menu menu) {
// Inflate a menu resource providing context menu items
MenuInflater inflater = mode.getMenuInflater();
inflater.inflate(R.menu.action_menu, menu);
return true;
}
// 5. Called when the user click share item
@Override
public boolean onActionItemClicked(android.view.ActionMode mode, MenuItem item) {
switch (item.getItemId()) {
case R.id.action_share:
Toast.makeText(this, "Shared!", Toast.LENGTH_SHORT).show();
mode.finish(); // Action picked, so close the CAB
return true;
default:
return false;
}
}
// 6. Called each time the action mode is shown. Always called after onCreateActionMode, but
// may be called multiple times if the mode is invalidated.
@Override
public boolean onPrepareActionMode(android.view.ActionMode mode, Menu menu) {
Toast.makeText(ActionModeActivity.this,"onPrepareActionMode Called ",Toast.LENGTH_SHORT).show();
return false; // Return false if nothing is done
}
// 7. Called when the user exits the action mode
@Override
public void onDestroyActionMode(android.view.ActionMode mode) {
mActionMode = null;
}
}
// Utils类有改变主题的方法 //我创建它是因为需要动态更改应用主题 import android.app.Activity;
public class Utils {
private static int sTheme;
public final static int THEME_DEFAULT = 0;
public final static int THEME_WHITE = 1;
public final static int THEME_BLUE = 2;
/**
* Set the theme of the Activity, and restart it by creating a new Activity of the same type.
*/
public static int getsTheme() {
return sTheme;
}
public static void changeToTheme(Activity activity, int theme) {
sTheme = theme;
activity.recreate();
// activity.finish();
// activity.startActivity(new Intent(activity, activity.getClass()));
}
/**
* Set the theme of the activity, according to the configuration.
*/
public static void onActivityCreateSetTheme(Activity activity) {
switch (sTheme) {
default:
case THEME_DEFAULT:
activity.setTheme(R.style.FirstTheme);
break;
case THEME_WHITE:
activity.setTheme(R.style.SecondTheme);
break;
case THEME_BLUE:
activity.setTheme(R.style.Thirdheme);
break;
}
}
}
V21-的themes.xml
<resources>
<style name="AppTheme" parent="AppTheme.Base">
<item name="android:windowContentTransitions">true</item>
<item name="android:windowAllowEnterTransitionOverlap">true</item>
<item name="android:windowAllowReturnTransitionOverlap">true</item>
<item name="android:windowSharedElementEnterTransition">@android:transition/move</item>
<item name="android:windowSharedElementExitTransition">@android:transition/move</item>
<item name="android:actionOverflowButtonStyle">@style/Widget.ActionButton.Overflow</item>
<!-- <item name="android:navigationBarColor">@color/PrimaryColor</item>-->
<item name="windowActionBar">false</item>
<item name="windowActionModeOverlay">true</item>
<!-- To Make Navigation Drawer Fill Status Bar and become Transparent Too -->
<item name="android:windowDrawsSystemBarBackgrounds">true</item>
<item name="android:statusBarColor">@android:color/transparent</item>
<!--//if darker status bar needed-->
<!-- <item name="android:windowTranslucentStatus">true</item>-->
</style>
<style name="AppTheme.Base" parent="Theme.AppCompat.Light.NoActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/PrimaryColor</item>
<item name="colorPrimaryDark">@color/PrimaryDarkColor</item>
<item name="colorAccent">@color/AccentColor</item>
<item name="android:textColorPrimary">@color/TextPrimaryColor</item>
<item name="android:windowBackground">@color/WindowBackground</item>
</style>
<style name="Widget.ActionButton.Overflow" parent="@android:style/Widget.Holo.ActionButton.Overflow">
<item name="android:contentDescription">@string/accessibility_overflow</item>
</style>
<!-- style for the tool bar backgrounds -->
<style name="ToolBarStyle" parent="ToolBarStyle.Base" />
<style name="ToolBarStyle.Base" parent="">
<item name="popupTheme">@style/ThemeOverlay.AppCompat.Light</item>
<item name="theme">@style/ThemeOverlay.AppCompat.Dark.ActionBar</item>
</style>
<style name="ToolBarStyle.Event" parent="ToolBarStyle">
<item name="titleTextAppearance">@style/TextAppearance.Widget.Event.Toolbar.Title</item>
</style>
<style name="TextAppearance.Widget.Event.Toolbar.Title" parent="TextAppearance.Widget.AppCompat.Toolbar.Title">
<!--Any text styling can be done here-->
<item name="android:textStyle">normal</item>
<item name="android:textSize">18sp</item>
<item name="android:textColor">#000000</item>
</style>
<!-- Customize your theme example here. -->
<style name="FirstTheme">
<item name="android:textColor">#FF0000</item>
<item name="colorPrimary">#FF0000</item>
<item name="colorPrimaryDark">#ff0000</item>
<item name="colorAccent">#ff0087</item>
<item name="android:shadowColor">#00ccff</item>
<item name="android:shadowRadius">1.5</item>
<item name="android:shadowDy">1</item>
</style>
<style name="SecondTheme">
<item name="android:textColor">#00FF00</item>
<item name="colorPrimary">#00FF00</item>
<item name="colorPrimaryDark">#00FF00</item>
<item name="colorAccent">#00FF90</item>
<item name="android:shadowColor">#00ccff</item>
<item name="android:shadowRadius">1.5</item>
<item name="android:shadowDy">1</item>
</style>
<style name="Thirdheme">
<item name="android:textColor">#0000F0</item>
<item name="colorPrimary">#0000F0</item>
<item name="colorPrimaryDark">#0000F0</item>
<item name="colorAccent">#0090F0</item>
<item name="android:shadowColor">#00ccff</item>
<item name="android:shadowRadius">1.5</item>
<item name="android:shadowDy">1</item>
</style>
<style name="AppCompatAlertDialogStyle" parent="Theme.AppCompat.Light.Dialog.Alert">
<item name="colorAccent">#FFCC00</item>
<item name="android:textColorPrimary">#FFFFFF</item>
<item name="android:background">#5fa3d0</item>
</style>
</resources>
答案 1 :(得分:0)
我遇到了类似的问题。
在我提高了build.gradle的“compileSdkVersion”和“buildToolsVersion”的值之后,我发现没有调用onPrepareActionMode。
所以我把代码从(A)移到了(B)。 (请参阅下文)
我不确定这是否是正确的解决方案,但它确实有效。
以下是我的代码的摘录。
list1 = findViewById(R.id.listView1);
list1.setMultiChoiceModeListener(new AbsListView.MultiChoiceModeListener() {
@Override
public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
//(A)
//MenuItem menuItem1 = menu.findItem(R.id.menu_item1);
//menuItem1.setVisible(false);
return false;
}
@Override
public boolean onCreateActionMode(ActionMode mode, Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.menu_action_mode, menu);
//(B)
MenuItem menuItem1 = menu.findItem(R.id.menu_item1);
menuItem1.setVisible(false);
return true;
}