c# - SetSupportActionBar 在 Visual Studio 和 Xamarin 中崩溃

标签 c# android xamarin visual-studio-2015 toolbar

我正在尝试使用 Xamarin 和 Visual Studio 创建一个 Android 应用程序。 在使用 SetSupportActionBar 函数时突然出现一个奇怪的错误。

这是我的 XML 代码:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">
  <android.support.v7.widget.Toolbar
      android:id="@+id/toolbar"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:minHeight="?attr/actionBarSize"
      android:background="?attr/colorPrimary"
      app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
      app:popupTheme="@style/ThemeOverlay.AppCompat.Dark" />
  <android.support.v4.widget.DrawerLayout
      android:id="@+id/drawer_layout"
      android:layout_width="match_parent"
      android:layout_height="match_parent">
    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">
      .
      .
      .
    </RelativeLayout>
    <ListView
        android:id="@+id/left_drawer"
        android:layout_width="240dp"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        android:choiceMode="singleChoice"
        android:divider="#818181"
        android:dividerHeight="1dp"
        android:background="#E3F2FD" />
  </android.support.v4.widget.DrawerLayout>
</LinearLayout>

这是我的 C# 文件代码:

using System;
using System.Collections.Generic;
using System.Linq;
using Android.App;
using Android.OS;
using Android.Widget;
using SupportToolBar = Android.Support.V7.Widget.Toolbar;
using Android.Support.V7.App;
using Android.Support.V4.Widget;
using Android.Locations;
using System.Net;

namespace IBuy
{
    [Activity(Label = "Main Screen", Theme = "@style/MyTheme")]
    public class MainScreen : ActionBarActivity, ILocationListener
    {
        private SupportToolBar mToolbar;
        private MyActionBarDrawerToggle mDrawerToggle;
        private DrawerLayout mDrawerLayout;
        private ListView mLeftDrawer;
        private int userID, storeID, permission;
        private LocationManager locationManager;
        private string deviceID = Build.Serial;
        private double currentX = 0, currentY = 0;
        private bool sent = false;
        private ProgressBar pBar;
        private TextView txt;

        protected override void OnCreate(Bundle bundle)
        {
            base.OnCreate(bundle);
            SetContentView(Resource.Layout.MainScreen);

            Title = GetString(Resource.String.main_screen);

            try
            {
                mToolbar = FindViewById<SupportToolBar>(Resource.Id.toolbar);
                mDrawerLayout = FindViewById<DrawerLayout>(Resource.Id.drawer_layout);
                mLeftDrawer = FindViewById<ListView>(Resource.Id.left_drawer);
                SetSupportActionBar(mToolbar);
            }
            catch (Exception ex)
            {
                Console.WriteLine("@@@@@@@@@@@@@@@@@@@");
                Console.WriteLine(ex.Message);
                Console.WriteLine(ex.InnerException);
                Console.WriteLine(ex.Data);
                Console.WriteLine(ex.Source);
                Console.WriteLine(ex.StackTrace);
                Console.WriteLine(ex.ToString());
                Console.WriteLine("#################");
            }

            mDrawerToggle = new MyActionBarDrawerToggle(this, mDrawerLayout, Resource.String.openDrawer, Resource.String.closeDrawer);

            mDrawerLayout.SetDrawerListener(mDrawerToggle);

            SupportActionBar.SetHomeButtonEnabled(true);
            SupportActionBar.SetDisplayShowTitleEnabled(true);
            mDrawerToggle.SyncState();

            .
            .
            .
        }
    }
}

奇怪的是应用程序在执行此命令时崩溃:SetSupportActionBar(mToolbar);

这是我得到的异常:

Exception of type 'Java.Lang.IllegalStateException' was thrown.
09-26 12:09:03.399 I/mono-stdout(13640): Exception of type 'Java.Lang.IllegalStateException' was thrown.
System.Collections.Generic.Dictionary`2[System.Object,System.Object]
09-26 12:09:05.849 I/mono-stdout(13640): System.Collections.Generic.Dictionary`2[System.Object,System.Object]
mscorlib
09-26 12:09:07.468 I/mono-stdout(13640): mscorlib
  at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw () [0x0000b] in /Users/builder/data/lanes/1978/f98871a9/source/mono/mcs/class/corlib/System.Runtime.ExceptionServices/ExceptionDispatchInfo.cs:61 
