Java 存储用户在手机上创建的数据。请看这篇文章
我的情况是下一个。我正在创建一个应用程序,当你可以做一个调查,然后,你可以看到调查答案,点击按钮,在应用程序中,而不去电话文件或类似的东西。我已经创建了大约55%的应用程序,但其他45%是最重要的。有多少可能性,或者我可以做些什么来实现这一点,当一个人点击应用程序内的按钮时,可以看到调查答案。我做了界面、按钮、文本视图等。。我创建了一个数据库,认为创建它,就有可能实现我想要的。我希望当你可以做一个调查,然后按下一个按钮,打开一个新的活动,并看到调查的答案时,你可以做一个系统。当您关闭应用程序并再次打开时,调查答案不会消失,它们仍然保存。谢谢 以下是我的调查代码,XML和JAVA:Java 存储用户在手机上创建的数据。请看这篇文章,java,android,Java,Android,我的情况是下一个。我正在创建一个应用程序,当你可以做一个调查,然后,你可以看到调查答案,点击按钮,在应用程序中,而不去电话文件或类似的东西。我已经创建了大约55%的应用程序,但其他45%是最重要的。有多少可能性,或者我可以做些什么来实现这一点,当一个人点击应用程序内的按钮时,可以看到调查答案。我做了界面、按钮、文本视图等。。我创建了一个数据库,认为创建它,就有可能实现我想要的。我希望当你可以做一个调查,然后按下一个按钮,打开一个新的活动,并看到调查的答案时,你可以做一个系统。当您关闭应用程序并再
Button sig = (Button) findViewById(R.id.env); // cargo el boton
encuestadoSQLiteHelper encuestado = new encuestadoSQLiteHelper(this, "DBEncuestado", null, 1); // base de datos
final SQLiteDatabase db = encuestado.getWritableDatabase();
sig.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Context context = getApplicationContext();
EditText preg5 = (EditText) findViewById(R.id.editText2);
EditText preg4 = (EditText) findViewById(R.id.editText);
Spinner cur = (Spinner) findViewById(R.id.spinnerp);
EditText nom = (EditText) findViewById(R.id.editText3);
RadioGroup gruporadio = (RadioGroup) findViewById(R.id.Grupo1);
RadioGroup gruporadio2 = (RadioGroup) findViewById(R.id.Grupo2);
RadioGroup gruporadio3 = (RadioGroup) findViewById(R.id.Grupo3);
String strNombre = nom.getText().toString();
String nombre = "PabloGonzalez";
String curso = cur.getSelectedItem().toString();
String strPregCinco = preg5.getText().toString();
String strPregCuatro = preg4.getText().toString();
if(gruporadio.getCheckedRadioButtonId() == -1 || gruporadio2.getCheckedRadioButtonId() == -1 || gruporadio3.getCheckedRadioButtonId() == -1 )
{
Toast.makeText(context,"¡No marcaste ninguna respuesta!",Toast.LENGTH_LONG).show();
}
else if (strNombre.matches("") || strPregCinco.matches("") || strPregCuatro.matches(""))
{
Toast.makeText(context,"¡Dejaste campos vacíos!",Toast.LENGTH_LONG).show();
}
else if(db == null)
{
Toast.makeText(context, "No funciona la base de datos.", Toast.LENGTH_LONG).show();
db.close();
}
else
{
Intent i = new Intent (encuesta.this, res8.class);
i.putExtra("nombre", strNombre);
startActivity(i);
Intent pas = new Intent(encuesta.this, MainActivity.class);
Toast.makeText(context,"¡Encuesta enviada!",Toast.LENGTH_LONG).show();
startActivity(pas);
db.execSQL("INSERT INTO Encuestado (nombre) " +
"VALUES ('" + nombre +"')");
db.close();
new Thread(new Runnable() {
@Override
public void run() {
try {
File sd = Environment.getExternalStorageDirectory();
File data = Environment.getDataDirectory();
if (sd.canWrite()) {
String currentDBPath = "/data/com.example.pablo.myapplication/databases/DBEncuestado";
String backupDBPath = "backdatabase.sqlite";
File currentDB = new File(data, currentDBPath);
File backupDB = new File(sd, backupDBPath);
if (currentDB.exists()) {
FileChannel src = new FileInputStream(currentDB).getChannel();
FileChannel dst = new FileOutputStream(backupDB).getChannel();
dst.transferFrom(src, 0, src.size());
src.close();
dst.close();
}
}
} catch (Exception e) {
System.out.println("error in data base copy:"+e);
}
}
}).start();
}
}
});
}
}
如果你能看到,有一个数据库,但我不知道这是不是必要的或是
XML:
我想展示答案的活动是res8.javaBro,只需创建一个像getter和setter这样的模型类,首先创建像getQuestion()、setQuestion()、getAnswer()和setAnswer()这样的方法。然后,当用户回答您的调查问题时,只需创建该模型类的对象,如:-
ArrayList<MyModel> datalist = new ArrayList();
MyModel model = new MyModel();
model.setQuestion(list.get(i).question);
model.setAnswer(list.get(i).answer);
....
....
dataList.add(model);
ArrayList datalist=new ArrayList();
MyModel model=新的MyModel();
model.setQuestion(list.get(i).question);
model.setAnswer(list.get(i.answer));
....
....
添加(模型);
这样只需捕获所有用户输入的数据,不需要在这个数据库中
这里的列表是你所有问题的列表
当你想获取数据时,只需调用datalist.get(i).getQuestion,类似地,还有答案。你做了什么,你想做什么,你希望如何做你想做的事?我做了界面、按钮、文本视图等。。我创建了一个数据库,认为创建它,就有可能实现我想要的。我希望当你可以做一个调查,然后按下一个按钮,打开一个新的活动,并看到调查的答案时,你可以做一个系统。当你关闭应用程序并再次打开时,调查答案不会消失,它们仍然保存着。我建议你用持久化实现的详细信息更新你的问题,这样你就可以让数据库按详细信息(我是指代码)工作。定义一个表,插入和检索数据等等,我如何用我在问题上发布的代码来做到这一点?
ArrayList<MyModel> datalist = new ArrayList();
MyModel model = new MyModel();
model.setQuestion(list.get(i).question);
model.setAnswer(list.get(i).answer);
....
....
dataList.add(model);