android - XML 显示白屏
问题描述
我正在尝试在 Kotlin 中为我的应用程序登录并创建帐户页面。问题是我在 AndroidManifest 上添加了创建帐户页面作为打开应用程序时的第一页,它只显示白屏。我注意到在 Android Studio 中有一个设计选项卡,页面显示完全符合我的要求。你能帮助我吗?
这是我的 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"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/gradient_background">
<TextView
android:id="@+id/register"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/create_account"
android:textSize="30sp"
android:textColor="@color/white"
android:gravity="center"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.498"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.132" />
<androidx.cardview.widget.CardView
android:id="@+id/myCardView"
android:layout_width="393dp"
android:layout_height="451dp"
android:layout_gravity="center"
android:layout_margin="4dp"
app:cardBackgroundColor="@color/cardsColor"
app:cardCornerRadius="12dp"
app:cardElevation="0dp"
app:cardUseCompatPadding="true"
app:contentPadding="12sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<LinearLayout
android:layout_width="361dp"
android:layout_height="426dp"
android:orientation="vertical"
android:padding="16dp"
android:paddingStart="16dp"
android:paddingLeft="16dp"
android:paddingTop="16dp"
android:paddingEnd="16dp"
android:paddingRight="16dp"
android:paddingBottom="16dp"
android:weightSum="5.5">
<EditText
android:id="@+id/email"
android:layout_width="match_parent"
android:layout_height="70dp"
android:layout_marginBottom="10dp"
android:background="@drawable/edit_text_stroke"
android:gravity="center"
android:hint="@string/email"
android:minLines="2"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.213"
android:importantForAutofill="no" />
<EditText
android:id="@+id/password"
android:layout_width="match_parent"
android:layout_height="70dp"
android:layout_marginBottom="10dp"
android:background="@drawable/edit_text_stroke"
android:gravity="center"
android:hint="@string/password"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.3"
android:importantForAutofill="no" />
</LinearLayout>
</androidx.cardview.widget.CardView>
<Button
android:id="@+id/register_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:background="@drawable/button_round_corners"
android:gravity="center"
android:padding="12dp"
android:text="@string/create_account"
android:textColor="@color/white"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.164"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/myCardView"
app:layout_constraintVertical_bias="0.535" />
<Button
android:id="@+id/login_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/button_round_corners"
android:padding="12dp"
android:text="@string/login"
android:textColor="@color/white"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.81"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/myCardView"
app:layout_constraintVertical_bias="0.535" />
</androidx.constraintlayout.widget.ConstraintLayout>
和我的科特林课
package projeto.a43796.dashboard
import android.content.Intent
import android.os.Bundle
import android.os.PersistableBundle
import android.text.TextUtils
import android.widget.Button
import android.widget.EditText
import android.widget.Toast
import androidx.appcompat.app.AppCompatActivity
import com.google.firebase.auth.FirebaseAuth
import com.google.firebase.auth.FirebaseUser
import kotlinx.android.synthetic.main.activity_create_account.*
class CreateAccount : AppCompatActivity() {
lateinit var registerButton: Button
lateinit var email: EditText
lateinit var password: EditText
override fun onCreate(savedInstanceState: Bundle?, persistentState: PersistableBundle?) {
super.onCreate(savedInstanceState, persistentState)
setContentView(R.layout.activity_create_account)
registerButton = findViewById(R.id.register_button)
email = findViewById(R.id.email)
password = findViewById(R.id.password)
registerButton.setOnClickListener(){
when{
TextUtils.isEmpty(email.text.toString().trim{it <= ' '}) -> {
Toast.makeText(
this@CreateAccount,
"Please enter your e-mail",
Toast.LENGTH_SHORT
).show()
}
TextUtils.isEmpty(password.text.toString().trim{it <= ' '}) -> {
Toast.makeText(
this@CreateAccount,
"Please enter your password",
Toast.LENGTH_SHORT
).show()
}
else -> {
val email: String = email.text.toString().trim{it <= ' '}
val passord: String = password.text.toString().trim{it <= ' '}
FirebaseAuth.getInstance().createUserWithEmailAndPassword(email, passord)
.addOnCompleteListener { task ->
if (task.isSuccessful) {
val firebaseUser: FirebaseUser = task.result!!.user!!
Toast.makeText(
this@CreateAccount,
"Account Created",
Toast.LENGTH_SHORT
).show()
val intent =
Intent(this@CreateAccount, Dashboard::class.java)
intent.flags = Intent.FLAG_ACTIVITY_NEW_TASK or Intent.FLAG_ACTIVITY_CLEAR_TASK
intent.putExtra("user_id", firebaseUser.uid)
intent.putExtra("email_user", email)
startActivity(intent)
finish()
}
else{
Toast.makeText(
this@CreateAccount,
task.exception!!.message.toString(),
Toast.LENGTH_SHORT
).show()
}
}
}
}
}
}
}
解决方案
推荐阅读
- django - 如何将 datepicker 和 timepicker 添加到 Django forms.SplitDateTimeField?
- android - 调用 startActivityForResult 后检测进程死亡
- database - 聚合。我想计算 mongo 中的记录,然后我想将该计数乘以不同集合中的字段
- reactjs - 在 API 响应中映射数组值以进行条件检查
- python - 模块导入类函数
- android - 在没有生命周期所有者的情况下使用 LiveData
- .htaccess - htaccess 路由与一个域和几个文件夹
- blockchain - 同一笔交易的不同gas量
- c# - 如何用指针作为参数在 C# 中包装 C++ DLL?
- c# - 在 IHostedService 中应该如何使用取消令牌?