我使用以下代码:
UserTimeline userTimeline = new UserTimeline.Builder().screenName("ZainAlabdin878").build();
final TweetTimelineListAdapter adapter = new TweetTimelineListAdapter(MainActivity.this, userTimeline);
System.out.println(adapter.getCount()+"");
虽然我有推文,但我得到了输出0。
我做错了吗? 我想要实现的是获取某个用户的推文列表。我正在使用android studio和插件。
*我的目标不是显示列表而是获取列表
非常感谢。答案 0 :(得分:2)
final TwitterAuthConfig authConfig = new TwitterAuthConfig(TWITTER_KEY, TWITTER_SECRET);
Fabric.with(context, new Twitter(authConfig), new TweetUi());
TwitterCore.getInstance().logInGuest(new Callback<AppSession>() {
@Override
public void success(Result<AppSession> result) {
AppSession session = result.data;
TwitterApiClient twitterApiClient = TwitterCore.getInstance().getApiClient(session);
twitterApiClient.getStatusesService().userTimeline(tweetId, screenName, tweetCount, null, null, false, false, false, true, new Callback<List<Tweet>>() {
@Override
public void success(Result<List<Tweet>> listResult) {
for (Tweet tweet : listResult.data) {
// here you will get list
}
}
@Override
public void failure(TwitterException e) {
e.printStackTrace();
}
});
}
@Override
public void failure(TwitterException e) {
Log.e(TAG, "Load Tweet failure", e);
}
});
答案 1 :(得分:0)
以下是实际获取Tweet
个对象所需的代码:
ArrayList<Tweet> tweets = new ArrayList<>();
TwitterCore.getInstance().getApiClient(session).getStatusesService()
.userTimeline(null,
"screenname",
10 //the number of tweets we want to fetch,
null,
null,
null,
null,
null,
null,
new Callback<List<Tweet>>() {
@Override
public void success(Result<List<Tweet>> result) {
for (Tweet t : result.data) {
tweets.add(t);
android.util.Log.d("twittercommunity", "tweet is " + t.text);
}
}
@Override
public void failure(TwitterException exception) {
android.util.Log.d("twittercommunity", "exception " + exception);
}
});
您需要在新的线程(不是UI线程)中运行它
修改强>
*从技术上讲,你没有有在一个新线程中运行它,因为它是异步的(如果我错了,有人请在这里纠正我)。我知道其他Twitter API调用是异步的,所以我假设这个也是,虽然我找不到Fabric源中实际调用的位置。*
以下是Fabric SDK
中userTimeline()的完整参数列表void userTimeline(@Query("user_id") Long var1, @Query("screen_name") String var2, @Query("count") Integer var3, @Query("since_id") Long var4, @Query("max_id") Long var5, @Query("trim_user") Boolean var6, @Query("exclude_replies") Boolean var7, @Query("contributor_details") Boolean var8, @Query("include_rts") Boolean var9, Callback<List<Tweet>> var10);