Все технические форумы на одном сайте Удобный поиск информации с популярных форумов в одном месте
Вопрос: Vk-android-sdk

Всем доброго дня!

Вопрос связан с Android SDK для vk. Собственно ошибка у меня появляется в момент авторизации

{"error":"invalid_client","error_description":"client_id incorrect"}

Все делал как описано в документации



Код взял отсюда



Кто-нибудь сталкивался с такой проблемой?

ID приложения я вставлял в ресурсы, на сайте vk вводил название пакета, ключ sha1, включил его... Не могу понять где ошибка.
Ответ: У меня уже надежда появилась что вот она где-то тут, ошибочка.

Мысли вслух.
А вообще стоит ли на этой библиотеке заморачиваться? Может без нее нормально получится... Еще не пробовал но несколько раз встречал код, как если сам руками запрос формирую и показываю в вебвью, ответ ловлю и паршу токен.
Вопрос: Виртуальный android на реальном android-смартфоне. Реально ли?

Имею смартфон с android 5.1 lollipop(philips xenium v377). Есть ли какие-то виртуализаторы систем? Virtualbox для android нету, bochs, qemu требовательны к железу, тормозят и эмулируют только x86 архитектуру, да и android под них никто не делал. Есть ли какая-то альтернатива, которой можно выделить, скажем, 1-2 РЕАЛЬНЫХ ядра процессора, место на карте? Я хочу запустить какой-нибудь виртуальный android 2.3.6 на телефоне. Компьютера нету, да и под Винду вообще куча эмуляторов android, ставь хоть kitkat, хоть ICS, хоть gingerbread. Так реален ли виртуальный android в реальном? Заранее благодарю.

P.S. ОЗУ 1 гиг, проц mediatek MT6580 1.3 GHz, 4 ядра. Слабое железо, знаю, но так как я хочу запускать старые версии android типа 2.3 или максимум 4.0.4, то, думаю, 2 ядер и 256-512 оперативки им хватит.
Ответ: Возможно, но тормозить будет жутко. Есть даже виртуальный Windows 98 для Андроида, но больше чем для прикола (смотрите, у меня винда с компьютера на телефоне!) она не годится, любого чиха будете от неё ждать минут по пять. Мощности железа несопоставимы с компьютерным.
Вопрос: Получить информация об устройстве Android на Java

Здраствуйте! Подскажите пожалуйста, как получить характеристики телефона Android: количество ядер CPU, частота ядер CPU, общий объем ОЗУ и жесткого диска, разрешение камеры(основной и фронтальной). Смог получить только объем ОЗУ и жесткого диска, количество ядер, но никак не могу получить частоту ядер и разрешение камеры...
Ответ: то, что лежит на поверхности: android.os.Build...

остальное, по-моему, прямыми запросами к железу.
Вопрос: Посоветуйте Android эмулятор

Посоветуйте бесплатный Android эмулятор для отладки готовых ark приложений с возможность настройки разрешений мобильного устройства.

Спасибо за ответ
Ответ:
Сообщение от IlushaMax
он требовательный к железу
бабки около подъезда рассказали?
Вопрос: Клиент-серверная разработка под Android

Нужна помощь в вопросе клиент серверных приложений на java под Андроид.
Уже несколько недель потратил на поиски нужной информации в интернете но так и не нашел ответов на свои вопросы.
Прошу помогите.
Вопросы которые меня интересует:
Подробный курс или что-то подобное по тому, как же все таки сделать и клиент и сервер и как их связывать вместе. А конкретно ещё и то, где же и как правильно разместить серверную часть, интересует все, вплоть до выбора хотсинга и настройки.
Не то чтобы я не умею пользоваться поиском... Прочитал много статей но ни где не нашел подробного объяснения как это сделать. Да много информации находил, но ни где ни кто не публикует то, как он например серверную часть размещает на хостинге, как он определяет то, как его приложение найдет его сервер в интернете. Мне бы хотя бы просто строчку с текстом передать на сервер, и сохранить ее там, и когда захочу получить ее от туда на клиент. И чтобы множество разных клиентов могли подключаться. Уж по другому мне изучить это вопрос не получается
Ответ: Арендуете какой нибудь VDS, я например выбрал first (не реклама), но у них приятная wiki на все случаи жизни.
При аренде выберите ОС и конфигурацию, после завершения придёт письмо с вашим личным IP для вашего VDS.
На нём поднимаете что хотите, хоть java сервер, хоть web(можно заренее установить автоматически).

