【问题标题】:Android Studio - " Unfortunately 'appname' has stopped working "Android Studio - “不幸的是 'appname' 已停止工作”
【发布时间】:2015-08-17 04:13:02
【问题描述】:

我正在按照tutorial 制作我的第一个基于材料设计的应用程序。我遇到了几个错误,但除了应用程序崩溃错误之外,我已经克服了这些错误。我不知道为什么会发生这种情况。我尝试使用 API 21 和 API 22 SDK 以及 AVD。我也在真实设备上尝试过。我想错误应该与 java 文件有关,但不知道在哪个文件中,在哪里以及为什么。我这样做是为了我的大学提交。请帮助我。

我的 MainActivity.java :

package com.aa.bb.cc;

import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;

public class MainActivity extends ActionBarActivity {

    private Toolbar mToolbar;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mToolbar = (Toolbar) findViewById(R.id.toolbar);

        setSupportActionBar(mToolbar);
        getSupportActionBar().setDisplayShowHomeEnabled(true);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}

我的 Activity_Main.xml :

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">

<LinearLayout
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentTop="true"
    android:orientation="vertical">

    <include
        android:id="@+id/toolbar"
        layout="@layout/toolbar" />
</LinearLayout>

我的toolbar.xml:

 <?xml version="1.0" encoding="utf-8"?>
<android.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:local="http://schemas.android.com/apk/res-auto"
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:minHeight="?attr/actionBarSize"
    android:background="?attr/colorPrimary"
    local:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
    local:popupTheme="@style/ThemeOverlay.AppCompat.Light" />

我的样式.xml:

<resources>

<!-- Base application theme. -->
<style name="MyMaterialTheme" parent="MyMaterialTheme.Base">

</style>

<style name="MyMaterialTheme.Base" parent="Base.Theme.AppCompat.Light.DarkActionBar">


    <item name="android:windowNoTitle">true</item>
    <item name="windowActionBar">false</item>
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>


   </style>
</resources>

LogCat:

    --------- beginning of crash
06-03 11:24:46.739    2065-2065/com.ij.indrajith.firstmaterialdesignapp E/AndroidRuntime﹕ FATAL EXCEPTION: main
    Process: com.ij.indrajith.firstmaterialdesignapp, PID: 2065
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.ij.indrajith.firstmaterialdesignapp/com.ij.indrajith.firstmaterialdesignapp.MainActivity}: java.lang.IllegalArgumentException: AppCompat does not support the current theme features
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
            at android.app.ActivityThread.access$800(ActivityThread.java:144)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5221)
            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:899)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
     Caused by: java.lang.IllegalArgumentException: AppCompat does not support the current theme features
            at android.support.v7.app.AppCompatDelegateImplV7.ensureSubDecor(AppCompatDelegateImplV7.java:360)
            at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:246)
            at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:106)
            at com.ij.indrajith.firstmaterialdesignapp.MainActivity.onCreate(MainActivity.java:16)
            at android.app.Activity.performCreate(Activity.java:5937)
            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
            at android.app.ActivityThread.access$800(ActivityThread.java:144)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5221)
            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:899)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)

通过查看 logcat,我尝试将父主题更改为许多其他主题,但没有用。

更新: 我对主题做了一些更改,现在错误跳转到:

 java.lang.RuntimeException: Unable to start activity ComponentInfo{com.ij.indrajith.firstmaterialdesignapp/com.ij.indrajith.firstmaterialdesignapp.MainActivity}: java.lang.ClassCastException: android.widget.Toolbar cannot be cast to android.support.v7.widget.Toolbar

【问题讨论】:

  • 您能提供来自 logcat 的错误代码吗?为此,请通过 ADB 连接设备,然后在 Android Studio 上运行项目。当应用程序崩溃时,将在 Studio 中创建日志。如果可以的话,用错误日志编辑帖子。
  • @AleksandarStefanović。我已经用 logcat 更新了帖子。请调查并帮助我找到解决方案
  • 如果您查看日志,它会显示“... AppCompat 不支持当前主题功能”。那就是你的错误所在。如果您正在为 21 SDK 级别进行设计,则无需使用 AppCompat 库,它们用于将 Material Design 实现到原生不支持它的 Android 版本中。
  • @AleksandarStefanović 是的,我也看到了,并尝试将基类主题更改为 app 'Theme.AppCompat.NoActionBar' 、 'Theme.AppCompat.Light' 等主题。但它没有帮助.您能否告诉我在同一方法中是否有任何其他方法或特定方法可以解决该问题?
  • @AleksandarStefanović 在这种情况下,如何照顾应用程序的向后兼容性?另外,当旧的 API 不支持材料设计时,如何设计它以支持 API 21,22 中的材料设计并且在旧 API 中也能正常工作?

标签: java android-studio android-activity android-toolbar android-appcompat


【解决方案1】:

在您使用的布局中:

android.widget.Toolbar

在您正在使用的活动中:

android.support.v7.widget.Toolbar

改变你的布局:

<android.support.v7.widget.Toolbar 
  .... />

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2014-01-03
    • 2014-01-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多