首页 > 解决方案 > 当我尝试在我的 secondactivity.kt 页面中使用我的 mainactivity 中的布局 ID 时,它返回为 null 并且应用程序崩溃

问题描述

我正在尝试制作一个测验应用程序,在主页上单击 + 按钮,它会将您带到一个新页面,您可以在其中输入测验的标题。单击检查按钮后,它将带您返回主页,并在此处创建按钮形式的新测验。但是,当我尝试将 id 用于我的 mainactivity 中的布局时,它返回为 null,并且当我单击检查按钮时应用程序崩溃。有谁知道我该如何解决这个问题?

第二个活动:

    package com.example.k_ari

import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.view.Gravity
import android.widget.Button
import android.widget.EditText
import android.widget.LinearLayout
import android.widget.Toast
import com.google.android.material.floatingactionbutton.FloatingActionButton

class Page2 : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_page2)

        val button = Button(this@Page2)
        button.layoutParams = LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT)

        val txtt = findViewById<EditText>(R.id.txt)
        val textmessage: String = txtt.text.toString()
        button.setText(textmessage)

        val message = "New quiz created"
        val toast1= Toast.makeText(applicationContext, message, Toast.LENGTH_LONG)
        toast1.setGravity(Gravity.CENTER, 0,0)
        
        val layout = findViewById<LinearLayout>(R.id.mainlayout)

        val btn = findViewById<FloatingActionButton>(R.id.floatingActionButton2)

        btn.setOnClickListener{

            layout.addView(button)

            toast1.show()

            val intent = Intent(this@Page2, MainActivity::class.java)
            startActivity(intent)
        }
    }
}

第二个活动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"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/secondlayout"
    android:orientation="vertical"
    tools:context=".Page2">

    <TextView
        android:id="@+id/textView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="#99141414"
        android:backgroundTint="#180030"
        android:gravity="center_horizontal"
        android:padding="20dp"
        android:text="Enter the title:"
        android:textAlignment="center"
        android:textColor="#DADADA"
        android:textSize="35sp"
        android:textStyle="bold"
        android:translationX="50dp"
        android:translationY="100dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.433"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.112" />

    <EditText
        android:id="@+id/txt"
        android:layout_width="361dp"
        android:layout_height="67dp"
        android:autofillHints="title"
        android:background="#99141414"
        android:backgroundTint="#180030"
        android:hint="title"
        android:inputType="text"
        android:padding="10dp"
        android:textColor="#DADADA"
        android:textColorHint="#9ADCDCDC"
        android:textSize="28sp"
        android:translationX="25dp"
        android:translationY="170dp"
        app:layout_constraintBottom_toTopOf="@+id/textView"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <com.google.android.material.floatingactionbutton.FloatingActionButton
        android:id="@+id/floatingActionButton2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:clickable="true"
        android:contentDescription="@string/todo"
        android:focusable="true"
        android:translationX="300dp"
        android:translationY="400dp"
        app:backgroundTint="#180030"
        app:layout_constraintBottom_toTopOf="@+id/textView"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.9"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />


</LinearLayout>

主要活动:

    package com.example.k_ari

import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import com.google.android.material.floatingactionbutton.FloatingActionButton

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val floatingActionButton = findViewById<FloatingActionButton>(R.id.btn)

        floatingActionButton.setOnClickListener{
            val intent = Intent(this, Page2::class.java)

            startActivity(intent)
        }
    }
}

主要活动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"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/mainlayout"
    android:orientation="vertical"
    android:layout_gravity="center"
    tools:context=".MainActivity">

    <com.google.android.material.floatingactionbutton.FloatingActionButton
        android:id="@+id/btn"
        android:layout_width="wrap_content"
        android:layout_height="56dp"
        android:backgroundTint="#250A43"
        android:backgroundTintMode="add"
        android:clickable="true"
        android:contentDescription="@string/todo"
        android:tint="#250A43"
        android:translationX="280dp"
        android:translationY="580dp"
        app:backgroundTint="#250A43"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.56"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:rippleColor="#FFFFFF"
        app:srcCompat="@android:drawable/ic_input_add"
        android:focusable="true" />
</LinearLayout>

日志猫:

2020-12-23 15:32:03.599 1474-1474/com.example.k_ari E/Toast: setGravity() 不应该在文本 toasts 上调用,这些值不会被使用 2020-12-23 15:32 :05.482 1474-1474/com.example.k_ari E/AndroidRuntime:致命异常:主进程:com.example.k_ari,PID:1474 java.lang.NullPointerException:尝试调用虚拟方法'void android.widget.LinearLayout.addView (android.view.View)' 在 com.example.k_ari.Page2$onCreate$1.onClick(Page2.kt:35) 在 android.view.View.performClick(View.java:8178) 在 com.example.k_ari.Page2$onCreate$1.onClick(Page2.kt:35) 在空对象引用.view.View.performClickInternal(View.java:8147) at android.view.View.access$3700(View.java:888) at android.view.View$PerformClick.run(View.java:30233) at android.os .Handler.handleCallback(Handler.java:938) 在 android.os.Handler.dispatchMessage(Handler.java:99) 在 android.os.Looper.loop(Looper.java:246) 在 com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:第596章)在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1130)

标签: androidkotlin

解决方案


您不能View从不Activity持有它的地方访问 a。

要处理这样的活动之间的数据,您应该阅读ViewModel和/或SharedPreferences

https://developer.android.com/topic/libraries/architecture/viewmodel

https://developer.android.com/reference/android/content/SharedPreferences


推荐阅读