Форум программистов, компьютерный форум CyberForum.ru

Для чего применяется класс OAuthConsumer при публикации приложений в твиттере? - Android

Войти
Регистрация
Восстановить пароль
Другие темы раздела
Android Запуск таймера после закрытия второй Активити http://www.cyberforum.ru/android-dev/thread1238142.html
Есть две Активити, на первой есть Chronometer. При запуске активити1 запускается таймер, при переходе в активити2 таймер в первой активити должен останавливаться и запускаться заново только после закрытия второй активити При переходе ко второй активити делаю так: Timer.Stop(); startActivity(intent); таймер остановился, но как теперь его запустить заново после закрытия второй активити...
Android Менеджер не загружает файлы Привет Друзья! начал изучать андроид, делаю все строго по алгоритму, скачал с оф.сайта пак (еклипс, сдк, менеджер сдк). Менеджер непонятно себя ведет, в общем все загрузилось, а в пунктах ВЕРСИЯ грузиться только первая строчка, остальные никак, ругается вроде на неправильный репозитарий, фото "того что не грузиться" прикрепляю. Что скажите? Как решить проблему? Спасибо за понимание. http://www.cyberforum.ru/android-dev/thread1238064.html
Разбиение большого текста на страницы Android
Есть большой текстовый файл, его надо вывести на экран частями (страницами). Задача состоит в предварительном определении числа страниц вывода с учетом установленных параметров шрифта (размер и межстрочный интервал). А затем вывод на экран нужного куска текста, в зависимости от выбранного номера страницы. Нашел несколько вариантов схожих решений, но никак не могу в них толком разобраться....
Не работает android:state_pressed Android
<Button android:id="@+id/button1" android:layout_width="150dp" android:layout_height="150dp" android:layout_centerHorizontal="true" android:layout_centerVertical="true" android:text="Button" android:textColor="@android:color/white" android:textSize="30sp" android:background="@drawable/buttoncustombgg"/>
Android Delphi и SoundPool http://www.cyberforum.ru/android-dev/thread1237973.html
Господа, нигде не могу найти документации по андроидскому SoundPool в Delphi. Для остальных языков - навалом всяких разных, но это как в супермаркете, есть все, кроме того, что нужно. Может, есть у кого примеры, или вспомнит свежей головой? Мозг совсем перегрелся. Вот к примеру, такое. Естественно, не компилируется, ошибка "record, object or class required". var SndPool: JSoundPool; SndNum:...
Android Не могу программно поставить Title у MenuItem Есть такое выпадающее меню(вроде с 3-ей версии android появилось). Ну если мало места на экране то нажимаете вверху справа и вылазит меню. Мне нужно в процессе изменить название одного из пунктов меню, но вылетает ошибка. MenuItem some_item; some_item= (MenuItem)findViewById(R.id.some_item); ...... some_item.setTitle("SomeText"); В xml файле меню так: <item подробнее

Показать сообщение отдельно
yura91
28 / 26 / 2
Регистрация: 23.10.2013
Сообщений: 2,202
21.08.2014, 17:50  [ТС]     Для чего применяется класс OAuthConsumer при публикации приложений в твиттере?
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
findViewById(R.id.postImageButton).setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                if (LoginActivity.isActive(context)) {
                    try {
 
                        mAlertBuilder = new AlertDialog.Builder(context).create();
                        mAlertBuilder.setCancelable(false);
                        mAlertBuilder.setTitle(R.string.please_wait_title);
                        View view = getLayoutInflater().inflate(R.layout.view_loading, null);
                        ((TextView) view.findViewById(R.id.messageTextViewFromLoading)).setText(getString(R.string.posting_image_message));
                        mAlertBuilder.setView(view);
                        mAlertBuilder.show();
 
                        InputStream inputStream  = v.getContext().getAssets().open("1.png");
                        Bitmap bmp = BitmapFactory.decodeStream(inputStream);
                        String filename = Environment.getExternalStorageDirectory().toString() + File.separator + "1.png";
                        Log.d("BITMAP", filename);
                        FileOutputStream out = new FileOutputStream(filename);
                        bmp.compress(Bitmap.CompressFormat.PNG, 90, out);
 
                        HelperMethods.postToTwitterWithImage(context, ((Activity)context), filename, getString(R.string.tweet_with_image_text), new TwitterCallback() {
 
                            @Override
                            public void onFinsihed(Boolean response) {
                                mAlertBuilder.dismiss();
                                Log.d(TAG, "----------------response----------------" + response);
                                Toast.makeText(context, getString(R.string.image_posted_on_twitter), Toast.LENGTH_SHORT).show();
                            }
                        });
 
                    } catch (Exception ex) {
                        Toast.makeText(context, "ERROR", Toast.LENGTH_SHORT).show();
                    }
                }else{
                    startActivity(new Intent(context, LoginActivity.class));
                }               
            }
        });
