2016-05-26 8 views
1

イム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)

私は何か間違っているかどうか教えてください。私はさまざまなソースを試しましたが、これは最も一般的な答えと思われます。私は大いに助けに感謝します。事前のおかげで

答えて

0

の代わりに任意の接続を開始せずとせずにURLを(渡して、あなたがImageViewの中に画像を表示するためにピカソライブラリを使用する必要があります

bitmap = BitmapFactory.decodeStream(facebookProfileURL.openConnection().getInputStream()); 

このラインで使用されるように、入力ストリームを使用して)入力ストリームを使用して、唯一のFacebookから受け取ったURLを使用して:

Picasso.with(this).load(/* url of image */).into(/*your imageview id*/); 

としてthis answerに示されている。

関連する問題