Все технические форумы на одном сайте Удобный поиск информации с популярных форумов в одном месте
Вопрос: Первые шаги к собственному лаунчеру

Пытаюсь изучать программирование под android и решил написать свой лаунчер.
Вот только возникло несколько проблем, может подскажите где почитать или объясните на пальцпх, так сказать.
Вопрос первый - как реализовать возможность размещения виджетов в своем лаунчере.
Перерыл весь интернет, но так и не смог найти информации по этому поводу - кругом только инфа о том, как создать виджет.

Вопрос второй - как реализуется главное активити в стиле 3d.
Пример в аттаче.
Больше интересует первый скрин - где обоина используется системная, а сами рабочие столы имеют прокрутку.
Понятное дело, что переход реализуется по свайпу, но как отображать их в таком виде?

Понимаю, что задау сразу вагонами ставлю, но мне так проще разбираться.

Заранее спасибо всем откликнувшимся.
Ответ: Hello world - первый шаг. Потом станет понятно что делать дальше.
Вопрос: Первые шаги

Нужно ли знать java для разработки приложений под Android и в каком объеме? Предполагаю, что да. Если я прав, то какую версию java рекомендуется изучать?
Ответ: тогда нечем было бы занять вас
Вопрос: Количество миллисекунд между первым и вторым нажатием на кнопку

Как на java (android studio) проще и лучше узнать количество миллисекунд между первым и вторым нажатием на одну и ту же кнопку? Спасибо!
Ответ: Запомнить время первого нажатия, потом вычесть его из времени второго нажатия. Определить время - System.CurrentTimeMillis.
Вопрос: Передача данных из первого activity во второй и сохранения getSharedPreferences

Всем привет.
Есть 2 activity, хочу передать данные из первого activity во второе. Данные передаются, проверил через логи.
Но когда происходит сохранения приложения вылетает в ошибку. В чем может быть дело?

С первого activity передаю переменные во второе activity без intent.
Вот так:

Код Java(TM) 2 Platform Standard Edition 5.0
1
2
3
MainActivity2Activity test = new MainActivity2Activity();
String hi = "первое Активити";
test.saveTextS(hi);           
На втором activity получаю так:
Код Java(TM) 2 Platform Standard Edition 5.0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public void saveTextS(String hi) {
 
       sPref = getSharedPreferences("MyPref", MODE_PRIVATE);
       SharedPreferences.Editor ed = sPref.edit();
 
      
       String ee = String.valueOf(hi);
       ed.putString("his", ee);
       ed.commit();
 
        //Log.d("tsave", hi + " : "+ee);
 
 
}
Ответ: Спасибо что направили в нужное русло.
Но в моем коде уже была реализация сохранения.

Решил сделать так, может кому то и пригодится:

Save
Код Java(TM) 2 Platform Standard Edition 5.0
1
2
3
4
5
6
7
8
 void saveTH(String string) 
{
        SharedPreferences userDetails = getSharedPreferences(SAVED_TEXT, MODE_PRIVATE);
        SharedPreferences.Editor edit = userDetails.edit();
        edit.putString("all", string);
        Log.d("hsave", string);
        edit.commit();
}
Load
Код Java(TM) 2 Platform Standard Edition 5.0
1
2
3
SharedPreferences userDetails = getSharedPreferences(SAVED_TEXT, MODE_PRIVATE);
String Uname = userDetails.getString("all", "");
 Log.d("thload", ""+Uname);
Вопрос: Просьба обсудить первое приложение Android

