获取当前用户的帖子状态

时间:2012-05-24 12:16:29

标签: android facebook facebook-graph-api facebook-fql facebook-android-sdk

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

现在我一直在尝试多种方法来查询帖子的列,并检查当前用户是否喜欢帖子来显示状态。基本上,我正在设置一个drawable来表示用户喜欢帖子。

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

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

编辑:这是我最近尝试查询likes列并将结果与​​当前用户的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();
            }
        }
    }

1 个答案:

答案 0 :(得分: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
      }
    }
  ]
}