Добавлено через 2 минуты
сдесь идет обработчик кнопки который вызывает диалог

Добавлено через 1 минуту
Java
1
2
3
4
5
public static void postToTwitterWithImage(Context context, final Activity callingActivity, final String imageUrl, final String message, final TwitterCallback postResponse){
        if(!LoginActivity.isActive(context)){
            postResponse.onFinsihed(false);
            return;
        }
вызывается вот такой вот метод

Добавлено через 2 минуты
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
package com.learnncode.demotwitterimagepost;
 
import twitter4j.Twitter;
import twitter4j.TwitterFactory;
import twitter4j.auth.AccessToken;
import twitter4j.auth.RequestToken;
import twitter4j.conf.Configuration;
import twitter4j.conf.ConfigurationBuilder;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.content.SharedPreferences.Editor;
import android.graphics.Bitmap;
import android.graphics.Color;
import android.net.Uri;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.TextView;
import android.widget.Toast;
 
public class LoginActivity extends Activity {
 
    public static final int TWITTER_LOGIN_RESULT_CODE_SUCCESS = 1111;
    public static final int TWITTER_LOGIN_RESULT_CODE_FAILURE = 2222;
 
    private static final String TAG = "LoginActivity";
 
    private WebView twitterLoginWebView;
    private AlertDialog mAlertBuilder;
    private static String twitterConsumerKey;
    private static String twitterConsumerSecret;
 
    private static Twitter twitter;
    private static RequestToken requestToken;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_twitter_login);
        twitterConsumerKey = getResources().getString(R.string.twitter_consumer_key);
        twitterConsumerSecret = getResources().getString(R.string.twitter_consumer_secret);
 
        if(twitterConsumerKey == null || twitterConsumerSecret == null){
            Log.e(TAG, "ERROR: Consumer Key and Consumer Secret required!");
            LoginActivity.this.setResult(TWITTER_LOGIN_RESULT_CODE_FAILURE);
            LoginActivity.this.finish();
        }
 
 
        mAlertBuilder = new AlertDialog.Builder(this).create();
        mAlertBuilder.setCancelable(false);
        mAlertBuilder.setTitle(R.string.please_wait_title);
        View view = getLayoutInflater().inflate(R.layout.view_loading, null);
        ((TextView) view.findViewById(R.id.messageTextViewFromLoading)).setText(getString(R.string.authenticating_your_app_message));
        mAlertBuilder.setView(view);
        mAlertBuilder.show();
 
 
        twitterLoginWebView = (WebView)findViewById(R.id.twitterLoginWebView);
        twitterLoginWebView.setBackgroundColor(Color.TRANSPARENT);
        twitterLoginWebView.setWebViewClient( new WebViewClient(){
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url){
 
                if( url.contains(AppConstant.TWITTER_CALLBACK_URL)){
                    Uri uri = Uri.parse(url);
                    LoginActivity.this.saveAccessTokenAndFinish(uri);
                    return true;
                }
                return false;
            }
 
            @Override
            public void onPageFinished(WebView view, String url) {
                super.onPageFinished(view, url);
 
                if(mAlertBuilder != null){
                    mAlertBuilder.cancel();
                }
            }
 
            @Override
            public void onPageStarted(WebView view, String url, Bitmap favicon) {
                super.onPageStarted(view, url, favicon);
 
                if(mAlertBuilder != null){
                    mAlertBuilder.show();
                }
            }
        });
 
        Log.d(TAG, "Authorize....");
        askOAuth();
    }
 
    @Override
    protected void onDestroy() {
        super.onDestroy();
 
        if(mAlertBuilder != null) {
            mAlertBuilder.dismiss();
        }
    }
 
    @Override
    protected void onNewIntent(Intent intent) {
        super.onNewIntent(intent);
    }
 
    @Override
    protected void onResume() {
        super.onResume();
    }
 
    private void saveAccessTokenAndFinish(final Uri uri){
        new Thread(new Runnable() {
            @Override
            public void run() {
                String verifier = uri.getQueryParameter(AppConstant.IEXTRA_OAUTH_VERIFIER);
                try { 
                    SharedPreferences sharedPrefs = getSharedPreferences(AppConstant.SHARED_PREF_NAME, Context.MODE_PRIVATE);
                    AccessToken accessToken = twitter.getOAuthAccessToken(requestToken, verifier); 
                    Editor e = sharedPrefs.edit();
                    e.putString(AppConstant.SHARED_PREF_KEY_TOKEN, accessToken.getToken()); 
                    e.putString(AppConstant.SHARED_PREF_KEY_SECRET, accessToken.getTokenSecret()); 
                    e.commit();
 
                    Log.d(TAG, "TWITTER LOGIN SUCCESS ----TOKEN " + accessToken.getToken());
                    Log.d(TAG, "TWITTER LOGIN SUCCESS ----TOKEN SECRET " + accessToken.getTokenSecret());
                    LoginActivity.this.setResult(TWITTER_LOGIN_RESULT_CODE_SUCCESS);
                } catch (Exception e) { 
                    e.printStackTrace();
                    if(e.getMessage() != null){
                        Log.e(TAG, e.getMessage());
 
                    }else{
                        Log.e(TAG, "ERROR: Twitter callback failed");
                    }
                    LoginActivity.this.setResult(TWITTER_LOGIN_RESULT_CODE_FAILURE);
                }
                LoginActivity.this.finish();
            }
        }).start();
    }
 
 
    public static boolean isActive(Context ctx) {
        SharedPreferences sharedPrefs = ctx.getSharedPreferences(AppConstant.SHARED_PREF_NAME, Context.MODE_PRIVATE);
        return sharedPrefs.getString(AppConstant.SHARED_PREF_KEY_TOKEN, null) != null;
    }
 
    public static void logOutOfTwitter(Context ctx){
        SharedPreferences sharedPrefs = ctx.getSharedPreferences(AppConstant.SHARED_PREF_NAME, Context.MODE_PRIVATE);
        Editor e = sharedPrefs.edit();
        e.putString(AppConstant.SHARED_PREF_KEY_TOKEN, null); 
        e.putString(AppConstant.SHARED_PREF_KEY_SECRET, null); 
        e.commit();
    }
 
    public static String getAccessToken(Context ctx){
        SharedPreferences sharedPrefs = ctx.getSharedPreferences(AppConstant.SHARED_PREF_NAME, Context.MODE_PRIVATE);
        return sharedPrefs.getString(AppConstant.SHARED_PREF_KEY_TOKEN, null);
    }
 
    public static String getAccessTokenSecret(Context ctx){
        SharedPreferences sharedPrefs = ctx.getSharedPreferences(AppConstant.SHARED_PREF_NAME, Context.MODE_PRIVATE);
        return sharedPrefs.getString(AppConstant.SHARED_PREF_KEY_SECRET, null);
    }
 
    private void askOAuth() {
        ConfigurationBuilder configurationBuilder = new ConfigurationBuilder();
        configurationBuilder.setOAuthConsumerKey(twitterConsumerKey);
        configurationBuilder.setOAuthConsumerSecret(twitterConsumerSecret);
        Configuration configuration = configurationBuilder.build();
        twitter = new TwitterFactory(configuration).getInstance();
 
        new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    requestToken = twitter.getOAuthRequestToken(AppConstant.TWITTER_CALLBACK_URL);
                } catch (Exception e) {
                    final String errorString = e.toString();
                    LoginActivity.this.runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            mAlertBuilder.cancel();
                            Toast.makeText(LoginActivity.this, errorString.toString(), Toast.LENGTH_SHORT).show();
                            finish();
                        }
                    });
                    return;
                }
 
                LoginActivity.this.runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        twitterLoginWebView.loadUrl(requestToken.getAuthenticationURL());
                    }
                });
            }
        }).start();
    }
 
}
Добавлено через 50 секунд
вот само LoginActivity