Прошу не судить строго, это мое первое приложение. Написал калькулятор,если очень плохо написано, попрошу внести предложения, Ваши коментарии по сокращению или улучшению кода.Проблема в том что, если результат целое число то должно выводить тип int, а выводит всеравно float;


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
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
package com.example.leon.calculat;
import android.app.Activity;
import android.os.Bundle;
import android.text.Editable;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.view.View;
import java.util.LinkedList;
public class MainActivity extends Activity implements OnClickListener {
    EditText etNum;
    Button btnOne,btnTwo,btnThree,btnFour ,btnFive,btnSix,btnSeven, btnEight, btnNine, btnZero;
    Button btnAdd, btnDiv, btnMul, btnSub, btnAnswer,btnClin,btn_back,btn_l_bracket,btn_r_bracket;
    Button btn_dot;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        // находим элементы
        etNum = (EditText)findViewById(R.id.etNum);
        btnOne = (Button)findViewById(R.id.btnOne);
        btnTwo = (Button)findViewById(R.id.btnTwo);
        btnThree = (Button)findViewById(R.id.btnThree);
        btnFour = (Button)findViewById(R.id.btnFour);
        btnFive = (Button)findViewById(R.id.btnFive);
        btnSix = (Button)findViewById(R.id.btnSix);
        btnSeven = (Button)findViewById(R.id.btnSeven);
        btnEight = (Button)findViewById(R.id.btnEight);
        btnNine = (Button)findViewById(R.id.btnNine);
        btnZero = (Button)findViewById(R.id.btnZero);
        btnAdd = (Button)findViewById(R.id.btnAdd);
        btnDiv = (Button)findViewById(R.id.btnDiv);
        btnMul = (Button)findViewById(R.id.btnMul);
        btnSub = (Button)findViewById(R.id.btnSub);
        btnAnswer = (Button)findViewById(R.id.btnAnswer);
        btnClin = (Button)findViewById(R.id.btnClin);
        btn_back = (Button)findViewById(R.id.btn_back);
        btn_l_bracket = (Button)findViewById(R.id.btn_l_bracket);
        btn_r_bracket = (Button)findViewById(R.id.btn_r_bracket);
        btn_dot = (Button)findViewById(R.id.btn_dot);
        //прописываем обработчик
        btnOne.setOnClickListener(this);
        btnTwo.setOnClickListener(this);
        btnThree.setOnClickListener(this);
        btnFour.setOnClickListener(this);
        btnFive.setOnClickListener(this);
        btnSix.setOnClickListener(this);
        btnSeven.setOnClickListener(this);
        btnEight.setOnClickListener(this);
        btnNine.setOnClickListener(this);
        btnZero.setOnClickListener(this);
        btnAdd.setOnClickListener(this);
        btnDiv.setOnClickListener(this);
        btnMul.setOnClickListener(this);
        btnSub.setOnClickListener(this);
        btnAnswer.setOnClickListener(this);
        btnClin.setOnClickListener(this);
        btn_back.setOnClickListener(this);
        btn_l_bracket.setOnClickListener(this);
        btn_r_bracket.setOnClickListener(this);
        btn_dot.setOnClickListener(this);
    }
 
 
