まず、私の下手な英語で申し訳ありません。
公式の 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)
...
この問題を回避する方法を教えてください。ありがとう