Приложение неожиданно остановилось! Arraylist Hashmaps и TabHost - PullRequest
0 голосов
/ 17 февраля 2011

У меня проблема с моим кодом, и я не могу его найти! Ошибка ... Приложение неожиданно остановилось! Я понятия не имею, что происходит. (Я также начинающий DevAndroid) Моя первая вкладка работает нормально, но когда я переключаюсь на вторую с помощью ArrayList Hashmap, она вылетает.

Вот мой код BonuriActivity:

public class BonuriActivity extends ListActivity {

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.tab_bonuri);

    final String url="http://xxxzzz/throwdata.php?p=bonuri";

    ListView lv = (ListView) findViewById(android.R.id.list);
    SimpleAdapter adapter = new SimpleAdapter(BonuriActivity.this,
            getBonuri(url), R.layout.list_bon, 
            new String[] {"Produs", "Cantitate", "UM", "IdVinzare"},
            new int[] { R.id.Produs, R.id.Cantitate, R.id.UM, R.id.IdVinzare });
    lv.setAdapter(adapter);
}

private ArrayList<HashMap<String,String>> getBonuri(String KEY_121) {

       InputStream is = null;
       String result = "";  

       HashMap<String,String> entitiesHashMap = new HashMap<String, String>();
       ArrayList<HashMap<String, String>> returnString = new ArrayList<HashMap<String,String>>();

        //http post
        try{
                HttpClient httpclient = new DefaultHttpClient();
                HttpPost httppost = new HttpPost(KEY_121);
                HttpResponse response = httpclient.execute(httppost);
                HttpEntity entity = response.getEntity();
                is = entity.getContent();

        }catch(Exception e){
                Log.e("log_tag", "Error in http connection "+e.toString());
        }

        //convert response to string
        try{
                BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
                StringBuilder sb = new StringBuilder();
                String line = null;
                while ((line = reader.readLine()) != null) {
                        sb.append(line + "\n");
                }
                is.close();
                result=sb.toString();
        }catch(Exception e){
                Log.e("log_tag", "Error converting result "+e.toString());
        }
        //parse json data
        try{
                JSONArray jArray = new JSONArray(result);
                for(int i=0;i<jArray.length();i++){
                        JSONObject json_data = jArray.getJSONObject(i);                    
                        //Get an output to the screen
                        entitiesHashMap.put("Produs", json_data.getString("Produs"));
                        entitiesHashMap.put("Cantitate", json_data.getString("Cantitate"));
                        entitiesHashMap.put("UM", json_data.getString("UM"));
                        entitiesHashMap.put("IdVinzare", json_data.getString("IdVinzare"));
                        returnString.add(entitiesHashMap);
                }
        }catch(JSONException e){
                Log.e("log_tag", "Error parsing data "+e.toString());
        }

        return returnString; 
    }     

}

А вот и мой TabBonuri.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="fill_parent"
android:layout_height="fill_parent" android:id="@+id/tab2Layout">

<ListView
android:id="@android:id/list"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
</ListView>

</LinearLayout>

И мой list_bon.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearView xmlns:android="http://schemas.android.com/apk/res/android">
<TextView
android:id="@+id/UM"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="10dp"
android:text="UM"
android:textSize="16sp"
>
</TextView>

<TextView
android:id="@+id/Cantitate"
android:layout_width="wrap_content"
android:layout_height="21px"
android:padding="10dp"
android:text="Cantitate"
android:textSize="16sp"
>
</TextView>
<TextView
android:id="@+id/Produs"
android:layout_width="121px"
android:layout_height="22px"
android:padding="10dp"
android:text="Produs"
android:textSize="16sp"
>
</TextView>
<TextView
android:id="@+id/IdVinzare"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:visibility="invisible"
android:text="TextView"
/>
</LinearView>

Благодарю вас за то, что вы уделили мне время. Пожалуйста, прокомментируйте, если вы видите, почему моя программа дает сбой, потому что я уже напуган этим (пробовал 2 дня, это расстраивает).

Ответы [ 2 ]

1 голос
/ 17 февраля 2011

Очевидно, вы не знаете, где найти LogCat ...

Если вы разрабатываете с Eclipse, посмотрите здесь: http://developer.android.com/guide/developing/debug-tasks.html Сообщение об ошибке, которое вы найдете, это то, что мыНужно помочь тебе.Так что скопируйте и вставьте его в свой вопрос.

Если вы хотите научиться отлаживать, вот небольшая инструкция для этого: http://www.droidnova.com/debugging-in-android-using-eclipse,541.html

update

Хорошо, скриншот из logcat - не лучший способ сообщить об ошибке, но он показывает то, что предложил Бланделл: вы выбираете из Интернета в потоке пользовательского интерфейса.Прочитайте это: http://developer.android.com/guide/practices/design/responsiveness.html, и загрузка вашего интернет-контента должна быть сделана с этим: http://developer.android.com/reference/android/os/AsyncTask.html

0 голосов
/ 18 февраля 2011

Вы также можете просто создать новый поток и использовать обработчик:

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.HashMap;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.ListActivity;
import android.app.ProgressDialog;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.widget.ListView;
import android.widget.SimpleAdapter;

public class BonuriActivity extends ListActivity {

private static final int PASS = 0;
private static final int FAIL = 1;

private final String url = "http://xxxzzz/throwdata.php?p=bonuri";

private ArrayList<HashMap<String, String>> bonnieList = null;

private ProgressDialog mProgressDialog;

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.tab_bonuri);

    fetchData();
}

private void fetchData() {
    mProgressDialog = ProgressDialog.show(this, "Please Wait", "loading..", true);
    new Thread() {
        @Override
        public void run() {
            // Do the internet call in it's own thread
            bonnieList = getBonuri(url);
            // Call back to the UI thread with the result
            if (bonnieList != null || !bonnieList.isEmpty()) {
                doAfterInternetCall.sendEmptyMessage(PASS);
            } else {
                doAfterInternetCall.sendEmptyMessage(FAIL);
            }
            mProgressDialog.dismiss();
        }
    }.start();
}

private Handler doAfterInternetCall = new Handler() {
    @Override
    public void handleMessage(Message msg) {
        switch (msg.what) {
        case PASS:
            actUponRetreivedData();
            break;
        case FAIL:
            // TODO do something else
            break;
        }
    }
};

private ArrayList<HashMap<String, String>> getBonuri(String KEY_121) {

    InputStream is = null;
    String result = "";

    HashMap<String, String> entitiesHashMap = new HashMap<String, String>();
    ArrayList<HashMap<String, String>> returnString = new ArrayList<HashMap<String, String>>();

    // http post
    try {
        HttpClient httpclient = new DefaultHttpClient();
        HttpPost httppost = new HttpPost(KEY_121);
        HttpResponse response = httpclient.execute(httppost);
        HttpEntity entity = response.getEntity();
        is = entity.getContent();

    } catch (Exception e) {
        Log.e("log_tag", "Error in http connection " + e.toString());
    }

    // convert response to string
    try {
        BufferedReader reader = new BufferedReader(new InputStreamReader(is, "iso-8859-1"), 8);
        StringBuilder sb = new StringBuilder();
        String line = null;
        while ((line = reader.readLine()) != null) {
            sb.append(line + "\n");
        }
        is.close();
        result = sb.toString();
    } catch (Exception e) {
        Log.e("log_tag", "Error converting result " + e.toString());
    }
    // parse json data
    try {
        JSONArray jArray = new JSONArray(result);
        for (int i = 0; i < jArray.length(); i++) {
            JSONObject json_data = jArray.getJSONObject(i);
            // Get an output to the screen
            entitiesHashMap.put("Produs", json_data.getString("Produs"));
            entitiesHashMap.put("Cantitate", json_data.getString("Cantitate"));
            entitiesHashMap.put("UM", json_data.getString("UM"));
            entitiesHashMap.put("IdVinzare", json_data.getString("IdVinzare"));
            returnString.add(entitiesHashMap);
        }
    } catch (JSONException e) {
        Log.e("log_tag", "Error parsing data " + e.toString());
    }

    return returnString;
}

protected void actUponRetreivedData() {
    ListView lv = (ListView) findViewById(android.R.id.list);
    SimpleAdapter adapter = new SimpleAdapter(BonuriActivity.this, bonnieList, R.layout.list_bon, new String[] { "Produs", "Cantitate", "UM", "IdVinzare" }, new int[] { R.id.Produs,
            R.id.Cantitate, R.id.UM, R.id.IdVinzare });
    lv.setAdapter(adapter);
}

}

Это не может гарантировать работу, я проверю это позже, но это покажет принцип потоков и обработчиков.

...