1

我已经能够使用“me/home”图形 API 调用为登录用户提取 Facebook 新闻源,并在活动中显示结果。

现在我一直在尝试多种方法来查询帖子的like 列并检查当前用户是否喜欢帖子以显示状态。本质上,我正在设置一个可绘制对象以指示用户喜欢一个帖子。

我无法真正发布到目前为止我尝试过的任何代码,因为它们都不起作用。相信我,我已经尝试了无数种方法。

如果有人至少能在正确的方向上刺激我,我将不胜感激。

编辑:这是我查询喜欢列并将结果与​​当前用户的 ID 进行比较的最新尝试:

这段代码是我检查喜欢计数并将它们添加到 ArrayList 的地方。这也是我运行查询以在帖子中获得喜欢的地方。

// GET THE POST'S LIKES COUNT

    if (json_data.has("likes")) {
        JSONObject feedLikes = json_data.optJSONObject("likes");
        String countLikes = feedLikes.getString("count");
        postLikesCountArrayList.add(countLikes);

        // TEST STARTS

        // QUERY THE LIKES COLUMN TO CHECK YOUR LIKE STATUS ON A POST

        Bundle params = new Bundle();
        params.putString(Facebook.TOKEN, Utility.mFacebook.getAccessToken());
        Utility.mAsyncRunner.request(finalThreadID + "/likes&limit=200", params, new LikesListener());

        // TEST ENDS
        } else {
            String countLikes = "0";
            postLikesCountArrayList.add(countLikes);
        }

此代码块是检查结果的侦听器(同一活动中的私有类):

private class LikesListener extends BaseRequestListener {
        @Override
        public void onComplete(final String response, final Object state) {

            try {
                JSONObject JOLikes = new JSONObject(response);

                JSONArray JALikes = JOLikes.getJSONArray("data");

                for (int i = 0; i < JALikes.length(); i++) {
                    JSONObject JOTemp = JALikes.getJSONObject(i);

                    if (JOTemp.has("id"))   {
                        String getTempID = JOTemp.getString("id");

                        if (getTempID.equals(initialUserID))    {

                            Runnable run = new Runnable() {

                                @Override
                                public void run() {
                                    // TODO Auto-generated method stub


                                    ImageView postYourLike = (ImageView) findViewById(R.id.postYourLike);
                                    postYourLike.setBackgroundResource(R.drawable.btn_icon_liked);
                                }
                            };
                            TestNewsFeeds.this.runOnUiThread(run);
                        }
                    }

                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
4

1 回答 1

2

您可以使用此 fql。替换 post_id

SELECT likes.can_like, likes.user_likes FROM stream WHERE  post_id = "1274834235_3976149403543"

响应看起来像这样,如果 user_likes 是真的,他喜欢它

 {
  "data": [
    {
      "likes": {
        "can_like": true, 
        "user_likes": false
      }
    }
  ]
}
于 2012-05-24T12:34:19.887 回答