これは非常によくある質問だと思いますが、すべての回答を見ても解決できません。テーマ (壁紙、着信音、通知音) を保存できる Android アプリケーションを作成しています。ボタンをクリックしてデータベースに3つのものを保存しようとすると、強制的に閉じられ、「スタックトレースを開くことができません」などのエラーがいくつかあります
Code:
public class HelloGallery extends Activity
{
private ThemeAdapter ta;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ta=new ThemeAdapter(this);
final Button save=(Button)findViewById(R.id.save);
save.setText(R.string.save);
// some amount of code
save.setOnClickListener(new OnClickListener(){
public void onClick(View v)
{
themename=tv.toString(); //tv is EditText
ta.createTheme(themename, resID, uri,uri2);
Toast.makeText(HelloGallery.this,"Theme Saved", Toast.LENGTH_SHORT).show();
}
});
}
}
public class ThemeAdapter {
private SQLiteDatabase db;
private myThemeHelper mth;
String[] columns={myThemeHelper.KEY_ID,myThemeHelper.NAME,myThemeHelper.RING,myThemeHelper.SYS};
public ThemeAdapter(Context _con)
{
mth=new myThemeHelper(_con);
}
public ThemeAdapter open()
{
try
{
db=mth.getWritableDatabase();
}
catch(SQLiteException e)
{
db=mth.getReadableDatabase();
}
return this;
}
public void close()
{
db.close();
}
public void createTheme(String name,int wallId,Uri ring,Uri sys)
{
ContentValues val=new ContentValues();
val.put(myThemeHelper.NAME,name);
val.put(myThemeHelper.WALL,wallId);
val.put(myThemeHelper.RING,ring.toString());
val.put(myThemeHelper.SYS,sys.toString());
long id=db.insert(myThemeHelper.DB_TABLE, null, val);
Cursor cursor=db.query(myThemeHelper.DB_TABLE,columns,myThemeHelper.KEY_ID+ "= "
+ id, null,null, null, null);
cursor.moveToFirst();
}
}
public class myThemeHelper extends SQLiteOpenHelper
{
//initializing all db names, colum names
public myThemeHelper(Context context) {
super(context, DB_NAME, null, DB_VERSION);
}
@Override
public void onCreate(SQLiteDatabase database) {
database.execSQL(DB_CREATE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
Log.w(myThemeHelper.class.getName(),
"Upgrading database from version " + oldVersion + " to "
+ newVersion + ", which will destroy all old data");
db.execSQL("DROP TABLE IF EXISTS " + DB_TABLE);
onCreate(db);
}
}
スタック トレースで NullPointerException が発生し、スタック トレースを開けません。WRITE_EXTERNAL_STORAGE パーミッションも付与しました。