>
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.