Невозможно отобразить значение из предыдущего действия

При отображении значения в textview на втором занятии получаю ошибку как

объявление ожидающего члена

Это мой код для другой деятельности:

   package com.example.trial.sudoku_solver
import android.app.AlertDialog
import android.content.Intent
import android.graphics.Bitmap
import android.media.MediaScannerConnection
import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import android.os.Environment
import android.provider.MediaStore
import android.text.Editable
import android.util.Log
import android.view.View
import android.widget.*
import com.example.trial.sudoku_solver.R
import kotlinx.android.synthetic.main.activity_main.view.*
import java.io.ByteArrayOutputStream
import java.io.File
import java.io.FileOutputStream
import java.io.IOException
import java.util.*
import kotlinx.android.synthetic.main.activity_main.*
import org.w3c.dom.Text

class AnotherActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_another)
    }


    var a: String = intent.getStringExtra("text")
    val text1: TextView = findViewById(R.id.textview) as TextView
    text1.text = intent.getStringExtra("text")

}

Это мой частичный код для функции в MainActivity

private fun clickText() {
    val text1: EditText = findViewById(R.id.editText)
    if (text1 != null) {
        //Toast.makeText(this, text1.text, Toast.LENGTH_LONG).show()
        var text1 = text1.editText.toString()
        val intent = Intent(this, AnotherActivity::class.java)
        intent.putExtra("text",text1)
        startActivity(intent);
    }
}

4 ответа

Решение

8 Вам нужно позвонить intent, findViewById а потом setText после звонка setContentView:

class AnotherActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_another)

        var a: String = intent.getStringExtra("text")
        val text1: TextView = findViewById(R.id.textview) as TextView
        text1.text = intent.getStringExtra("text")
    }
}

Самый простой способ сделать это:

Intent intent = new Intent(getBaseContext(), Activity2.class);
intent.putExtra("ID", sId);
startActivity(intent);

Доступ к этому намерению при следующей деятельности

String sId= getIntent().getStringExtra("ID");

Надеюсь, что это поможет вам

Вам нужно добавить этот кусок кода внутри блока метода onCreate

Вы должны добавить свои исполняемые операторы внутри методов.

Так что код будет выглядеть так:

 override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_another)

        // add these statement inside onCreate block
        var a: String = intent.getStringExtra("text")
        val text1: TextView = findViewById(R.id.textview) as TextView
        text1.text = intent.getStringExtra("text")
    }

Threre не метод settext в Activity, Вы должны установить текстовую строку в TextView как это:

var a: String = intent.getStringExtra("text")
val text1 = findViewById(R.id.textview) as TextView
text1.text = a

Кроме того, когда вы пишете код на kotlin, нет необходимости использовать findViewById в действиях. Из-за синтетических свойств, представления доступны через их идентификаторы из XML-файла. Итак, ваши три строки кода можно заменить, как показано ниже:

textview.text = intent.getStringExtra("text")

Также измените блок кода в MainActivity на:

private fun clickText() {
    val editText1: EditText = findViewById(R.id.editText)
    if (editText1 != null) {
        //Toast.makeText(this, text1.text, Toast.LENGTH_LONG).show()
        var text1 = editText1.text.toString()
        val intent = Intent(this, AnotherActivity::class.java)
        intent.putExtra("text", text1)
        startActivity(intent);
    }
}
Другие вопросы по тегам