从 Intent putExtra 设置数据不起作用

Setting data from Intent putExtra not working

我正在尝试将 Intent putExtra 中的数据从一个 Activity 设置为另一个 Activity,但是当数据访问更新时,显示而不是显示输入数据,是一个带有 id 的代码的字符串。 数据在我的 recyclerView 上正常显示。我使用带有 SQLite 的数据库。 我尝试了很多东西,但没有任何效果。 谁能帮帮我?

我的适配器:

package com.myapplication.umdocededaisy;

import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.LinearLayout;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;
import java.util.List;

public class CustomAdapter extends RecyclerView.Adapter<CustomAdapter.MyViewHolder> {

    private Context context;
    private Activity activity;
    private RecyclerView recyclerView;

    CustomAdapter(Context context, Activity activity, List<MateriaPrima> listaProdutos, RecyclerView recyclerView) {
        this.context = context;
        this.activity = activity;
        this.listaProdutos = listaProdutos;
        this.recyclerView = recyclerView;
    }

    List<MateriaPrima> listaProdutos;

    @NonNull
    @Override
    public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        LayoutInflater inflater = LayoutInflater.from(context);
        View view = inflater.inflate(R.layout.ingredientes, parent, false);
        return new MyViewHolder(view);
    }

    @Override
    public void onBindViewHolder(@NonNull CustomAdapter.MyViewHolder holder, int position) {
        holder.txtId.setText(String.valueOf(listaProdutos.get(position).getCodigo()));
        holder.txtProduto.setText(String.valueOf(listaProdutos.get(position).getProduto()));
        holder.txtValor.setText(String.valueOf(listaProdutos.get(position).getValor()));
        holder.txtQtd.setText(String.valueOf(listaProdutos.get(position).getQuantidade()));
        holder.txtTipo.setText(String.valueOf(listaProdutos.get(position).getTipo()));
        holder.mainLayout.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent(context,UpdateActivity.class);
                intent.putExtra("codigo", listaProdutos.get(position).toString());
                intent.putExtra("produto", listaProdutos.get(position).toString());
                intent.putExtra("valor", String.valueOf(listaProdutos.get(position)));
                intent.putExtra("quantidade", String.valueOf(listaProdutos.get(position)));
                intent.putExtra("tipo", String.valueOf(listaProdutos.get(position)));
                context.startActivity(intent);
            }
        });

    }

    @Override
    public int getItemCount() {
        return listaProdutos.size();
    }

    public class MyViewHolder extends RecyclerView.ViewHolder {
        TextView txtId, txtProduto, txtValor, txtQtd, txtTipo;
        LinearLayout mainLayout;

        public MyViewHolder(@NonNull View itemView) {
            super(itemView);
            txtId = itemView.findViewById(R.id.txtId);
            txtProduto = itemView.findViewById(R.id.txtProduto);
            txtValor = itemView.findViewById(R.id.txtValor);
            txtQtd = itemView.findViewById(R.id.txtQtd);
            txtTipo = itemView.findViewById(R.id.txtTipo);
            mainLayout = itemView.findViewById(R.id.mainLayout);
        }
    }
}

更新Activity:

package com.myapplication.umdocededaisy;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class UpdateActivity extends AppCompatActivity {

    EditText editCodigo2, editProduto2, editValor2, editQuantidade2, editTipo2;
    Button btnUpdate;
    String codigo, produto, valor, quantidade, tipo;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_update);

        //Declarações objetos:
        editCodigo2 = findViewById(R.id.editCodigo2);
        editProduto2 = findViewById(R.id.editProduto2);
        editValor2 = findViewById(R.id.editValor2);
        editQuantidade2 = findViewById(R.id.editQuantidade2);
        editTipo2 = findViewById(R.id.editTipo2);
        btnUpdate = findViewById(R.id.btnUpdate);

        getAndSetIntentData();

        btnUpdate.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

            }
        });

    }

    void getAndSetIntentData() {
        if (getIntent().hasExtra("codigo") && getIntent().hasExtra("produto") && getIntent().hasExtra("valor") &&
                getIntent().hasExtra("quantidade") && getIntent().hasExtra("tipo")){
            //Getting data:
            codigo = getIntent().getStringExtra("codigo");
            produto = getIntent().getStringExtra("produto");
            valor = getIntent().getStringExtra("valor");
            quantidade = getIntent().getStringExtra("quantidade");
            tipo = getIntent().getStringExtra("tipo");

            //Setting data:
            editCodigo2.setText(codigo);
            editProduto2.setText(produto);
            editValor2.setText(valor);
            editQuantidade2.setText(quantidade);
            editTipo2.setText(tipo);

        }else{
            Toast.makeText(this, R.string.strData0, Toast.LENGTH_SHORT).show();
        }
    }
}

