public class RegularExpensesActivity extends ListActivity implements OnClickListener{
privat开发者_开发技巧e static final String TAG = "RegularExpensesActivity";
private static final int state_edit = 0;
private static final int state_insert = 1;
private static final String array_key = "array";
private static final String pref_name = "Setting";
private static final String des_key = "DES";
private static final String amt_key = "AMT";
private String des;
private String amt;
private ArrayList<HashMap<String, String>> list;
ArrayList<String> array;
HashMap<String, String> map;
private SharedPreferences preferences;
private SharedPreferences.Editor editor;
private Button add_btn;
private EditText description;
private EditText amount;
private SimpleAdapter adapter;
private int clickedPosition;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.setContentView(R.layout.setting_reg_list);
preferences = getSharedPreferences (pref_name, MODE_PRIVATE);
list = new ArrayList<HashMap<String, String>>();
map = new HashMap<String, String>();
retrieveAndLoadData();
displayList();
add_btn = (Button) findViewById(R.id.button_add_reg);
add_btn.setOnClickListener(this);
add_btn.setText(R.string.btn_add);
}
@Override
protected void onListItemClick(ListView l, View v, int position, long id) {
clickedPosition = position;
openDialog(state_edit);
}
@Override
public void onClick(View view) {
if(view==add_btn){
openDialog(state_insert);
}
}
private void openDialog(int state) {
LayoutInflater inflater = (LayoutInflater) getBaseContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View view = inflater.inflate(R.layout.reg_add_edit, null);
description = (EditText) view.findViewById(R.id.edit_reg_description);
amount = (EditText) view.findViewById(R.id.edit_reg_amount);
AlertDialog.Builder alert = new AlertDialog.Builder(this);
alert.setView(view)
.setIcon(android.R.drawable.ic_menu_more);
switch(state){
case state_insert:
alert.setTitle("Add Record")
.setPositiveButton("Ok", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,int id) {
if(!description.getText().toString().equals(null)&& !amount.getText().toString().equals(null)){
array.add(description.getText().toString());
map = new HashMap<String, String>();
map.put(des_key, description.getText().toString());
map.put(amt_key, amount.getText().toString());
list.add(map);
editor = preferences.edit();
editor.putString(array_key, fromArrayListToString(array));
editor.putString(""+array.indexOf(description.getText().toString()), amount.getText().toString());
editor.commit();
adapter.notifyDataSetChanged();
dialog.dismiss();
}
}
})
.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,int id) {
dialog.cancel();
}
});
break;
case state_edit:
String selectedDes;
String selectedAmt;
selectedDes = array.get(clickedPosition);
selectedAmt = preferences.getString(""+clickedPosition, "0");
description.setText(selectedDes);
amount.setText(selectedAmt);
alert.setTitle("Edit Record")
.setPositiveButton("Ok", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,int id) {
if(!description.getText().toString().equals(null)&& !amount.getText().toString().equals(null)){
array.set(clickedPosition, description.getText().toString());
map = new HashMap<String, String>();
map.put(des_key, description.getText().toString());
map.put(amt_key, amount.getText().toString());
list.set(clickedPosition, map);
editor = preferences.edit();
editor.putString(array_key, fromArrayListToString(array));
editor.putString(""+clickedPosition, amount.getText().toString());
editor.commit();
dialog.dismiss();
adapter.notifyDataSetChanged();
Toast.makeText(getBaseContext(),"Record added.",Toast.LENGTH_LONG).show();
}
}
})
.setNegativeButton("Delete", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,int id) {
array.remove(clickedPosition);
list.remove(clickedPosition);
for(int i = clickedPosition;i<array.size();i++){
int oldPosition = i+1;
String old = preferences.getString(""+oldPosition,"0");
editor = preferences.edit();
editor.putString(""+i, old);
}
editor.putString(array_key, fromArrayListToString(array));
editor.commit();
dialog.cancel();
adapter.notifyDataSetChanged();
Toast.makeText(getBaseContext(),"Deleted.",Toast.LENGTH_LONG).show();
}
});
break;
}
alert.create();
alert.show();
}
public String fromArrayListToString(ArrayList<String> arrayList) {
StringBuffer packedString = new StringBuffer();
for (int i = 0; i < arrayList.size(); i++) {
if (i > 0) {
packedString.append("\u001f");
}
packedString.append(arrayList.get(i));
}
return packedString.toString();
}
public ArrayList<String> getArrayList(String packedString) {
String[] array = packedString.split("\u001f");
ArrayList<String> returnArrayList = new ArrayList<String>();
Log.d(TAG, "split array length: "+array.length);
if(!array[0].equals("")){
for (int i = 0; i < array.length; i++) {
returnArrayList.add(array[i]);
}
}
return returnArrayList;
}
private String convText(TextView v,String text) {
switch (v.getId()) {
case R.id.reg_amount:
double dblAmt;
if(!text.equals("0")){
DecimalFormat twoDigit = new DecimalFormat("#,##0.00");
dblAmt = Double.parseDouble(text);
return "RM "+twoDigit.format(dblAmt);
}
}
return text;
}
private void displayList() {
adapter = new SimpleAdapter(this, list, R.layout.reg_row, new String[] { des_key, amt_key },
new int[] { R.id.reg_description,R.id.reg_amount}){
@Override
public void setViewText(TextView v, String text) {
super.setViewText(v, convText(v, text));
}
};
setListAdapter(adapter);
}
private void retrieveAndLoadData() {
des=preferences.getString(array_key,"");
Log.d(TAG, des);
array = getArrayList(des);
for(int i=0;i<array.size();i++){
map = new HashMap<String, String>();
map.put(des_key, array.get(i));
map.put(amt_key, preferences.getString(""+i, "0"));
list.add(map);
}
}
}
I'm a beginner in android apps development, I really need some help. My code works well when I add the 1st record, I can get back the record after i restart my apps. But when i trying to add the 2nd record i will get this warning and i can't get the previously saved record after restart.
WARN/ApplicationContext(17598): getSharedPreferences
WARN/ApplicationContext(17598): org.xmlpull.v1.XmlPullParserException: Error parsing document. (position:line -1, column -1) caused by: org.apache.harmony.xml.ExpatParser$ParseException: At line 4, column 27: not well-formed (invalid token)
WARN/ApplicationContext(17598): at org.apache.harmony.xml.ExpatPullParser$ByteDocument.flush(ExpatPullParser.java:958)
WARN/ApplicationContext(17598): at org.apache.harmony.xml.ExpatPullParser$Document.pump(ExpatPullParser.java:769)
WARN/ApplicationContext(17598): at org.apache.harmony.xml.ExpatPullParser$Document.dequeue(ExpatPullParser.java:813)
WARN/ApplicationContext(17598): at org.apache.harmony.xml.ExpatPullParser.next(ExpatPullParser.java:302)
WARN/ApplicationContext(17598): at com.android.internal.util.XmlUtils.readValueXml(XmlUtils.java:675)
WARN/ApplicationContext(17598): at com.android.internal.util.XmlUtils.readMapXml(XmlUtils.java:470)
WARN/ApplicationContext(17598): at android.app.ContextImpl.getSharedPreferences(ContextImpl.java:373)
WARN/ApplicationContext(17598): at android.content.ContextWrapper.getSharedPreferences(ContextWrapper.java:146)
WARN/ApplicationContext(17598): at com.yan.app.RegularExpensesActivity.onCreate(RegularExpensesActivity.java:78)
WARN/ApplicationContext(17598): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
WARN/ApplicationContext(17598): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1586)
WARN/ApplicationContext(17598): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1638)
WARN/ApplicationContext(17598): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
WARN/ApplicationContext(17598): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:928)
WARN/ApplicationContext(17598): at android.os.Handler.dispatchMessage(Handler.java:99)
WARN/ApplicationContext(17598): at android.os.Looper.loop(Looper.java:123)
WARN/ApplicationContext(17598): at android.app.ActivityThread.main(ActivityThread.java:3647)
WARN/ApplicationContext(17598): at java.lang.reflect.Method.invokeNative(Native Method)
WARN/ApplicationContext(17598): at java.lang.reflect.Method.invoke(Method.java:507)
WARN/ApplicationContext(17598): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
WARN/ApplicationContext(17598): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
WARN/ApplicationContext(17598): at dalvik.system.NativeStart.main(Native Method)
Why could this happen?? Can anyone give me some advice? what wrong with my code?? Thanks.
EDIT:
editor = preferences.edit();
for(int i = clickedPosition;i<array.size();i++){
int oldPosition = i+1;
String old = preferences.getString(""+oldPosition,"0");
editor.putString(""+i, old);
}
editor.putString(array_key, fromArrayListToString(array));
editor.commit();
updated with my code.
public void onClick(DialogInterface dialog,int id) {
array.remove(clickedPosition);
list.remove(clickedPosition);
for(int i = clickedPosition;i<array.size();i++){
int oldPosition = i+1;
String old = preferences.getString(""+oldPosition,"0");
editor = preferences.edit();
editor.putString(""+i, old);
}
editor.putString(array_key, fromArrayListToString(array));
editor.commit();
dialog.cancel();
adapter.notifyDataSetChanged();
Toast.makeText(getBaseContext(),"Deleted.",Toast.LENGTH_LONG).show();
}
});
This looks pretty odd. In for loop you're opening multiple editors without committing them and in the end you're committing only the last one. I don't know if this is the source of your problem but it's a problem :)
you need this:
preferences = getAplicationContext().getSharedPreferences (pref_name, MODE_PRIVATE);
if im not mistaken sharedPreferences needs the context of the aplication.
精彩评论