>

Fórum

Fórum da RL System, voltado para analistas, programadores etc. Tudo sobre linguagem de programação e desenvolvimento Full Stack: Banco de Dados, Android, C#, Java, .NET, PHP, Node, Javascript, TypeScript, Front, HTML e muito mais.



Erro no botão Salvar


Caused by: java.lang.NullPointerException



9 Respostas


Ola Carlos,

tente mostrar o seu codigo..




package br.com.carlosaguiar.vendas;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteCursor;
import android.database.sqlite.SQLiteDatabase;
import android.location.Criteria;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.view.View;
import android.widget.SimpleCursorAdapter;
import android.widget.Spinner;
import android.widget.Toast;

public class NovaVendaActivity extends ActionBarActivity implements LocationListener{

private double la;
private double lo;

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

Spinner spProdutos = (Spinner) findViewById(R.id.spProdutos);

SQLiteDatabase db = openOrCreateDatabase("vendas.bd", Context.MODE_PRIVATE, null);

Cursor cursor = db.rawQuery("SELECT * FROM produtos ORDER BY nome ASC", null);

String[] from = {"_id", "nome", "preco"};
int[] to = {R.id.txvID, R.id.txvNome, R.id.txvPreco};

SimpleCursorAdapter add = new SimpleCursorAdapter(getBaseContext(), R.layout.spinner, cursor, from, to, 1);

spProdutos.setAdapter(add);

db.close();

}

public void Click_Salvar(View v){

LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
Criteria criteria = new Criteria();
String provider = locationManager.getBestProvider(criteria, false);
Location location = locationManager.getLastKnownLocation(provider);
la = location.getLatitude();
lo = location.getLongitude();

SQLiteDatabase db = openOrCreateDatabase("vendas.db", Context.MODE_PRIVATE, null);

Spinner spProdutos = (Spinner) findViewById(R.id.spProdutos);

SQLiteCursor dados = (SQLiteCursor) spProdutos.getAdapter().getItem(spProdutos.getSelectedItemPosition());

ContentValues ctv = new ContentValues();
ctv.put("produto", dados.getInt(0));
ctv.put("preco", dados.getInt(2));
ctv.put("la", la);
ctv.put("lo", lo);

if(db.insert("vendas", "_id", ctv) > 0){
Toast.makeText(getBaseContext(), "Sucesso", Toast.LENGTH_SHORT).show();
}

}
@Override
public void onLocationChanged(Location location) {
// TODO Auto-generated method stub

}
@Override
public void onStatusChanged(String provider, int status, Bundle extras) {
// TODO Auto-generated method stub

}
@Override
public void onProviderEnabled(String provider) {
// TODO Auto-generated method stub

}
@Override
public void onProviderDisabled(String provider) {
// TODO Auto-generated method stub

}
}




Alterei o dados.getInt do "preco" para getDouble, mas continua dando o mesmo erro.




Ola Carlos

eu acho q o problema ta nessa linha aki

SQLiteDatabase db = openOrCreateDatabase("vendas.bd", Context.MODE_PRIVATE, null);

naum é vendas.bd

é vendas.db

:)




Foi muita falta de atenção da minha parte. Mas obrigado.
Agora surgiu outro erro ao clicar em Nova Venda:
Caused by: android.database.sql.SQLiteException: no such table: produtos (code 1):,
while compiling: SELECT * FROM produtos ORDER BY nome ASC.
Desde já, agradeço.




Na verdade, cometi o mesmo erro na MainActivity. É db, e não bd.




Agora o NullPointerException tá apontando para la = location.getLatitude();
Preciso de ajuda novamente.




mostre o log cat ... por favor...




O problema estava no emulador. Mas obrigado e até a próxima.