我的数据库:

package com.myapplication.umdocededaisy;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.widget.Toast;

import java.util.ArrayList;
import java.util.List;

public class MyDatabase extends SQLiteOpenHelper {

    List<MateriaPrima> listaProduto = new ArrayList<>();

    private final Context context;
    private static final String DATABASE_NAME = "BancoDoceDaisy.db";
    private static final int DATABASE_VERSION = 3;

    //Estruturas das Tabelas do banco de dados:

    //Tabela dos produtos - materia prima:
    private static final String TABLE_PRODUTO = "materia_prima";
    private static final String COLUMN_CODIGO = "codigo";
    private static final String COLUMN_PRODUTO = "produto";
    private static final String COLUMN_VALOR = "valor";
    private static final String COLUMN_QTD = "quantidade";
    private static final String COLUMN_TIPO = "tipo";
    
    public MyDatabase(Context context) {
        super(context, DATABASE_NAME,null, DATABASE_VERSION);
        this.context = context;
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        String query = "CREATE TABLE "+ TABLE_PRODUTO +
                " (" + COLUMN_CODIGO + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
                COLUMN_PRODUTO + " TEXT, " +
                COLUMN_VALOR + " FLOAT, " +
                COLUMN_QTD + " FLOAT, " +
                COLUMN_TIPO + " TEXT); ";
        db.execSQL(query);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        db.execSQL("DROP TABLE IF EXISTS " + "materia_prima");
        onCreate(db);
    }

    void addMateriaPrima(MateriaPrima materiaPrima) {
        SQLiteDatabase db = this.getWritableDatabase();
        ContentValues cv = new ContentValues();

        cv.put(COLUMN_PRODUTO, materiaPrima.getProduto());
        cv.put(COLUMN_VALOR, materiaPrima.getValor());
        cv.put(COLUMN_QTD, materiaPrima.getQuantidade());
        cv.put(COLUMN_TIPO, materiaPrima.getTipo());

        long result = db.insert(TABLE_PRODUTO, null, cv);
        if (result == -1) {
            Toast.makeText(context, R.string.strFailed, Toast.LENGTH_SHORT).show();
        }else {
            Toast.makeText(context, R.string.strAddSucess, Toast.LENGTH_SHORT).show();
        }
        db.close();
    }

    Cursor readAllData(){
        String query = "SELECT * FROM " + TABLE_PRODUTO;
        SQLiteDatabase db = this.getReadableDatabase();

        Cursor cursor = null;
        if(db != null){
            cursor = db.rawQuery(query,null);
        }
        return cursor;
    }

    public List<MateriaPrima> buscaProduto() {
        String columns[] = {COLUMN_CODIGO, COLUMN_PRODUTO, COLUMN_VALOR, COLUMN_QTD, COLUMN_TIPO};
        SQLiteDatabase db = getReadableDatabase();
        Cursor cursor = db.query(TABLE_PRODUTO, columns, null, null, null,null, null);

        while (cursor.moveToNext()) {
            int index1 = cursor.getColumnIndex(COLUMN_CODIGO);
            int codigo = cursor.getInt(index1);
            int index2 = cursor.getColumnIndex(COLUMN_PRODUTO);
            String produto = cursor.getString(index2);
            int index3 = cursor.getColumnIndex(COLUMN_VALOR);
            float valor = cursor.getFloat(index3);
            int index4 = cursor.getColumnIndex(COLUMN_QTD);
            float quantidade = cursor.getFloat(index4);
            int index5 = cursor.getColumnIndex(COLUMN_TIPO);
            String tipo = cursor.getString(index5);
            MateriaPrima produtos = new MateriaPrima(codigo, produto, valor, quantidade, tipo);
            listaProduto.add(produtos);
        }
        return listaProduto;
    }

}

在每个

intent.putExtra("####", listaProdutos.get(position).toString());

您在转换 .toString() 之前没有调用值 get###。您的意图应如下所示:

Intent intent = new Intent(context,UpdateActivity.class);
                intent.putExtra("codigo", listaProdutos.get(position).getCodigo().toString());
                intent.putExtra("produto", listaProdutos.get(position).getProduto().toString());
                intent.putExtra("valor", String.valueOf(listaProdutos.get(position).getValor()));
                intent.putExtra("quantidade", String.valueOf(listaProdutos.get(position).getQuantidade()));
                intent.putExtra("tipo", String.valueOf(listaProdutos.get(position).getTipo()));
                context.startActivity(intent);