1

まず、私の下手な英語で申し訳ありません。

公式の Facebook API を使用して Facebook に接続するシンプルな Android アプリを作成しようとしています。ユーザーがログインしてアプリを承認すると、ユーザー名とプロフィール写真を取得して、アプリに表示したいと考えています。Facebook API に付属している Hackbook サンプル アプリのコードをいくつか採用しました。これがメインアクティビティクラスの私のコードです。

public class SocialApp2Activity extends Activity {
    private Handler handler;

    private Facebook facebook;
    private AsyncFacebookRunner asyncRunner;

    private TextView text;
    private ImageView imgUserPic;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        handler = new Handler();

        text = (TextView) findViewById(R.id.txt);
        imgUserPic = (ImageView) findViewById(R.id.user_pic);

        facebook = new Facebook("MY_FB_APP_ID");
        asyncRunner = new AsyncFacebookRunner(facebook);

        facebook.authorize(this, new DialogListener() {
            @Override
            public void onComplete(Bundle values) {
                Bundle params = new Bundle();
                params.putString("fields", "name, picture");
                asyncRunner.request("me", params, new UserRequestListener());
            }

            ... 

        });
    }

    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);

        facebook.authorizeCallback(requestCode, resultCode, data);
    }


    /* Callback for fetching username and profile picture */
    public class UserRequestListener implements RequestListener {

        @Override
        public void onComplete(final String response, final Object state) {

            JSONObject jsonObject;

            try {
                jsonObject = new JSONObject(response);

                final String picURL = jsonObject.getString("picture");
                final String name = jsonObject.getString("name");

                handler.post(new Runnable() {
                    @Override
                    public void run() {
                        text.setText(name);

                        /********************************
                         *** This line cause an error ***
                         ********************************/
                        imgUserPic.setImageBitmap(Utility.getBitmap(picURL));

                    }
                });
            } catch (JSONException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        ...
    }
}

リモート サーバーからプロファイル画像のビットマップ データを読み取る独自のメソッドを呼び出すと、エラーが発生します。エラーは NetworkOnMainThreadException で、スタック トレースの一部がここにあります。

05-04 14:37:28.898: W/System.err(1117): android.os.NetworkOnMainThreadException
05-04 14:37:28.905: W/System.err(1117):     at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1084)
05-04 14:37:28.905: W/System.err(1117):     at java.net.InetAddress.lookupHostByName(InetAddress.java:391)
...
05-04 14:37:29.005: W/System.err(1117):     at libcore.net.http.HttpsURLConnectionImpl.connect(HttpsURLConnectionImpl.java:164)
05-04 14:37:29.005: W/System.err(1117):     at promlert.socialapp2.Utility.getBitmap(Utility.java:26)
05-04 14:37:29.016: W/System.err(1117):     at promlert.socialapp2.SocialApp2Activity$UserRequestListener$1.run(SocialApp2Activity.java:95)
...

この問題を回避する方法を教えてください。ありがとう

4

1 に答える 1

1

handler.post(Runnable runnable) は、UI スレッドでランナブルを実行しています。したがって、UI スレッドでネットワーク操作を実行しようとすると、この例外が発生します。これを回避するには、最初に UI スレッドからではなく Utility.getBitmap(picURL) を呼び出し、次に imgUserPic.setImageBitmap() メソッドのみを UI スレッドにポストします。

new Thread(new Runnable() {

                @Override
                public void run() {
                    //this line must be called not from the UI  thread
                final Bitmap bitmap = Utility.getBitmap(picURL)
                handler.post(new Runnable() {
                @Override
                public void run() {
                                   text.setText(name);
                                   imgUserPic.setImageBitmap(bitmap );

                                  }
                  });   
                }
}).start();
于 2012-05-04T09:41:33.540 に答える