09-26 12:09:09.037 I/mono-stdout(13640):   at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw () [0x0000b] in /Users/builder/data/lanes/1978/f98871a9/source/mono/mcs/class/corlib/System.Runtime.ExceptionServices/ExceptionDispatchInfo.cs:61 
09-26 12:09:09.038 I/mono-stdout(13640):   at Android.Runtime.JNIEnv.CallNonvirtualVoidMethod (IntPtr jobject, IntPtr jclass, IntPtr jmethod, Android.Runtime.JValue* parms) [0x00084] in /Users/builder/data/lanes/1978/f98871a9/source/monodroid/src/Mono.Android/src/Runtime/JNIEnv.g.cs:1029 
  at Android.Runtime.JNIEnv.CallNonvirtualVoidMethod (IntPtr jobject, IntPtr jclass, IntPtr jmethod, Android.Runtime.JValue* parms) [0x00084] in /Users/builder/data/lanes/1978/f98871a9/source/monodroid/src/Mono.Android/src/Runtime/JNIEnv.g.cs:1029 
  at Android.Support.V7.App.AppCompatActivity.SetSupportActionBar (Android.Support.V7.Widget.Toolbar toolbar) [0x00091] in <filename unknown>:0 
  at IBuy.MainScreen.OnCreate (Android.OS.Bundle bundle) [0x0005b] in C:\Users\איציק\Source\Workspaces\iBuy\IBuy\IBuy\Screens\MainScreen.cs:42 
  --- End of managed exception stack trace ---
java.lang.IllegalStateException: This Activity already has an action bar supplied by the window decor. Do not request Window.FEATURE_ACTION_BAR and set windowActionBar to false in your theme to use a Toolbar instead.
    at android.support.v7.app.AppCompatDelegateImplV7.setSupportActionBar(AppCompatDelegateImplV7.java:193)
    at android.support.v7.app.AppCompatActivity.setSupportActionBar(AppCompatActivity.java:96)
    at md5f6ea2975de2355cb6a
09-26 12:09:09.038 I/mono-stdout(13640):   at Android.Support.V7.App.AppCompatActivity.SetSupportActionBar (Android.Support.V7.Widget.Toolbar toolbar) [0x00091] in <filename unknown>:0 
09-26 12:09:09.038 I/mono-stdout(13640):   at IBuy.MainScreen.OnCreate (Android.OS.Bundle bundle) [0x0005b] in C:\Users\איציק\Source\Workspaces\iBuy\IBuy\IBuy\Screens\MainScreen.cs:42 
574b5b4ea31e7d.MainScreen.n_onCreate(Native Method)
    at md5f6ea2975de2355cb6a574b5b4ea31e7d.MainScreen.onCreate(MainScreen.java:36)
    at android.app.Activity.performCreate(Activity.java:5990)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2418)
    at android.app.ActivityThread.access$900(ActivityThread.java:154)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1321)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:135)
    at android.app.ActivityThread.main(ActivityThread.java:5289)
    at java.lang.reflect.Method.invoke(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:372)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:904)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:699)