В самой java программе должен быть сервер сокет
new ServerSocket(2000);
2000 это порт

теперь чтобы подключиться из android, в android надо использовать соответственно
Java
1
2
addr = new InetSocketAddress(ip, port);
socket.connect(addr, reconnectInterval);
При этом на сервере можете в одном потоке работать пока с одним клиентом, потом или nio или по потоку на клиента, тут от кол-ва клиентов исходить и своих возможностей.

В android же обязательно отдельный поток, ну это поймёте на автомате потом.

Сейчас пока арендовать ничего не надо, работайте в локальной сети, чтобы деньги зря не тратить.
Потом когда научитесь работать дома тогда и переносите сервер в vds, а в android приложении просто в addr замените ip и всё.

И да, мы прописываем ip циферками в приложении дабы исключить проблемы с DNS различного рода.
Вопрос: GPS android studio

Помогите что здесь за ошибка может быть :
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
locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, this);
Вот код : 
package com.example.root.gps12;
 
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.content.Context;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.widget.TextView;
 
import android.util.Log;
public class MainActivity extends AppCompatActivity implements LocationListener{
protected LocationManager locationManager;
protected LocationListener locationListener;
protected Context context;
TextView txtLat;
String lat;
String provider;
protected String latitude,longitude;
protected boolean gps_enabled,network_enabled;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
txtLat = (TextView) findViewById(R.id.textView2);
locationManager = (LocationManager)getSystemService(Context.LOCATION_SERVICE);
gps_enabled = locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER);
if(gps_enabled) {
locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, this);
}
}
 
@Override
public void onLocationChanged(Location location) {
txtLat = (TextView) findViewById(R.id.textView2);
txtLat.setText("Latitude:" + location.getLatitude() + ", Longitude:" + location.getLongitude());
}
 
@Override
public void onStatusChanged(String provider, int status, Bundle extras) {
Log.d("Latitude","status");
}
 
@Override
public void onProviderEnabled(String provider) {
Log.d("Latitude","enable");
}
 
@Override
public void onProviderDisabled(String provider) {
Log.d("Latitude","disable");
}
}
Ответ: DartHrack, как минимум ошибка здравого смысла (где вопрос?) и ошибка этикета (такая вот постановка "вопроса" это неуважение)
Вопрос: Авторизация Android ошибки

Крашится приложение после того, как я нажимаю кнопку войти в LoginActivity, в этом деле я новичек и делал всё руководствуюсь статьями из сети. В чем причина краша?

LoginActivity
Кликните здесь для просмотра всего текста
Java(TM) 2 Platform Standard Edition 5.0
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
import android.app.Activity;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
 
import org.apache.http.NameValuePair;
import org.apache.http.message.BasicNameValuePair;
import org.json.JSONException;
import org.json.JSONObject;
 
import java.util.ArrayList;
import java.util.List;
 
public class Login extends Activity {
 
    public static String URL_LOGIN = "localhost/Auth.php";
 
    EditText etLogin;
    EditText etPassword;
    Button btnLogin;
    List<NameValuePair> params;
    SharedPreferences sharedPreferences;
    ServerRequest serverRequest;
 
 
    @Override
    protected void onCreate(final Bundle savedInstanceState) {
 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_login);
 
        serverRequest = new ServerRequest();
 
        etLogin = (EditText) findViewById(R.id.etLogin);
        etPassword = (EditText) findViewById(R.id.etPassword);
 
        btnLogin = (Button) findViewById(R.id.btnLogin);
 
        btnLogin.setOnClickListener(new View.OnClickListener() {
 
            @Override
            public void onClick(View v) {
 
                String email = etLogin.getText().toString();
                String password = etPassword.getText().toString();
                params = new ArrayList<NameValuePair>();
                params.add(new BasicNameValuePair("email", email));
                params.add(new BasicNameValuePair("password", password));
                ServerRequest serverRequest = new ServerRequest();
                JSONObject jsonObject = serverRequest.getJSON(URL_LOGIN);
                if(jsonObject != null) {
 
                    try {
 
                        String jsonstr = jsonObject.getString("response");
                        if (jsonObject.getBoolean("res")){
                            String token = jsonObject.getString("token");
                            SharedPreferences.Editor editor = sharedPreferences.edit();
                            editor.putString("token", token);
                            editor.apply();
                            Intent intent = new Intent(Login.this,Main.class);
                            startActivity(intent);
                            finish();
                        }
 
                        Toast.makeText(getApplication(),jsonstr,Toast.LENGTH_LONG).show();
 
                    }
 
                    catch (JSONException e) {
 
                        e.printStackTrace();
 
                    }
                }
 
            }
 
        });
 
    }
 
}


