イムFacebookのSDKとAndroidの中でFacebookのプロフィール画像をロードしますが、例外を取得しているように見える時に例外を取得。私はビットマップ、ピカソなどを使用してイメージを読み込む方法を説明するスタックオーバーフローを注ぎましたが、何らかの理由でまだ読み込めませんでした。私は問題がいくつかのネットワークスレッドの問題だと思うが、私はそれが重要ではない.executeAsync()でメソッドを実行するので、私は思った。 ナビゲーション引き出しのなた上部に私のAndroidアプリにFacebookのプロフィール画像をロードしようと4+
ここ<de.hdodenhof.circleimageview.CircleImageView
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/profile_image"
android:layout_width="70dp"
android:layout_height="70dp"
android:src="@drawable/hanger_circle"
app:border_color="#FF000000"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:layout_marginBottom="8dp"/>
</RelativeLayout>
iは、Facebookのログインの成功(画像を要求する私の活動からの抜粋です: は、ここで私はプロフィールの写真(nav_header_main.xml)することで、画像を宣言xmlです:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//initialize facebook sdk
FacebookSdk.sdkInitialize(getApplicationContext());
setContentView(R.layout.activity_login);
//Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
//setSupportActionBar(toolbar);
//call custom application class to initialize intercom (not login, just setup)
ApplicationHelper helper = (ApplicationHelper)getApplicationContext();
//create facebook button recognition
callbackManager = CallbackManager.Factory.create();
LoginManager.getInstance().registerCallback(callbackManager,
new FacebookCallback<LoginResult>() {
@Override
public void onSuccess(LoginResult loginResult) {
//facebook picture stuff
Bundle params = new Bundle();
params.putString("fields", "id,email,gender,cover,picture.type(large)");
new GraphRequest(AccessToken.getCurrentAccessToken(), "me", params, HttpMethod.GET,
new GraphRequest.Callback() {
@Override
public void onCompleted(GraphResponse response) {
if (response != null) {
try {
JSONObject data = response.getJSONObject();
if (data.has("picture")) {
String profilePicUrl = data.getJSONObject("picture").getJSONObject("data").getString("url");
// set profile image to imageview using Picasso or Native methods
Bitmap profilePic = getFacebookProfilePicture(profilePicUrl);
ImageView mImageView = (ImageView) findViewById(R.id.profile_image);
mImageView.setImageBitmap(profilePic);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
}).executeAsync();
// launch next activity
Toast.makeText(getApplicationContext(), "SUCCESS", Toast.LENGTH_SHORT).show();
startActivity(new Intent(LoginActivity.this, MainActivity.class));
finish();
}
@Override
public void onCancel() {
// App code
Toast.makeText(getApplicationContext(), "CANCEL", Toast.LENGTH_SHORT).show();
}
@Override
public void onError(FacebookException exception) {
// App code
Toast.makeText(getApplicationContext(), "FAIL", Toast.LENGTH_SHORT).show();
}
});
//check if facebook user is logged in already
AccessToken token = AccessToken.getCurrentAccessToken();
Profile prof = Profile.getCurrentProfile();
if(token != null && prof != null){
//log in
//Toast.makeText(getApplicationContext(), token.getToken(), Toast.LENGTH_SHORT).show();
startActivity(new Intent(LoginActivity.this, MainActivity.class));
finish();
}
//check if regular user is logged in already
SharedPreferences shared = getSharedPreferences("shared", MODE_PRIVATE);
if(shared.contains("username") && shared.contains("password")){
//password exists in file so launch next activity (make sure there correct with API)
startActivity(new Intent(LoginActivity.this, MainActivity.class));
finish();
}
}
私はまた、このヘルパーメソッドを使用します。ここでは
public static Bitmap getFacebookProfilePicture(String url){
URL facebookProfileURL= null;
Bitmap bitmap = null;
try {
facebookProfileURL = new URL(url);
bitmap = BitmapFactory.decodeStream(facebookProfileURL.openConnection().getInputStream());
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return bitmap;
}
は私の例外です: 5月26日14:20:05.751 11101から11101/com.android.press.pressのW/System.errの:android.os.NetworkOnMainThreadException 5月26日14:20:05.751 11101から11101/com.android.press。 W/System.errを押してください:android.os.StrictMode $ AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1147) 05-26 14:20:05.751 11101-11101/com.android.press.press W/System.err: 20:05.751 11101から11101/com.android.press.pressのW/System.errの:java.net.InetAddress.getAllByNameImplで(java.net.InetAddress.lookupHostByName(InetAddress.java:418) 5月26日14時InetAddress.java:252) 05-26 14:20:05.751 11101-11101/com.android.press.press W/System.err:java.net.InetAddress.getAllByName(InetAddress.java:215) 05- 26 14:20:05.751 11101-11101/com.android.press.press W/System.err:com.android.okhttp.HostResolver $ 1.getAllByName(HostResolver.java:29) 05-26 14:20:05.752 11101-11101/com.android.press.press W/System.err:com.android.okhttp.internal.http.RouteSelector.resetNextInetSocketAddress(RouteSelector.java:232) 05- 26 14:20:05.752 11101-11101/com.android.press.press W/System.err:com.android.okhttp.internal.http.RouteSelector.next(RouteSelector.java:124) 05-26 14: 20:05.752 11101-11101/com.android.press.press W/System.err:com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:272) 05-26 14:20:05.752 11101から11101/com.android.press.pressのW/System.errの:com.android.okhttp.internal.http.HttpEngine.sendRequestで(HttpEngine.java:211) 5月26日14:20:05.752 11101から11101 /com.android.press.press W/System.err:com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:373) 05-26 14:20:05.752 11101-11101/com。 android.pre ss.press W/System.err:com.android.okhttp.internal.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:323) 05-26 14:20:05.752 11101-11101/com.android.press.press W/System.err:com.android.okhttp.internal.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:190) 05-26 14:20:05.752 11101-11101/com.android.press.press W/System .err:at com.android.okhttp.internal.http.DelegatingHttpsURLConnection.getInputStream(DelegatingHttpsURLConnection.java:210) 05-26 14:20:05.752 11101-11101/com.android.press.press W/System.err: com.android.okhttp.internal.http.HttpsURLConnectionImpl.getInputStreamで(HttpsURLConnectionImpl.java:25) 5月26日14:20:05.752 11101から11101/com.android.press.pressのW/System.errの:COMで。 android.press.press.LoginActivity.getFacebookProfilePicture(LoginActivity.java:215) 05-26 14:20:0 5.752 11101-11101/com.android.press.press W/System.err:com.android.press.press.LoginActivity $ 1 $ 1.onCompleted(LoginActivity.java:85) 05-26 14:20:05.752 11101- 11101/com.android.press.press W/System.err:at com.facebook.GraphRequest $ 5.run(GraphRequest.java:1379) 05-26 14:20:05.752 11101-11101/com.android.press。W/System.err:android.os.Handler.handleCallback(Handler.java:739) 05-26 14:20:05.752 11101-11101/com.android.press.press W/System.err:android .os.Handler.dispatchMessage(Handler.java:95) 05-26 14:20:05.752 11101-11101/com.android.press.press W/System.err:android.os.Looper.loop(Looper。 java:135) 05-26 14:20:05.752 11101-11101/com.android.press.press W/System.err:at android.app.ActivityThread.main(ActivityThread.java:5221) 05-26 14 :20:05.752 11101-11101/com.android.press.press W/System.err:java.lang.reflect.Method.invoke(ネイティブメソッド) 05-26 14:20:05.752 11101-11101/com。 android.press.press W/System.err:java.lang.reflect.Method.invoke(Method.java:372) 05-26 14:20:05.752 11101-11101/com.android.press.press W/System.err:com.android.internal.os.ZygoteInit $ MethodAndArgs Caller.run(ZygoteInit.java:899) 05-26 14:20:05.752 11101-11101/com.android.press.press W/System.err:com.android.internal.os.ZygoteInit.main(ZygoteInit .java:694)
私は何か間違っているかどうか教えてください。私はさまざまなソースを試しましたが、これは最も一般的な答えと思われます。私は大いに助けに感謝します。事前のおかげで