09-26 12:09:09.038 I/mono-stdout(13640):   --- End of managed exception stack trace ---
09-26 12:09:09.038 I/mono-stdout(13640): java.lang.IllegalStateException: This Activity already has an action bar supplied by the window decor. Do not request Window.FEATURE_ACTION_BAR and set windowActionBar to false in your theme to use a Toolbar instead.
09-26 12:09:09.039 I/mono-stdout(13640):    at android.support.v7.app.AppCompatDelegateImplV7.setSupportActionBar(AppCompatDelegateImplV7.java:193)
09-26 12:09:09.039 I/mono-stdout(13640):    at android.support.v7.app.AppCompatActivity.setSupportActionBar(AppCompatActivity.java:96)
09-26 12:09:09.039 I/mono-stdout(13640):    at md5f6ea2975de2355cb6a574b5b4ea31e7d.MainScreen.n_onCreate(Native Method)
09-26 12:09:09.039 I/mono-stdout(13640):    at md5f6ea2975de2355cb6a574b5b4ea31e7d.MainScreen.onCreate(MainScreen.java:36)
09-26 12:09:09.040 I/mono-stdout(13640):    at android.app.Activity.performCreate(Activity.java:5990)
09-26 12:09:09.040 I/mono-stdout(13640):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106)
09-26 12:09:09.040 I/mono-stdout(13640):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309)
09-26 12:09:09.041 I/mono-stdout(13640):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2418)
09-26 12:09:09.041 I/mono-stdout(13640):    at android.app.ActivityThread.access$900(ActivityThread.java:154)
09-26 12:09:09.042 I/mono-stdout(13640):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1321)
09-26 12:09:09.042 I/mono-stdout(13640):    at android.os.Handler.dispatchMessage(Handler.java:102)
09-26 12:09:09.042 I/mono-stdout(13640):    at android.os.Looper.loop(Looper.java:135)
09-26 12:09:09.042 I/mono-stdout(13640):    at android.app.ActivityThread.main(ActivityThread.java:5289)
09-26 12:09:09.042 I/mono-stdout(13640):    at java.lang.reflect.Method.invoke(Native Method)
09-26 12:09:09.042 I/mono-stdout(13640):    at java.lang.reflect.Method.invoke(Method.java:372)
09-26 12:09:09.042 I/mono-stdout(13640):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:904)
09-26 12:09:09.042 I/mono-stdout(13640):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:699)
09-26 12:09:10.509 I/mono-stdout(13640): Java.Lang.IllegalStateException: Exception of type 'Java.Lang.IllegalStateException' was thrown.
Java.Lang.IllegalStateException: Exception of type 'Java.Lang.IllegalStateException' was thrown.
09-26 12:09:10.515 I/mono-stdout(13640):   at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw () [0x0000b] in /Users/builder/data/lanes/1978/f98871a9/source/mono/mcs/class/corlib/System.Runtime.ExceptionServices/ExceptionDispatchInfo.cs:61 
  at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw () [0x0000b] in /Users/builder/data/lanes/1978/f98871a9/source/mono/mcs/class/corlib/System.Runtime.ExceptionServices/ExceptionDispatchInfo.cs:61 
09-26 12:09:10.517 I/mono-stdout(13640):   at Android.Runtime.JNIEnv.CallNonvirtualVoidMethod (IntPtr jobject, IntPtr jclass, IntPtr jmethod, Android.Runtime.JValue* parms) [0x00084] in /Users/builder/data/lanes/1978/f98871a9/source/monodroid/src/Mono.Android/src/Runtime/JNIEnv.g.cs:1029 
  at Android.Runtime.JNIEnv.CallNonvirtualVoidMethod (IntPtr jobject, IntPtr jclass, IntPtr jmethod, Android.Runtime.JValue* parms) [0x00084] in /Users/builder/data/lanes/1978/f98871a9/source/monodroid/src/Mono.Android/src/Runtime/JNIEnv.g.cs:1029 
  at Android.Support.V7.App.AppCompatActivity.SetSupportActionBar (Android.Support.V7.Widget.Toolbar toolbar) [0x00091] in <filename unknown>:0 
09-26 12:09:10.518 I/mono-stdout(13640):   at Android.Support.V7.App.AppCompatActivity.SetSupportActionBar (Android.Support.V7.Widget.Toolbar toolbar) [0x00091] in <filename unknown>:0 
  at IBuy.MainScreen.OnCreate (Android.OS.Bundle bundle) [0x0005b] in C:\Users\איציק\Source\Workspaces\iBuy\IBuy\IBuy\Screens\MainScreen.cs:42 
  --- End of managed exception stack trace ---
09-26 12:09:10.520 I/mono-stdout(13640):   at IBuy.MainScreen.OnCreate (Android.OS.Bundle bundle) [0x0005b] in C:\Users\איציק\Source\Workspaces\iBuy\IBuy\IBuy\Screens\MainScreen.cs:42 
java.lang.IllegalStateException: This Activity already has an action bar supplied by the window decor. Do not request Window.FEATURE_ACTION_BAR and set windowActionBar to false in your theme to use a Toolbar instead.
    at android.support.v7.app.AppCompatDelegateImplV7.setSupportActionBar(AppCompatDelegateImplV7.java:193)
    at android.support.v7.app.AppCompatActivity.setSupportActionBar(AppCompatActivity.java:96)
    at md5f6ea2975de2355cb6a574b5b4ea31e7d.MainScreen.n_onCreate(Native Method)
    at md5f6ea2975de2355cb6a574b5b4ea31e7d.MainScreen.onCreate(MainScreen.java:36)
    at android.app.Activity.performCreate(Activity.java:5990)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2418)