ServerRequest
Кликните здесь для просмотра всего текста
Java(TM) 2 Platform Standard Edition 5.0
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
import android.os.AsyncTask;
import android.util.Log;
 
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONException;
import org.json.JSONObject;
 
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.List;
import java.util.concurrent.ExecutionException;
 
public class ServerRequest {
 
    static InputStream is = null;
    static JSONObject jObj = null;
    static String json = "";
    List<NameValuePair> params;
 
 
    public ServerRequest() {
 
    }
 
    public JSONObject getJSONFromUrl(String url, List<NameValuePair> params) {
 
 
        try {
 
            DefaultHttpClient httpClient = new DefaultHttpClient();
            HttpPost httpPost = new HttpPost(url);
            httpPost.setEntity(new UrlEncodedFormEntity(params));
 
            HttpResponse httpResponse = httpClient.execute(httpPost);
            HttpEntity httpEntity = httpResponse.getEntity();
            is = httpEntity.getContent();
 
        } catch (IOException e) {
            e.printStackTrace();
        }
 
        try {
            BufferedReader reader = new BufferedReader(new InputStreamReader(
                    is, "iso-8859-1"), 8);
            StringBuilder sb = new StringBuilder();
            String line = null;
            while ((line = reader.readLine()) != null) {
                sb.append(line).append("n");
            }
            is.close();
            json = sb.toString();
            Log.e("JSON", json);
        } catch (Exception e) {
            Log.e("Buffer Error", "Error converting result " + e.toString());
        }
 
 
        try {
            jObj = new JSONObject(json);
        } catch (JSONException e) {
            Log.e("JSON Parser", "Error parsing data " + e.toString());
        }
 
 
        return jObj;
 
    }
    JSONObject jobj;
    public JSONObject getJSON(String url) {
 
        Params param = new Params(url,params);
        Request myTask = new Request();
        try{
            jobj= myTask.execute(param).get();
        }catch (InterruptedException | ExecutionException e) {
            e.printStackTrace();
        }
        return jobj;
    }
 
 
    private static class Params {
        String url;
        List<NameValuePair> params;
 
 
        Params(String url, List<NameValuePair> params) {
            this.url = url;
            this.params = params;
 
        }
    }
 
    private class Request extends AsyncTask<Params, String, JSONObject> {
 
        @Override
        protected JSONObject doInBackground(Params... args) {
 
            ServerRequest request = new ServerRequest();
 
            return request.getJSONFromUrl(args[0].url,args[0].params);
        }
 
        @Override
        protected void onPostExecute(JSONObject json) {
 
            super.onPostExecute(json);
 
        }
 
    }
}


Log

