【问题标题】:app is not opening next activity after splash screen and crashing启动屏幕和崩溃后应用程序未打开下一个活动
【发布时间】:2022-01-11 18:32:02
【问题描述】:

我正在为一个业余项目制作一个应用程序,而且我自己对 kotlin 编程还很陌生,我不知道我所面临的问题的最佳解决方案。当我运行我的应用程序时,会出现启动屏幕,但不会进入登录页面,而是关闭应用程序本身。令人惊讶的是,它没有给出任何错误并自行关闭 gradle。代码如下。感谢您提前提供帮助。

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout 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:background="@drawable/background"
        android:padding="32dp"
        tools:context=".MainActivity">
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_margin="10dp"
            android:orientation="vertical">
    
            <EditText
                android:id="@+id/username_et"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginTop="110dp"
                android:layout_marginBottom="50dp"
                android:hint="@string/username_in"/>
    
            <EditText
                android:id="@+id/password_et"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:hint="@string/password_in"
                android:inputType="textPassword" />
    
            <com.google.android.material.button.MaterialButton
                android:id="@+id/login_btn"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center_horizontal"
                android:layout_marginTop="50dp"
                android:layout_marginBottom="50dp"
                android:backgroundTint="@color/black"
                android:padding="12dp"
                android:text="@string/login_in"
                android:textSize="20sp"
                android:textAllCaps="false"
                android:textColor="@color/white"
                android:textStyle="bold"
                app:cornerRadius="10dp"/>
        </LinearLayout>
    
        <TextView
            android:id="@+id/app_heading"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/welcome"
            android:textAppearance="@style/TextAppearance.AppCompat.Headline"
            android:textColor="@color/black"
            android:textSize="40sp"
            android:textStyle="bold" />
    
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:layout_marginTop="580dp"
            android:layout_marginBottom="580dp"
            android:text="@string/learnr"
            android:textAppearance="@style/TextAppearance.AppCompat.Headline"
            android:textColor="@color/bright_yellow"
            android:textSize="40sp"
            android:textStyle="bold" />
    
    </RelativeLayout>

MainActivity.kt:

package com.example.learnr

import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.widget.Button
import android.widget.EditText
import android.widget.Toast
import android.widget.Toast.makeText

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        supportActionBar?.hide()
        makeText(this, "Welcome", Toast.LENGTH_SHORT).show()

        val userName = findViewById<EditText>(R.id.username_et)
        val passWord = findViewById<EditText>(R.id.password_et)
        val loginButton = findViewById<Button>(R.id.login_btn)

        loginButton.setOnClickListener {
            val status=if (userName.text.toString() == "DevangSahani"
                && passWord.text.toString() == "devangs"
            ) "Logged in Successfully" else "Login failed, please try again"
            makeText(this, status, Toast.LENGTH_SHORT).show()
        }
    }
}

activity_splash_screen.xml:

<?xml version="1.0" encoding="utf-8"?>
    <androidx.constraintlayout.widget.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"
        android:background="@color/black"
        tools:context=".SplashScreenActivity">
    
        <TextView
            android:id="@+id/splash_heading"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/learnr"
            android:textAppearance="@style/TextAppearance.AppCompat.Headline"
            android:textColor="@color/bright_yellow"
            android:textSize="60sp"
            android:textStyle="bold"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintHorizontal_bias="0.497"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintVertical_bias="0.499" />
    
    </androidx.constraintlayout.widget.ConstraintLayout>

SplashScreenActivity.kt:

package com.example.learnr

import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.os.Handler

class SplashScreenActivity : AppCompatActivity() {

    lateinit var handler: Handler
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_splash_screen)
        supportActionBar?.hide()

        handler = Handler()
        handler.postDelayed({

            val intent = Intent(this,MainActivity::class.java)
            startActivity(intent)
            finish()

        }, 3000)

    }
}

AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.learnr">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/Theme.Learnr">
        <activity
            android:name=".MainActivity"
            android:exported="true"
            android:theme="@style/DemoThemeMain"/>
        <activity
            android:name=".SplashScreenActivity"
            android:exported="true"
            android:theme="@style/DemoTheme">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

strings.xml:

<resources>
<string name="app_name">Learnr</string>
<string name="welcome">Welcome.</string>
<string name="learnr">Learnr.™</string>
<string name="username">Username:</string>
<string name="password">Password:</string>
<string name="username_in">Username</string>
<string name="password_in">Password</string>
<string name="login_in">Login</string>

<!-- Defined a new style with three items of color. -->
<style name="DemoTheme" parent="Theme.AppCompat.Light.NoActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/black</item>

    <!-- Defining that new color in ColorPrimaryDark -->
    <item name="colorPrimaryDark">@color/black</item>
    <item name="colorAccent">@color/black</item>