09-26 12:09:10.520 I/mono-stdout(13640):   --- End of managed exception stack trace ---
    at android.app.ActivityThread.access$900(ActivityThread.java:154)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1321)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:135)
09-26 12:09:10.523 I/mono-stdout(13640): java.lang.IllegalStateException: This Activity already has an action bar supplied by the window decor. Do not request Window.FEATURE_ACTION_BAR and set windowActionBar to false in your theme to use a Toolbar instead.
    at android.app.ActivityThread.main(ActivityThread.java:5289)
    at java.lang.reflect.Method.invoke(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:372)
09-26 12:09:10.523 I/mono-stdout(13640):    at android.support.v7.app.AppCompatDelegateImplV7.setSupportActionBar(AppCompatDelegateImplV7.java:193)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:904)
09-26 12:09:10.524 I/mono-stdout(13640):    at android.support.v7.app.AppCompatActivity.setSupportActionBar(AppCompatActivity.java:96)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:699)
09-26 12:09:10.529 I/mono-stdout(13640):    at md5f6ea2975de2355cb6a574b5b4ea31e7d.MainScreen.n_onCreate(Native Method)
09-26 12:09:10.529 I/mono-stdout(13640):    at md5f6ea2975de2355cb6a574b5b4ea31e7d.MainScreen.onCreate(MainScreen.java:36)
09-26 12:09:10.530 I/mono-stdout(13640):    at android.app.Activity.performCreate(Activity.java:5990)
09-26 12:09:10.531 I/mono-stdout(13640):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106)
09-26 12:09:10.532 I/mono-stdout(13640):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309)
09-26 12:09:10.534 I/mono-stdout(13640):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2418)
09-26 12:09:10.535 I/mono-stdout(13640):    at android.app.ActivityThread.access$900(ActivityThread.java:154)
09-26 12:09:10.536 I/mono-stdout(13640):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1321)
09-26 12:09:10.537 I/mono-stdout(13640):    at android.os.Handler.dispatchMessage(Handler.java:102)
09-26 12:09:10.539 I/mono-stdout(13640):    at android.os.Looper.loop(Looper.java:135)
09-26 12:09:10.543 I/mono-stdout(13640):    at java.lang.reflect.Method.invoke(Native Method)
09-26 12:09:10.544 I/mono-stdout(13640):    at java.lang.reflect.Method.invoke(Method.java:372)
09-26 12:09:10.546 I/mono-stdout(13640):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:904)
09-26 12:09:10.547 I/mono-stdout(13640):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:699)

它之前运行良好,我不记得有任何可能导致它崩溃的更改。

谁能告诉我该怎么做?

提前致谢!

最佳答案

看起来您的主题没有正确配置。

要么在你的主题中使用(参见 related answer )

<item name="windowActionBar">false</item>

或从没有操作栏的主题派生(参见 related answer ),例如:

Theme.AppCompat.Light.NoActionBar

关于c# - SetSupportActionBar 在 Visual Studio 和 Xamarin 中崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32795028/

相关文章:

c# - 选择另一个旁边的特定节点 - C# - SelectSingleNode

c# - 如何将字符串从 ASP.NET 代码后面传递到本地网络存储?

android - Firebase 监听器在空闲时间后无法识别或恢复连接

java - 单击按钮时如何将多个复选框值发送到 Firebase 数据库 Android

visual-studio - Xamarin-如何更新Mono.Android版本以解决依赖关系?

ios - 错误 : The specified provisioning profile could not be found

c# - 运行 ibtool : object cannot be nil (key: family) 时出现 Xamarin.IOS 异常

c# - LazyInitializer.EnsureInitialized 中的 volatile 局部变量?

c# - 拖放后将 div 保存到图像

android - Cast Receiver App 不显示字幕