public void onClick(View v) {
    Editable str =  etNum.getText();
    switch (v.getId()){
        // определяем нажатую кнопку и выполняем соответствующую операцию
        case R.id.btnOne: str= str.append(btnOne.getText());
            etNum.setText(str);break;
        case R.id.btnTwo: str =str.append(btnTwo.getText());
            etNum.setText(str); break;
        case R.id.btnThree: str = str.append(btnThree.getText());
            etNum.setText(str); break;
        case R.id.btnFour: str.append(btnFour.getText());
            etNum.setText(str);break;
        case R.id.btnFive: str = str.append(btnFive.getText());
            etNum.setText(str);break;
        case R.id.btnSix: str = str.append(btnSix.getText());
            etNum.setText(str);break;
        case R.id.btnSeven: str = str.append(btnSeven.getText());
            etNum.setText(str);break;
        case R.id.btnEight:str = str.append(btnEight.getText());
            etNum.setText(str);break;
        case R.id.btnNine: str = str.append(btnNine.getText());
            etNum.setText(str);break;
        case R.id.btnZero: str = str.append(btnZero.getText());
            etNum.setText(str);break;
        case R.id.btn_l_bracket: str.append(btn_l_bracket.getText());
            etNum.setText(str);break;
        case R.id.btn_r_bracket: str.append(btn_r_bracket.getText());
            etNum.setText(str);break;
        case R.id.btn_dot: str.append(btn_dot.getText());
            etNum.setText(str);break;
        case R.id. btn_back:
           StringBuilder bac = new StringBuilder(str);
            int lastback=str.length();
           if (bac.length()>1)
           bac.setLength(lastback-1);
            etNum.setText(bac);break;
        case R.id.btnAdd:str=str.append(btnAdd.getText());
            int lastAdd=str.length()-2;
            char chLastAdd= str.charAt(lastAdd);
            //игнорирует один оператор '-' в начале пустой оператор
            if(str.charAt(1)=='-'&&str.length()==2){
                etNum.setText(" -");}
            //меняет  на оператор '+', если до этого был введен другой оператор
             else if ((chLastAdd=='-')||(chLastAdd=='/')||(chLastAdd=='*')||(chLastAdd=='+')){
                StringBuilder sb = new StringBuilder(str);
                sb.setCharAt(lastAdd,'+');
                sb.setLength(lastAdd + 1);
                etNum.setText(sb);
                //не дает ввести вначале пустой строки оператор'+'
             }else if(str.charAt(1)=='+'){
                 etNum.setText(" ");}
              else
                etNum.setText(str);
            break;
 
        case R.id.btnDiv: str=str.append(btnDiv.getText());
            int lastDiv =str.length()-2;
            char chLastDiv =str.charAt(lastDiv);
            //игнорирует один оператор '-' в начале пустой строки
            if(str.charAt(1)=='-'&&str.length()==2){
                etNum.setText(" -");}
            //меняет  на оператор '/', если до этого был введен другой оператор
            else if((chLastDiv=='/')||(chLastDiv=='*')||(chLastDiv=='-')||(chLastDiv=='+')){
                StringBuilder sb = new StringBuilder(str);
                sb.setCharAt(lastDiv,'/');
                sb.setLength(lastDiv + 1);
                etNum.setText(sb);
                //не дает ввести вначале пустой строки оператор'/'
            }else if(str.charAt(1)=='/'){
                etNum.setText(" ");
            }else
                etNum.setText(str);
            break;
 
        case R.id.btnSub: str.append(btnSub.getText());
            int lastSub = str.length()-2;
            char chLastSub = str.charAt(lastSub);
            //меняет  на оператор '-', если до этого был введен другой оператор
            if((chLastSub=='-')||(chLastSub=='+')||(chLastSub=='/')||(chLastSub=='*')){
                StringBuilder sb = new StringBuilder(str);
                sb.setCharAt(lastSub,'-');
                sb.setLength(lastSub + 1);
                etNum.setText(sb);
            }else
                etNum.setText(str);
            break;
 
        case R.id.btnMul: str.append(btnMul.getText());
            int lastMul = str.length()-2;
            char chLastMul = str.charAt(lastMul);
            //игнорирует один оператор '-' в начале пустой строки
            if(str.charAt(1)=='-'&&str.length()==2){
            etNum.setText(" -");}
            //меняет  на оператор '*', если до этого был введен другой оператор
            else if((chLastMul=='/')||(chLastMul=='*')||(chLastMul=='-')||(chLastMul=='+')){
                StringBuilder sb = new StringBuilder(str);
                sb.setCharAt(lastMul, '*');
                sb.setLength(lastMul+1);
                etNum.setText(sb);
                //не дает ввести вначале пустой строки оператор'*'
            }else if(str.charAt(1)=='*'){
                etNum.setText(" ");}
 
            else
                etNum.setText(str);
            break;
        case R.id.btnAnswer:
            //выводит результат введенного числового выражения
            PolishNatation answ = new PolishNatation();
            String exp = etNum.getText().toString();
            answ.value(exp);
            String expOut = String.valueOf(answ.value(exp));
            etNum.setText(" "+expOut);
            break;
        case R.id.btnClin:
            etNum.setText(" ");
 
        default:
            System.out.print("bag");
    }
}
 