</style>

<!-- Defined a new style with three items of color. -->
<style name="DemoThemeMain" parent="Theme.AppCompat.Light.NoActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/bright_yellow</item>

    <!-- Defining that new color in ColorPrimaryDark -->
    <item name="colorPrimaryDark">@color/bright_yellow</item>
    <item name="colorAccent">@color/bright_yellow</item>
</style>

logcat:

2022-01-11 12:18:20.600 11350-11350/com.example.learnr E/AndroidRuntime: 致命异常: main 进程:com.example.learnr,PID:11350 java.lang.RuntimeException:无法启动活动 ComponentInfo{com.example.learnr/com.example.learnr.MainActivity}: android.view.InflateException:二进制 XML 文件第 46 行 com.example.learnr:layout/activity_main:二进制 XML 文件第 46 行 com.example.learnr:layout/activity_main: 错误膨胀类 com.google.android.material.button.MaterialButton 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3449) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3601) 在 android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85) 在 android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135) 在 android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066) 在 android.os.Handler.dispatchMessage(Handler.java:106) 在 android.os.Looper.loop(Looper.java:223) 在 android.app.ActivityThread.main(ActivityThread.java:7656) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947) 原因:android.view.InflateException:com.example.learnr:layout/activity_main 中的二进制 XML 文件第 46 行:com.example.learnr:layout/activity_main 中的二进制 XML 文件第 46 行:膨胀类 com.google 时出错。 android.material.button.MaterialButton 引起:android.view.InflateException:com.example.learnr 中的二进制 XML 文件第 46 行:layout/activity_main:膨胀类 com.google.android.material.button.MaterialButton 时出错 引起:java.lang.reflect.InvocationTargetException 在 java.lang.reflect.Constructor.newInstance0(本机方法) 在 java.lang.reflect.Constructor.newInstance(Constructor.java:343) 在 android.view.LayoutInflater.createView(LayoutInflater.java:852) 在 android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:1004) 在 android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:959) 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:1121) 在 android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1082) 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:1124) 在 android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1082) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:680) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:532) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:479) 在 androidx.appcompat.app.AppCompatDelegateImpl.setContentView(AppCompatDelegateImpl.java:706) 在 androidx.appcompat.app.AppCompatActivity.setContentView(AppCompatActivity.java:195) 在 com.example.learnr.MainActivity.onCreate(MainActivity.kt:13) 在 android.app.Activity.performCreate(Activity.java:8000) 在 android.app.Activity.performCreate(Activity.java:7984) 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1309) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3422) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3601) 在 android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85) 在 android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135) 在 android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066) 在 android.os.Handler.dispatchMessage(Handler.java:106) 在 android.os.Looper.loop(Looper.java:223) 在 android.app.ActivityThread.main(ActivityThread.java:7656) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947) 2022-01-11 12:18:20.601 11350-11350/com.example.learnr E/AndroidRuntime: 引起: java.lang.IllegalArgumentException: The 此组件的样式要求您的应用主题为 Theme.MaterialComponents(或后代)。 在 com.google.android.material.internal.ThemeEnforcement.checkTheme(ThemeEnforcement.java:243) 在 com.google.android.material.internal.ThemeEnforcement.checkMaterialTheme(ThemeEnforcement.java:217) 在 com.google.android.material.internal.ThemeEnforcement.checkCompatibleTheme(ThemeEnforcement.java:145) 在 com.google.android.material.internal.ThemeEnforcement.obtainStyledAttributes(ThemeEnforcement.java:76) 在 com.google.android.material.button.MaterialButton.(MaterialButton.java:229) 在 com.google.android.material.button.MaterialButton.(MaterialButton.java:220) ... 30 更多 2022-01-11 12:18:20.660 11350-11350/com.example.learnr I/Process:发送信号。 PID:11350 SIG:9

【问题讨论】:

  • 我将您的代码复制到一个新项目并运行它,它运行良好 - 不知道问题是什么,但如果您想要有意义的话,您需要将其缩小到可重现的案例和具体问题答案。
  • 请发布日志。
  • 我没有发现任何问题
  • 我找不到任何问题。

标签: android kotlin


【解决方案1】:

您好,请检查您正在使用的主题。您使用了 materialButton 和主题应该是材料主题,否则它会崩溃。如果您使用正确的材质主题并且想要隐藏或者您不需要操作栏,只需在样式中使用 NoActionBar 主题并将其应用到 main。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2018-11-27
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-05-06
    • 1970-01-01
    • 2019-06-02
    • 1970-01-01
    相关资源
    最近更新 更多