为什么我的Android Studio应用程序无法在Android设备上运行?

时间:2019-06-19 12:22:45

标签: java android grid-layout

我已经在Android Studio 3.0.1中构建了Connect 3游戏,但是当我尝试在Samsung Android设备上运行它时,它无法运行并显示消息Unfortunately, Connect 3 Game has stopped.

Android Studio中的Logcat窗口显示很多消息,例如;

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.stephenlearmonth.connect3game/com.example.stephenlearmonth.connect3game.MainActivity}: android.view.InflateException: Binary XML file line #0: Error inflating class android.widget.GridLayout

我已尝试在import android.widget.GridLayout;文件中将android.support.v7.widget.GridLayout;替换为MainActivity.java,但收到错误消息Cannot resolve symbol 'GridLayout'.

我已将我的minSdkVersion文件中的gradle.build设置为19

MainActivity.java的启动

package com.example.stephenlearmonth.connect3game;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.support.v7.widget.GridLayout;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;

build.gradle

apply plugin: 'com.android.application'

android {
    compileSdkVersion 26
    defaultConfig {
        applicationId "com.example.stephenlearmonth.connect3game"
        minSdkVersion 19
        targetSdkVersion 26
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'com.android.support:appcompat-v7:26.1.0'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
}

activity_main.xml的开始

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout 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"
    tools:context="com.example.stephenlearmonth.connect3game.MainActivity">

    <GridLayout
        android:id="@+id/gridLayout"
        android:layout_width="368dp"
        android:layout_height="368dp"
        android:layout_marginBottom="8dp"
        android:layout_marginEnd="8dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="64dp"
        android:background="@drawable/board"
        android:columnCount="3"
        android:rowCount="3"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent">

Android手机显示消息Unfortunately, Connect 3 Game has stopped.

Android Studio 3.0.1的Logcat窗口报告以下输出;

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.stephenlearmonth.connect3game/com.example.stephenlearmonth.connect3game.MainActivity}: android.view.InflateException: Binary XML file line #0: Error inflating class android.widget.GridLayout
   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3150)
   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3260)
   at android.app.ActivityThread.access$1000(ActivityThread.java:218)
   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1734)
   at android.os.Handler.dispatchMessage(Handler.java:102)
   at android.os.Looper.loop(Looper.java:145)
   at android.app.ActivityThread.main(ActivityThread.java:6934)
   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:1404)
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1199)
Caused by: android.view.InflateException: Binary XML file line #0: Error inflating class android.widget.GridLayout
   at android.view.LayoutInflater.createView(LayoutInflater.java:640)
   at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:55)
   at android.view.LayoutInflater.onCreateView(LayoutInflater.java:689)
   at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:748)
   at android.view.LayoutInflater.rInflate(LayoutInflater.java:813)
   at android.view.LayoutInflater.inflate(LayoutInflater.java:511)
   at android.view.LayoutInflater.inflate(LayoutInflater.java:415)
   at android.view.LayoutInflater.inflate(LayoutInflater.java:366)
   at android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:287)
   at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:139)
   at com.example.stephenlearmonth.connect3game.MainActivity.onCreate(MainActivity.java:147)
   at android.app.Activity.performCreate(Activity.java:6609)
   at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1134)
   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3103)
   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3260) 
   at android.app.ActivityThread.access$1000(ActivityThread.java:218) 
   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1734) 
   at android.os.Handler.dispatchMessage(Handler.java:102) 
   at android.os.Looper.loop(Looper.java:145) 
   at android.app.ActivityThread.main(ActivityThread.java:6934) 
   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:1404) 
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1199) 
Caused by: java.lang.reflect.InvocationTargetException
   at java.lang.reflect.Constructor.newInstance(Native Method)
   at java.lang.reflect.Constructor.newInstance(Constructor.java:288)
   at android.view.LayoutInflater.createView(LayoutInflater.java:614)
   at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:55) 
   at android.view.LayoutInflater.onCreateView(LayoutInflater.java:689) 
   at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:748) 
   at android.view.LayoutInflater.rInflate(LayoutInflater.java:813) 
   at android.view.LayoutInflater.inflate(LayoutInflater.java:511) 
   at android.view.LayoutInflater.inflate(LayoutInflater.java:415) 
   at android.view.LayoutInflater.inflate(LayoutInflater.java:366) 
   at android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:287) 
   at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:139) 
   at com.example.stephenlearmonth.connect3game.MainActivity.onCreate(MainActivity.java:147) 
   at android.app.Activity.performCreate(Activity.java:6609) 
   at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1134) 
   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3103) 
   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3260) 
   at android.app.ActivityThread.access$1000(ActivityThread.java:218) 
   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1734) 
   at android.os.Handler.dispatchMessage(Handler.java:102) 
   at android.os.Looper.loop(Looper.java:145) 
   at android.app.ActivityThread.main(ActivityThread.java:6934) 
   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:1404) 
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1199) 
Caused by: android.content.res.Resources$NotFoundException: Resource "com.example.stephenlearmonth.connect3game:drawable/board" (7f060054)  is not a Drawable (color or path): TypedValue{t=0x1/d=0x7f060054 a=-1 r=0x7f060054}
   at android.content.res.Resources.loadDrawableForCookie(Resources.java:4017)
   at android.content.res.Resources.loadDrawable(Resources.java:3929)
   at android.content.res.Resources.loadDrawable(Resources.java:3779)
   at android.content.res.TypedArray.getDrawable(TypedArray.java:776)
   at android.view.View.<init>(View.java:4001)
   at android.view.ViewGroup.<init>(ViewGroup.java:513)
   at android.widget.GridLayout.<init>(GridLayout.java:285)
   at android.widget.GridLayout.<init>(GridLayout.java:281)
   at android.widget.GridLayout.<init>(GridLayout.java:277)
   at java.lang.reflect.Constructor.newInstance(Native Method) 
   at java.lang.reflect.Constructor.newInstance(Constructor.java:288) 
   at android.view.LayoutInflater.createView(LayoutInflater.java:614) 
   at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:55) 
   at android.view.LayoutInflater.onCreateView(LayoutInflater.java:689) 
   at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:748) 
   at android.view.LayoutInflater.rInflate(LayoutInflater.java:813) 
   at android.view.LayoutInflater.inflate(LayoutInflater.java:511) 
   at android.view.LayoutInflater.inflate(LayoutInflater.java:415) 
   at android.view.LayoutInflater.inflate(LayoutInflater.java:366) 
   at android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:287) 
   at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:139) 
   at com.example.stephenlearmonth.connect3game.MainActivity.onCreate(MainActivity.java:147) 
   at android.app.Activity.performCreate(Activity.java:6609) 
   at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1134) 
   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3103) 
   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3260) 
   at android.app.ActivityThread.access$1000(ActivityThread.java:218) 
   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1734) 
   at android.os.Handler.dispatchMessage(Handler.java:102) 
   at android.os.Looper.loop(Looper.java:145) 
   at android.app.ActivityThread.main(ActivityThread.java:6934) 
   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:1404) 
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1199)

1 个答案:

答案 0 :(得分:0)

我将板子和计数器图像资源从drawable-v24文件夹移到了drawable文件夹中。