Кликните здесь для просмотра всего текста
Code
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
04-09 18:28:19.189 16849-16849/? I/art: Late-enabling -Xcheck:jni
04-09 18:28:19.661 16849-16885/com.dpa7dujijiepgmail.app I/OpenGLRenderer: Initialized EGL, version 1.4
04-09 18:28:19.661 16849-16885/com.dpa7dujijiepgmail.app W/OpenGLRenderer: Failed to choose config with EGL_SWAP_BEHAVIOR_PRESERVED, retrying without...
04-09 18:28:27.198 16849-16849/com.dpa7dujijiepgmail.app W/IInputConnectionWrapper: beginBatchEdit on inactive InputConnection
04-09 18:28:27.198 16849-16849/com.dpa7dujijiepgmail.app W/IInputConnectionWrapper: endBatchEdit on inactive InputConnection
04-09 18:28:30.577 16849-16849/com.dpa7dujijiepgmail.app W/System.err: java.util.concurrent.ExecutionException: java.lang.NullPointerException: Attempt to invoke interface method 'java.util.Iterator java.util.List.iterator()' on a null object reference
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at java.util.concurrent.FutureTask.report(FutureTask.java:93)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at java.util.concurrent.FutureTask.get(FutureTask.java:163)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at android.os.AsyncTask.get(AsyncTask.java:483)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at com.dpa7dujijiepgmail.diplom.ServerRequest.getJSON(ServerRequest.java:83)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at com.dpa7dujijiepgmail.diplom.Login$1.onClick(Login.java:56)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at android.view.View.performClick(View.java:4756)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at android.view.View$PerformClick.run(View.java:19761)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at android.os.Handler.handleCallback(Handler.java:739)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at android.os.Handler.dispatchMessage(Handler.java:95)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at android.os.Looper.loop(Looper.java:135)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at android.app.ActivityThread.main(ActivityThread.java:5253)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at java.lang.reflect.Method.invoke(Native Method)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at java.lang.reflect.Method.invoke(Method.java:372)
04-09 18:28:30.580 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:949)
04-09 18:28:30.581 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:744)
04-09 18:28:30.581 16849-16849/com.dpa7dujijiepgmail.app W/System.err: Caused by: java.lang.NullPointerException: Attempt to invoke interface method 'java.util.Iterator java.util.List.iterator()' on a null object reference
04-09 18:28:30.583 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at org.apache.http.client.utils.URLEncodedUtils.format(URLEncodedUtils.java:160)
04-09 18:28:30.583 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at org.apache.http.client.entity.UrlEncodedFormEntity.<init>(UrlEncodedFormEntity.java:71)
04-09 18:28:30.583 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at com.dpa7dujijiepgmail.diplom.ServerRequest.getJSONFromUrl(ServerRequest.java:41)
04-09 18:28:30.583 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at com.dpa7dujijiepgmail.diplom.ServerRequest$Request.doInBackground(ServerRequest.java:110)
04-09 18:28:30.583 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at com.dpa7dujijiepgmail.diplom.ServerRequest$Request.doInBackground(ServerRequest.java:103)
04-09 18:28:30.583 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at android.os.AsyncTask$2.call(AsyncTask.java:288)
04-09 18:28:30.583 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at java.util.concurrent.FutureTask.run(FutureTask.java:237)
04-09 18:28:30.583 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
04-09 18:28:30.583 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
04-09 18:28:30.583 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
04-09 18:28:30.583 16849-16849/com.dpa7dujijiepgmail.app W/System.err:     at java.lang.Thread.run(Thread.java:818)
04-09 18:28:30.585 16849-16983/com.dpa7dujijiepgmail.app E/AndroidRuntime: FATAL EXCEPTION: AsyncTask #5
                                                                              Process: com.dpa7dujijiepgmail.app, PID: 16849
                                                                              java.lang.RuntimeException: An error occured while executing doInBackground()
                                                                                  at android.os.AsyncTask$3.done(AsyncTask.java:300)
                                                                                  at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
                                                                                  at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
                                                                                  at java.util.concurrent.FutureTask.run(FutureTask.java:242)
                                                                                  at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
                                                                                  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
                                                                                  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
                                                                                  at java.lang.Thread.run(Thread.java:818)
                                                                               Caused by: java.lang.NullPointerException: Attempt to invoke interface method 'java.util.Iterator java.util.List.iterator()' on a null object reference
                                                                                  at org.apache.http.client.utils.URLEncodedUtils.format(URLEncodedUtils.java:160)
                                                                                  at org.apache.http.client.entity.UrlEncodedFormEntity.<init>(UrlEncodedFormEntity.java:71)
                                                                                  at com.dpa7dujijiepgmail.app.ServerRequest.getJSONFromUrl(ServerRequest.java:41)
                                                                                  at com.dpa7dujijiepgmail.app.ServerRequest$Request.doInBackground(ServerRequest.java:110)
                                                                                  at com.dpa7dujijiepgmail.app.ServerRequest$Request.doInBackground(ServerRequest.java:103)
                                                                                  at android.os.AsyncTask$2.call(AsyncTask.java:288)
                                                                                  at java.util.concurrent.FutureTask.run(FutureTask.java:237)
                                                                                  at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)*
                                                                                  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)*
                                                                                  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)*
                                                                                  at java.lang.Thread.run(Thread.java:818)*
04-09 18:31:29.992 16849-16849/com.dpa7dujijiepgmail.app W/IInputConnectionWrapper: beginBatchEdit on inactive InputConnection
04-09 18:31:29.993 16849-16849/com.dpa7dujijiepgmail.app W/IInputConnectionWrapper: finishComposingText on inactive InputConnection
04-09 18:31:29.993 16849-16849/com.dpa7dujijiepgmail.app W/IInputConnectionWrapper: endBatchEdit on inactive InputConnection
Ответ:
Сообщение от YuraAAA
params null
Да, действительно немного подредактировал и всё встало на свои места. Но теперь я столкнулся с другой проблемой, при попытке авторизоваться, запрос доходит до сервера и возвращается токен (это видно в логе), но далее идут непонятные мне ошибки.

Кликните здесь для просмотра всего текста
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
04-10 10:09:43.469 1086-1305/com.dpa7dujijiepgmail.diplom E/JSON: {"status":"OK","token":"6839f91efb7e0061847edab095eae5105704268021cd2be5018b4567"}n
04-10 10:09:43.473 1086-1086/com.dpa7dujijiepgmail.app W/System.err: org.json.JSONException: No value for response
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at org.json.JSONObject.get(JSONObject.java:354)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at org.json.JSONObject.getString(JSONObject.java:510)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at com.dpa7dujijiepgmail.app.Login$1.onClick(Login.java:61)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at android.view.View.performClick(View.java:4084)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at android.view.View$PerformClick.run(View.java:16966)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at android.os.Handler.handleCallback(Handler.java:615)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at android.os.Handler.dispatchMessage(Handler.java:92)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at android.os.Looper.loop(Looper.java:137)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at android.app.ActivityThread.main(ActivityThread.java:4745)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at java.lang.reflect.Method.invokeNative(Native Method)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at java.lang.reflect.Method.invoke(Method.java:511)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
04-10 10:09:43.497 1086-1086/com.dpa7dujijiepgmail.app W/System.err:     at dalvik.system.NativeStart.main(Native Method)


Добавлено через 9 часов 6 минут
Сообщение от Dpa7DuJIJIep
Да, действительно немного подредактировал и всё встало на свои места. Но теперь я столкнулся с другой проблемой, при попытке авторизоваться, запрос доходит до сервера и возвращается токен (это видно в логе), но далее идут непонятные мне ошибки.
Ошибку я нашел. Спасибо YuraAAA за ответ на предыдущий вопрос.
Вопрос: Android Загрузка изображения на стену vkontakte

Здравствуйте всем, возникла необходимость загрузить фотографию на стену вконтакте.
На сайте разработчиков есть статья
Там написано что необходимо выполнить 3 пункта.
1й - получить адрес сервера:
Java
1
2
3
4
5
6
7
8
public String photosGetWallUploadServer(Long user_id, Long group_id) throws MalformedURLException, IOException, JSONException, KException {
        Params params = new Params("photos.getWallUploadServer");
        params.put("uid",user_id);
        params.put("gid",group_id);
        JSONObject root = sendRequest(params);
        JSONObject response = root.getJSONObject("response");
        return response.getString("upload_url");
    }
3й - получить данные о загруженной фотографии:
Java
1
2
3
4
5
6
7
8
9
10
11
12
public ArrayList<Photo> saveWallPhoto(String server, String photo, String hash, Long user_id, Long group_id) throws MalformedURLException, IOException, JSONException, KException {
        Params params = new Params("photos.saveWallPhoto");
        params.put("server",server);
        params.put("photo",photo);
        params.put("hash",hash);
        params.put("uid",user_id);
        params.put("gid",group_id);
        JSONObject root = sendRequest(params);
        JSONArray array=root.getJSONArray("response");
        ArrayList<Photo> photos = parsePhotos(array);
        return photos;
    }
у меня встал вопрос как написать POST-запрос на полученный адрес? (2й пункт по ссылке)
вот мой нерабочий код:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
public String[] uploadPhotoOnWall(String server, String photo) throws MalformedURLException, IOException, JSONException, KException {
        Params params = new Params("post");
        params.put("server", server);
        params.put("photo", photo);
        JSONObject root = sendRequest(params);
        JSONObject response = root.getJSONObject("response");
        
        String server_ = response.optString("server");
        String photo_ = response.optString("photo");
        String hash_ = response.optString("hash");
        String[] res=new String[]{server_, photo_, hash_};
        return res;     
    }
Ответ: Тоже очень хотел бы получить ответ на этот вопрос. Пробую фото с компа загрузить и прикрепить к сообщению , но что то никак не пойму. сложно для меня это...
может вам поможет этот код , где реализованы различные методы vkApi. Код взял из их тестового приложения. И там вроде есть как отправить на стену фото, но я с трудом понимаю и не могу это переделать под прикрепление фото к личному сообщению .
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
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
public class TestActivity extends ActionBarActivity {
 
    private static final int[] IDS = {R.id.users_get, R.id.friends_get, R.id.messages_get, R.id.dialogs_get,
            R.id.captcha_force, R.id.upload_photo, R.id.wall_post, R.id.wall_getById, R.id.test_validation,
            R.id.test_share, R.id.upload_photo_to_wall, R.id.upload_doc, R.id.upload_several_photos_to_wall,
            R.id.test_send_request};
 
    public static final int TARGET_GROUP = 60479154;
    public static final int TARGET_ALBUM = 181808365;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_test);
        VKSdk.requestUserState(this, new VKPaymentsCallback() {
            @Override
            public void onUserState(final boolean userIsVk) {
                runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
//                      Toast.makeText(TestActivity.this, userIsVk ? "user is vk's" : "user is not vk's", Toast.LENGTH_SHORT).show();
                    }
                });
            }
        });
        if (getSupportActionBar() != null) {
            getSupportActionBar().setDisplayHomeAsUpEnabled(true);
        }
        if (savedInstanceState == null) {
            getSupportFragmentManager().beginTransaction().add(R.id.container, new PlaceholderFragment()).commit();
        }
    }
 
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        if (item.getItemId() == android.R.id.home) {
            finish();
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
 
    /**
     * A placeholder fragment containing a simple view.
     */
    public static class PlaceholderFragment extends Fragment implements View.OnClickListener {
        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
            View view = inflater.inflate(R.layout.fragment_test, container, false);
            for (int id : IDS) {
                view.findViewById(id).setOnClickListener(this);
            }
            return view;
        }
 
        @Override
        public void onClick(View v) {
            switch (v.getId()) {
                case R.id.test_send_request: {
                    makeRequest();
                }
                break;
                case R.id.users_get: {
                    VKRequest request = VKApi.users().get(VKParameters.from(VKApiConst.FIELDS,
                            "id,first_name,last_name,sex,bdate,city,country,photo_50,photo_100," +
                                    "photo_200_orig,photo_200,photo_400_orig,photo_max,photo_max_orig,online," +
                                    "online_mobile,lists,domain,has_mobile,contacts,connections,site,education," +
                                    "universities,schools,can_post,can_see_all_posts,can_see_audio,can_write_private_message," +
                                    "status,last_seen,common_count,relation,relatives,counters"));
                    request.secure = false;
                    request.useSystemLanguage = false;
                    startApiCall(request);
                }
                break;
                case R.id.friends_get:
                    startApiCall(VKApi.friends().get(VKParameters.from(VKApiConst.FIELDS, "id,first_name,last_name,sex,bdate,city")));
                    break;
                case R.id.messages_get:
                    startApiCall(VKApi.messages().get());
                    break;
                case R.id.dialogs_get:
                    startApiCall(VKApi.messages().getDialogs());
                    break;
                case R.id.captcha_force:
                    startApiCall(new VKApiCaptcha().force());
                    break;
                case R.id.upload_photo: {
                    final Bitmap photo = getPhoto();
                    VKRequest request = VKApi.uploadAlbumPhotoRequest(new VKUploadImage(photo, VKImageParameters.pngImage()), TARGET_ALBUM, TARGET_GROUP);
                    request.executeWithListener(new VKRequestListener() {
                        @Override
                        public void onComplete(VKResponse response) {
                            recycleBitmap(photo);
                            VKPhotoArray photoArray = (VKPhotoArray) response.parsedModel;
                            Intent i = new Intent(Intent.ACTION_VIEW, Uri.parse(String.format("https://vk.com/photo-%d_%s", TARGET_GROUP, photoArray.get(0).id)));
                            startActivity(i);
                        }
 
                        @Override
                        public void onError(VKError error) {
                            showError(error);
                        }
                    });
                }
                break;
                case R.id.wall_post:
                    makePost(null, "Hello, friends!");
                    break;
                case R.id.wall_getById:
                    startApiCall(VKApi.wall().getById(VKParameters.from(VKApiConst.POSTS, "1_45558")));
                    break;
                case R.id.test_validation:
                    startApiCall(new VKRequest("account.testValidation"));
                    break;
                case R.id.test_share: {
                    final Bitmap b = getPhoto();
                    VKPhotoArray photos = new VKPhotoArray();
                    photos.add(new VKApiPhoto("photo-47200925_314622346"));
                    new VKShareDialogBuilder()
                            .setText("I created this post with VK Android SDK\nSee additional information below\n#vksdk")
                            .setUploadedPhotos(photos)
                            .setAttachmentImages(new VKUploadImage[]{
                                    new VKUploadImage(b, VKImageParameters.pngImage())
                            })
                            .setAttachmentLink("VK Android SDK information", "https://vk.com/dev/android_sdk")
                            .setShareDialogListener(new VKShareDialog.VKShareDialogListener() {
                                @Override
                                public void onVkShareComplete(int postId) {
                                    recycleBitmap(b);
                                }
 
                                @Override
                                public void onVkShareCancel() {
                                    recycleBitmap(b);
                                }
 
                                @Override
                                public void onVkShareError(VKError error) {
                                    recycleBitmap(b);
                                }
                            })
                            .show(getFragmentManager(), "VK_SHARE_DIALOG");
                }
                break;
                case R.id.upload_photo_to_wall: {
                    final Bitmap photo = getPhoto();
                    VKRequest request = VKApi.uploadWallPhotoRequest(new VKUploadImage(photo, VKImageParameters.jpgImage(0.9f)), 0, TARGET_GROUP);
                    request.executeWithListener(new VKRequestListener() {
                        @Override
                        public void onComplete(VKResponse response) {
                            recycleBitmap(photo);
                            VKApiPhoto photoModel = ((VKPhotoArray) response.parsedModel).get(0);
                            makePost(new VKAttachments(photoModel));
                        }
 
                        @Override
                        public void onError(VKError error) {
                            showError(error);
                        }
                    });
                }
                break;
                case R.id.upload_doc:
                    startApiCall(VKApi.docs().uploadDocRequest(getFile()));
                    break;
                case R.id.upload_several_photos_to_wall: {
                    final Bitmap photo = getPhoto();
                    VKRequest request1 = VKApi.uploadWallPhotoRequest(new VKUploadImage(photo, VKImageParameters.jpgImage(0.9f)), 0, TARGET_GROUP);
                    VKRequest request2 = VKApi.uploadWallPhotoRequest(new VKUploadImage(photo, VKImageParameters.jpgImage(0.5f)), 0, TARGET_GROUP);
                    VKRequest request3 = VKApi.uploadWallPhotoRequest(new VKUploadImage(photo, VKImageParameters.jpgImage(0.1f)), 0, TARGET_GROUP);
                    VKRequest request4 = VKApi.uploadWallPhotoRequest(new VKUploadImage(photo, VKImageParameters.pngImage()), 0, TARGET_GROUP);
 
                    VKBatchRequest batch = new VKBatchRequest(request1, request2, request3, request4);
                    batch.executeWithListener(new VKBatchRequestListener() {
                        @Override
                        public void onComplete(VKResponse[] responses) {
                            super.onComplete(responses);
                            recycleBitmap(photo);
                            VKAttachments attachments = new VKAttachments();
                            for (VKResponse response : responses) {
                                VKApiPhoto photoModel = ((VKPhotoArray) response.parsedModel).get(0);
                                attachments.add(photoModel);
                            }
                            makePost(attachments);
                        }
 
                        @Override
                        public void onError(VKError error) {
                            showError(error);
                        }
                    });
                }
                break;
            }
        }
 
        private void startApiCall(VKRequest request) {
            Intent i = new Intent(getActivity(), ApiCallActivity.class);
            i.putExtra("request", request.registerObject());
            startActivity(i);
        }
 
        private void showError(VKError error) {
            new AlertDialog.Builder(getActivity())
                    .setMessage(error.toString())
                    .setPositiveButton("OK", null)
                    .show();
            if (error.httpError != null) {
                Log.w("Test", "Error in request or upload", error.httpError);
            }
        }
 
        private Bitmap getPhoto() {
            try {
                return BitmapFactory.decodeStream(getActivity().getAssets().open("android.jpg"));
            } catch (IOException e) {
                e.printStackTrace();
                return null;
            }
        }
 
        private static void recycleBitmap(@Nullable final Bitmap bitmap) {
            if (bitmap != null) {
                bitmap.recycle();
            }
        }
 
        private File getFile() {
            try {
                InputStream inputStream = getActivity().getAssets().open("android.jpg");
                File file = new File(getActivity().getCacheDir(), "android.jpg");
                OutputStream output = new FileOutputStream(file);
                byte[] buffer = new byte[4 * 1024]; // or other buffer size
                int read;
 
                while ((read = inputStream.read(buffer)) != -1) {
                    output.write(buffer, 0, read);
                }
                output.flush();
                output.close();
                return file;
            } catch (IOException e) {
                e.printStackTrace();
            }
            return null;
        }
 
        private void makePost(VKAttachments attachments) {
            makePost(attachments, null);
        }
 
        private void makeRequest() {
            VKRequest request = new VKRequest("apps.getFriendsList", VKParameters.from("extended", 1, "type", "request"));
            request.executeWithListener(new VKRequestListener() {
                @Override
                public void onComplete(VKResponse response) {
                    final Context context = getContext();
                    if (context == null || !isAdded()) {
                        return;
                    }
                    try {
                        JSONArray jsonArray = response.json.getJSONObject("response").getJSONArray("items");
                        int length = jsonArray.length();
                        final VKApiUser[] vkApiUsers = new VKApiUser[length];
                        CharSequence[] vkApiUsersNames = new CharSequence[length];
                        for (int i = 0; i < length; i++) {
                            VKApiUser user = new VKApiUser(jsonArray.getJSONObject(i));
                            vkApiUsers[i] = user;
                            vkApiUsersNames[i] = user.first_name + " " + user.last_name;
                        }
                        new AlertDialog.Builder(context)
                                .setTitle(R.string.send_request_title)
                                .setItems(vkApiUsersNames, new DialogInterface.OnClickListener() {
                                    @Override
                                    public void onClick(DialogInterface dialog, int which) {
                                        startApiCall(new VKRequest("apps.sendRequest",
                                                VKParameters.from("user_id", vkApiUsers[which].id, "type", "request")));
                                    }
                                }).create().show();
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            });
        }
 
        private void makePost(VKAttachments attachments, String message) {
            VKRequest post = VKApi.wall().post(VKParameters.from(VKApiConst.OWNER_ID, "-" + TARGET_GROUP, VKApiConst.ATTACHMENTS, attachments, VKApiConst.MESSAGE, message));
            post.setModelClass(VKWallPostResult.class);
            post.executeWithListener(new VKRequestListener() {
                @Override
                public void onComplete(VKResponse response) {
                    if (isAdded()) {
                        VKWallPostResult result = (VKWallPostResult) response.parsedModel;
                        Intent i = new Intent(Intent.ACTION_VIEW, Uri.parse(String.format("https://vk.com/wall-%d_%s", TARGET_GROUP, result.post_id)));
                        startActivity(i);
                    }
                }
 
                @Override
                public void onError(VKError error) {
                    showError(error.apiError != null ? error.apiError : error);
                }
            });
        }
    }
}
Вопрос: Android Floating Action Button со счетчиком

Здравствуйте.

Делаю FAB со счетчиком, вот разметка:
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
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:foo="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
 
    <android.support.design.widget.FloatingActionButton
        android:id="@+id/fab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/ic_fab"
        app:backgroundTint="@color/colorAccent"
        app:borderWidth="0dp"
        app:elevation="0dp"
        app:fabSize="normal" />
 
    <TextView
        android:layout_width="25dp"
        android:layout_height="25dp"
        android:layout_alignRight="@+id/fab"
        android:layout_marginBottom="-27dp"
        android:gravity="center"
        android:textColor="@android:color/white"/>
 
</RelativeLayout>
Короче говоря вот такую штуку - , только своими ручками)

