0

私は SwipeRefreshLayout を使用してデータをリモートで取得していますが、これを AsyncHttpClient を使用してネットワーク側を処理しています。

1 つのシナリオ (アプリの最初の onCreate 起動) を除いて、すべてが期待どおりに機能します。

主な活動:

public class MainActivity extends Activity implements AdapterView.OnItemClickListener, SwipeRefreshLayout.OnRefreshListener{

    ListView mainListView;
    JSONMainAdapter mJSONAdapter;
    SwipeRefreshLayout swipeLayout;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);

        swipeLayout = (SwipeRefreshLayout) findViewById(R.id.main_swipe_container);
        swipeLayout.setOnRefreshListener(this);
        swipeLayout.setColorScheme(android.R.color.holo_blue_bright,
                android.R.color.holo_green_light,
                android.R.color.holo_orange_light,
                android.R.color.holo_red_light);

        mainListView = (ListView) findViewById(R.id.main_listview);
        mainListView.setOnItemClickListener(this);

        mJSONAdapter = new JSONMainAdapter(this, getLayoutInflater());
        mainListView.setAdapter(mJSONAdapter);

        getGames();
    }

オンリフレッシュ:

@Override 
public void onRefresh() {
    getGames();
}

ネットワークのリフティングを行う getGames:

private void getGames() {

        swipeLayout.setRefreshing(true);
        //gets logged on first onCreate load
        Log.d("DEBUG", "IN GET GAMES");

        MyRestClient.get("games", null, new JsonHttpResponseHandler() {
            @Override
            public void onSuccess(JSONObject jsonObject) {
                //does NOT get logged on first onCreate
                //but does get logged on refresh and other onCreate calls 
                Log.d("DEBUG", "IN GET GAMES ON SUCCESS");
                swipeLayout.setRefreshing(false);
                Toast.makeText(getApplicationContext(), "Success!", Toast.LENGTH_LONG).show();
                mJSONAdapter.updateData(jsonObject.optJSONArray("games"));
            }

            @Override
            public void onFailure(int statusCode, Throwable throwable, JSONObject error) {
                Log.d("DEBUG", "IN GET GAMES ON FAIL");
                swipeLayout.setRefreshing(false);
                Toast.makeText(getApplicationContext(), "Error: " + statusCode + " " + throwable.getMessage(), Toast.LENGTH_LONG).show();
                Log.e("ERROR", statusCode + " " + throwable.getMessage());
            }
        });
    }

したがって、IDE からアプリを起動するonCreateと、getGames()関数が呼び出され、そこに入ったことがログに記録されますがMyRestClient.get("games", null, new JsonHttpResponseHandler() {、データをフェッチせず、onSuccess または onFailure にログオンしないため、ネットワークは呼び出されません。

現在、スワイプして更新すると機能し、取得したデータとログがリストビューに正常に読み込まれ、onSuccess に記録されます。

戻るボタンでアプリを閉じて再度開くと、正しく機能し、リストビューが更新されます。

したがって、IDE からエミュレーターに起動したときの最初の onCreate 呼び出しでのみ機能するわけではありませんが、その後、最初の最初の onCreate がすべて正常に機能しません。

ここで何が欠けているのかわかりません。助けていただければ幸いです。

SwipeRefreshLayout: https://developer.android.com/reference/android/support/v4/widget/SwipeRefreshLayout.html

AsyncHttpClient: http://loopj.com/android-async-http/

編集:

public class MyRestClient {
    private static final String BASE_URL = "http://10.10.1.10:3000/api/";

    private static AsyncHttpClient client = new AsyncHttpClient();

    public static void get(String url, RequestParams params, AsyncHttpResponseHandler responseHandler) {
        addAuthHeaders();
        client.get(getAbsoluteUrl(url), params, responseHandler);
    }

    public static void post(String url, RequestParams params, AsyncHttpResponseHandler responseHandler) {
        addAuthHeaders();
        client.post(getAbsoluteUrl(url), params, responseHandler);
    }

    private static String getAbsoluteUrl(String relativeUrl) {
        return BASE_URL + relativeUrl;
    }

    public static void addAuthHeaders(){
        client.addHeader("blah", "xxx");
        client.addHeader("blah", "xxx");
    }
}

編集2:

> 05-05 08:51:20.477: E/memtrack(1696): Couldn't load memtrack module
> (No such file or directory) 05-05 08:51:20.477:
> E/android.os.Debug(1696): failed to load memtrack module: -2 05-05
> 08:51:20.857: D/AndroidRuntime(1696): Calling main entry
> com.android.commands.am.Am 05-05 08:51:20.937: I/ActivityManager(380):
> START u0 {act=android.intent.action.MAIN
> cat=[android.intent.category.LAUNCHER] flg=0x10000000
> cmp=com.example.myapp.app/.MainActivity} from pid 1696 05-05
> 08:51:21.047: D/gralloc(49): Registering a buffer in the process that
> created it. This may cause memory ordering problems. 05-05
> 08:51:21.047: E/libEGL(49): called unimplemented OpenGL ES API 05-05
> 08:51:21.057: E/libEGL(49): called unimplemented OpenGL ES API 05-05
> 08:51:21.057: E/libEGL(49): called unimplemented OpenGL ES API 05-05
> 08:51:21.057: E/libEGL(49): called unimplemented OpenGL ES API 05-05
> 08:51:21.057: E/SurfaceFlinger(49): glCheckFramebufferStatusOES error
> 1620973071 05-05 08:51:21.057: E/SurfaceFlinger(49): got
> GL_FRAMEBUFFER_COMPLETE_OES error while taking screenshot 05-05
> 08:51:21.057: E/libEGL(49): called unimplemented OpenGL ES API 05-05
> 08:51:21.057: E/libEGL(49): called unimplemented OpenGL ES API 05-05
> 08:51:21.067: W/WindowManager(380): Screenshot failure taking
> screenshot for (328x546) to layer 21005

アプリの起動時にログで異常に見える唯一の部分です。

4

2 に答える 2

0

onCreate は getGames() を呼び出さないということですか? getGames() を onResume() に入れようとしましたか?

于 2014-05-06T02:05:42.050 に答える