class PolishNatation{
    // присваивание операторам приоритетов
    boolean isOperator(char c){
        return c=='+'||c=='-'||c=='/'||c=='*';
    }
    int prority(char oper){
        if(oper=='*'||oper=='/'){
            return 1;
        }else if(oper=='+'||oper=='-'){
            return 0;
        }else {
            return -1;
        }
    }
    // выполнение действий
    void calculatoin(LinkedList<Float>st,char oper) {
        float firstValue = st.removeLast();
        float secondValue = st.removeLast();
        switch (oper) {
            case '+':
                st.add(secondValue + firstValue);
                break;
            case '-':
                st.add(secondValue - firstValue);
                break;
            case '/':
                st.add(secondValue / firstValue);
                break;
            case '*':
                st.add(secondValue * firstValue);
                break;
            default:
                System.out.print("bag");
        }
    }
    float value(String exp) {
        //убирает пробелы с введенного выражения;меняеет "(-" на "(0-"
        exp = exp.replace(" ","").replace("(-","(0-");
        if (exp.charAt(0)=='-'){
            //если первым введен '-' то меняем "-" на "0-"
            exp = "0"+exp;
        }
 
        LinkedList<Float> someValue = new LinkedList<>();// для чисел
        LinkedList<Character> someOperator = new LinkedList<>();//для операторов
        for (int i = 0; i < exp.length(); i++) {
            char compare = exp.charAt(i);
            if (compare == '(') {
                someOperator.add('(');
            } else if (compare == ')') {
                while (someOperator.getLast() != '(') {
                    calculatoin(someValue, someOperator.removeLast());
                }
                someOperator.removeLast();
            } else if (isOperator(compare)) {
                while (!someOperator.isEmpty() && prority(someOperator.getLast()) >= prority(compare)) {
                    calculatoin(someValue, someOperator.removeLast());
                }
                someOperator.add(compare);
            }
            else {
                //если operand число (целое или дробное) передаем его в  someValue
                String operand = "";
                while (i < exp.length() && (Character.isDigit(exp.charAt(i))||exp.charAt(i)=='.')) {
                    operand = operand + exp.charAt(i++);
                }
                i--;
                someValue.add(Float.parseFloat(operand));
            }
        }
        while (!someOperator.isEmpty()) {
            calculatoin(someValue, someOperator.removeLast());
        }
        float a = someValue.getFirst();
        int b = (int)a;
         if(a %1==0){
            return b;}else
        return a;
    }
}
 
@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.menu_main, menu);
    return true;
}
 
@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();
 
    //noinspection SimplifiableIfStatement
    if (id == R.id.action_settings) {
        return true;
    }
 
    return super.onOptionsItemSelected(item);
}}
Ответ:
Сообщение от Leon_SA
Ваши коментарии по сокращению или улучшению кода
а можно не по сокращению а по увеличению? (функциональности)
сделайте функцию сохранения истории расчетов на флеху.
Вопрос: Первое приложение

Здравствуйте. Господа, расскажите у кого какое было первое приложение. Первое приложение которое вы кропотливо писали (лично для себя или для заказчика).
Ответ:

Не по теме:

Сообщение от Vladimirys
Лень, умножить на обжортис.
Представляю, какие там рыла были в отзывах

Вопрос: Изменить фон первого элемента Spinner'a

Как изменить цвет фона первого элемента спинера?
И еще, как загруглить углы у первого и последнего? У меня их несколько подряд, можно ли это как-нибудь сделать?
Ответ:
Вопрос: Как создать layout, который запускается один раз, при первом запуске приложения?

Как создать layout, который запускается один раз, при первом запуске приложения?
т.е. один раз запустилось и всё.
Ответ: Jungle, тут много можно написать, почитайте, например, здесь: http://developer.alexanderklimov.ru/...d/activity.php.
Основных способов два: startActivity и startActivityForResult.
Вопрос: Regex: проверить символьную строку, чтобы первые три ее символа были буквы

Как проверить символьную строку чтобы первые три ее символа были буквы(а не цифры и т.п.)???
Ответ:
Сообщение от NicholasWhite
Я не пойму ты прикалываешься что ли?
Ну да, делать мне больше нечего, скриншот он выложил
Вопрос: Удалить первые 10 символов

как можно удалить первые 10 символов из string переменной?
Ответ:
Код Java(TM) 2 Platform Standard Edition 5.0
1
2
3
public String removeChars(String s, int count){
   return s.substring(count);
}