В чем собственно проблема:
Когда повесить на fab слушатель (OnClickListener), и нажать на fab, он перекрывает TextView (встает поверх). Что я обнаружил: если поставить app:elevation="10dp" для TextView то все хорошо.
Как избежать такое?
Ответ: Так у меня вообще кастомная View extend RelativeLayout, в ней inflate даная разметка, и есть методы для управления TextView.
Но вопрос остается тот же: почему fab при нажатии перекрывает TextView.
Вопрос: Как приложение Android написать на С++ в Android NDK, чтоб получить *.apk? Нужен мануал

Уже не в первый раз задаю вопрос.
Молчание. В лучшем случае - "RTFM" и точка.
Так вот, официального мануала, где есть ответ на вышепоставленный вопрос и все описано по шагам, я на нашел. Неофициального - тоже, будь то на русском или английском.
Тем не менее, говорят, что сделать то, что я хочу, вполне реально, и такие приложения иногда делают.
Прошу дать либо ссылку на мануал, либо вкратце опишите здесь в топике, как это дело делается. Если вы делали так и знаете как это делается, то вам не составит труда написать несколько строчек.
Ответ:
Сообщение от Moon Speak
Так вот, официального мануала, где есть ответ на вышепоставленный вопрос и все описано по шагам, я на нашел. Неофициального - тоже, будь то на русском или английском.
Надо было у гугла спросить для начала.
Тогда бы ты не прошёл мимо книжки: .

Сообщение от Moon Speak
Если вы делали так и знаете как это делается, то вам не составит труда написать несколько строчек.
В зависимости от того, что считать приложением и твоих знаний, ответ может быть одной строчкой или книжкой.