Добавлено через 57 секунд
XML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<?xml version="1.0" encoding="utf-8"?>
<resources>
 
    <string name="app_name">DemoTwitterImagePost</string>
    <string name="action_settings">Settings</string>
    <string name="twitter_consumer_key">MtZV0R7nZMmTS0N5Uiiz52AV2</string>
    <string name="twitter_consumer_secret"> KZex7LHCC2wHuhLhiOwWFs5CgJfiUeSuqWgZx3b7C4GxFQSIRd</string>
    <string name="post_image">Post Image</string>
    <string name="post_tweet">Post Tweet</string>
    <string name="authentication_done_now_post_tweet_or_image_text"> Your app is authenticated. Now  you can post tweet/image on twitter. </string>
 
    <!-- loading messages -->
    <string name="please_wait_title"> Please wait </string>
    <string name="authenticating_your_app_message"> Authenticating your app... </string>
    <string name="posting_image_message"> Uploading image on twitter... </string>
    <string name="posting_tweet_message"> Posting tweet on twitter... </string>
 
    <!-- toast -->
 
    <string name="image_posted_on_twitter"> Image posted on twitter successfully. </string>
    <string name="tweet_posted_on_twitter"> Tweet posted on twitter successfully. </string>
    <string name="tweet_with_image_text"> dummy tweet with image. </string>
    <string name="tweet_text"> dummy tweet. </string>
 
</resources>
Добавлено через 52 секунды
а это ресурсы в которых также хранятся и API key

Добавлено через 1 минуту
А токен для работы с апи я беру в контексте приложения можно так??? в чем ошибка и как ее исправить??

Добавлено через 4 часа 1 минуту
можно ли брать token в контексте приложения через Context как тут реализовано?? в чем тогда ошибка??
 
Текущее время: 02:29. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru