0

runnable 内で getItem() メソッドを呼び出す必要があります。しかし、問題はそれが機能していないということです。両方のログが機能していますが、メソッドは実行されていません。

this.viewItems = new Runnable() {

        public void run() {

            Log.i("getitem", "before");
            getItems();
            Log.i("getitem", "done");
        }
    };

これは getItems メソッドです

    private void getItems() {
    try {
        Log.i("url", url);
        InputStream source = retrieveStream(this.url);
        Log.i("inside getitem", "before object");
        Gson gson = new Gson();

        Reader reader = new InputStreamReader(source);

        SearchResponse response = gson.fromJson(reader, SearchResponse.class); 

        Log.i("inside getitem", "after response");
        i_orders = new ArrayList<Items>();

        List<Offers> off = response.offers;

        for (Offers of : off) {

            Items item = new Items();

            item.setCovers(of.covers);
            item.setCuisine(of.cuisine);
            item.setDate_available(of.date_available);
            item.setDistance(of.distance);
            item.setEnd_time_available(of.end_time_available);
            item.setLarge_image_url(of.large_image_url);
            item.setLat(of.lat);
            item.setLon(of.lon);
            item.setMax_cover(of.max_cover);
            item.setMin_cover(of.min_cover);
            item.setOffer_description(of.offer_description);
            item.setOffer_id(of.offer_id);
            item.setPrice_range(of.price_range);
            item.setRestaurant_name(of.restaurant_name);
            item.setRestaurant_profile(of.restaurant_profile);
            item.setRestaurant_suburb(of.restaurant_suburb);
            item.setSmall_image_url(of.small_image_url);
            item.setStart_time_available(of.start_time_available);
            item.setTables_available(of.tables_available);
            item.setTime_available(of.time_available);


            i_orders.add(item);

        }

        Thread.sleep(1000);
        Log.i("ARRAY", "" + i_orders.size());
    } catch (Exception e) {
        Log.e("BACKGROUND_PROC", e.getMessage());
    }
    runOnUiThread(returnRes);
}

一番上のログメッセージさえも得られません。

前もって感謝します !!

4

2 に答える 2

0

暗黙の「これ」があります。getItems()の前にありますが、「this」から呼び出している場所は別のものです(実際にはRunnable)。

あなたはおそらく次のようなことをすることができるはずです:

プライベートコンテキストmyContext;

..。

myContext = this;

this.viewItems = newRunnable...。

myContext.getItems();

..。

しかし、どういうわけか、内側のスコープからそれを参照するために使用できる外側のスコープに「this」への参照であるある種の変数が必要です。

于 2011-05-13T08:31:21.627 に答える
0

URL がフォーマットされていないため、getItems メソッド内に例外があることがわかりました。

于 2011-05-16T08:23:01.290 に答える