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

В textView передается текст, из которого пользователю необходимы определенные слова. Как сделать фильтр чтобы отображались только они ?
Ответ: Сейчас попробуем
Вопрос: Передать номер из EditText в условие

Всем привет! Есть приложение в котором в EditText вводим номер и осуществляем звонок. С этим все хорошо. Код ниже.
Кликните здесь для просмотра всего текста
Код 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
public class MainActivity extends Activity {
EditText callNumber;
Button button_zapros;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.primary);
        callNumber = (EditText) findViewById(R.id.callNumber);
        OnClickListener oclBtn = new OnClickListener () {
        public void onClick(View v) {
            switch (v.getId()){
                case R.id.button_zapros:
                    Toast.makeText(getBaseContext(), "Connect", Toast.LENGTH_SHORT).show();
                    if (callNumber != null) {
                        String number = String.format("tel:%s", callNumber.getText().toString());
                        Uri callUri = Uri.parse(number);
                        Intent callIntent= new Intent(Intent.ACTION_CALL, callUri);
                    startActivity(callIntent);}
                    break;
                    }}};
button_zapros.setOnClickListener(oclBtn);
}

А хотелось бы что бы введенные в EditText номер участвовал и в BroadcastReceiver при выполнение условия проверки номера телефона с которого поступает входящая смс. Код ниже.
Кликните здесь для просмотра всего текста
Код Java(TM) 2 Platform Standard Edition 5.0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public class SmsReceiver extends BroadcastReceiver {
    @Override
    public void onReceive(Context ctx, Intent intent) {
        Bundle bundle = intent.getExtras();
        Object[] pdus = (Object[]) bundle.get("pdus");
        SmsMessage[] messages = new SmsMessage[pdus.length];
        for (int i = 0; i < messages.length; i++){
            messages[i] = SmsMessage.createFromPdu((byte[])pdus[i]);
            if (messages[i].getDisplayOriginatingAddress().contains("81234567890")) {
            Intent newintent = new Intent(ctx, MainActivity.class);
            newintent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); 
            newintent.putExtra("message", messages[i].getDisplayMessageBody());
            ctx.startActivity(newintent);         
            } } }
    }
Ответ: Всем привет.
Кликните здесь для просмотра всего текста
Код 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
public class MainActivity extends Activity {
    EditText callNumber;
    Button button_zapros;
    Button button_save;
    SharedPreferences sPref;
    final String SAVED_NUMBER = "saved_number";
 
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.primary);
        callNumber = (EditText) findViewById(R.id.callNumber);
        button_zapros = (Button) findViewById(R.id.button_zapros);
        button_save = (Button)findViewById(R.id.button_save);
 
        OnClickListener oclBtn = new OnClickListener () {
        public void onClick(View v) {
            switch (v.getId()){
                case R.id.button_zapros:
                    Toast.makeText(getBaseContext(), "Connect", Toast.LENGTH_SHORT).show();
                    if (callNumber != null) {
                        String number = String.format("tel:%s", callNumber.getText().toString());
                        Uri callUri = Uri.parse(number);
                        Intent callIntent= new Intent(Intent.ACTION_CALL, callUri);
                    startActivity(callIntent);}
                    break;
                case R.id.button_save:
                    saveText();
                    break;
                default:
                    break;
            }
        }
 
        };
    button_zapros.setOnClickListener(oclBtn);
    button_save.setOnClickListener(oclBtn);
    loadText();
    }
    void saveText() {
        sPref = getPreferences(MODE_PRIVATE);
        Editor ed = sPref.edit();
        ed.putString(SAVED_NUMBER, callNumber.getText().toString());
        ed.commit();
        Toast.makeText(this, "Save Number", Toast.LENGTH_SHORT).show();
  
    }
 
    void loadText() {
        sPref = getPreferences(MODE_PRIVATE);
        String savedNumber = sPref.getString(SAVED_NUMBER, "");
        callNumber.setText(savedNumber);
        Toast.makeText(this, "Load Number", Toast.LENGTH_SHORT).show();
    }
    
    @Override
    protected void onDestroy() {
        saveText();
        super.onDestroy();
    }

Сохранить номер получается и даже загружаю его при запуске, а вот как его прикрутить к сравнению не знаю.
Кликните здесь для просмотра всего текста
Код 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
public class SMSMonitor extends BroadcastReceiver {
 
    @Override
    public void onReceive(Context ctx, Intent intent) {
 
        Bundle bundle = intent.getExtras();
        Object[] pdus = (Object[]) bundle.get("pdus");
        SmsMessage[] messages = new SmsMessage[pdus.length];
        for (int i = 0; i < messages.length; i++){
            messages[i] = SmsMessage.createFromPdu((byte[])pdus[i]);
            if (messages[i].getOriginatingAddress().[B][U]contains("89827406922")[/U][/B]);{
                Intent newintent = new Intent(ctx, Secondory.class);
                newintent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                newintent.putExtra("message", messages[i].getDisplayMessageBody());
                ctx.startActivity(newintent);
            }
        }
    }
}

Помогите кто чем может.
Вопрос: Edittext longclick и клавиатура

Проблема - в программе есть edittext по клику открывается клавиатура редактирования. На лонгклик отзывается другое действие И СНОВА клавиатура. Как сохранить клавиатуру по клику но убрать ее с лонгклика?
Ответ: верю.
У меня в одной программе где нередактируемый edittext тоже добавляется нормально
тут редактируемый и почему то так странно работает
Вопрос: Передать текст из EditText на Activity другого приложения

В книге приводится пример простого мессенджера. Есть кнопка "Send Message" и EditText, куда сообщение вводится. По нажатию кнопки пользователю предлагается выбрать приложение, Activity которого поддерживает ACTION_SEND. Текст из первой Activity должен передаваться в выбранное приложение туда, где должен быть текст. В книге я не нашел кода, который бы получал строку из первой Activity и вставлял его в нужный TextField. У меня, соотвественно, когда я открываю выбранное приложение(в данном случае приложение "Сообщение"), никакого текста не появляется, а у авторов книги - появляется.

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
package com.artmal.messenger;
 
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
 
public class CreateMessageActivity extends AppCompatActivity {
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_create_message);
    }
 
    public void sendMessage(View view) {
        EditText editText = (EditText) findViewById(R.id.editText);
        String message = String.valueOf(editText.getText());
 
        Intent intent = new Intent(Intent.ACTION_SEND);
        intent.setType("text/plain");
        intent.putExtra("message", message);
        startActivity(intent);
    }
}
Ответ:
Сообщение от Artmal
А как найти нужный TextField в том приложении? Могут же быть в каждом приложении разные id у элементов.
Это все должно быть реализовано приложении которое принимает - намерение. Как например, когда вы хотите отправить сообщение, вам предлагается список (мыло, вайбер, ватсап, и т.д.), приложений которые это могут сделать. Но как они это сделают, это уже их дело.
Вопрос: Ввод текста в EditText

Всем здравствуйте.
Я начал недавно программировать под Android. И столкнулся с проблемкой, ответ на которую пока не смог найти в интернете.
В общем есть Activity в котором мнго EditText и когда вводишь текст в одном из них с системной клавиатуры то там есть кнопка далее если её нажимаешь то курсор перескакивает на следующий EditText. Как сделать так чтобы курсор или совсем исчезал из всех EditText или хотябы оставался в томже где был ввод или например перескакивал в указанный EditText и после нажатия далее закрывалась клавиатура. С кнопки я нашёл там закрывается а надо чтобы тоже самое было после нажати на клавиатуре "далее". Спасибо всем то сможет мне чем нибудь помочь.

@Override
protected void onCreate(Bundle savedInstanceState) {
. . . .
eP1=(EditText) findViewById(R.id.editPar1);
eP2=(EditText) findViewById(R.id.editPar2);
eP3=(EditText) findViewById(R.id.editPar3);
eP4=(EditText) findViewById(R.id.editPar4);
. . . .
@Override
public void onClick(View view) {
switch (view.getId()){
case R.id.buttonPar:
imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
imm.hideSoftInputFromWindow(editPar1.getWindowToken(), 0);
. . . .
break;
Ответ:
Сообщение от Bronzel
Спасибо у меня всё получилось. Я создал сбоку ещё один новый editText толщиной "1dp" с параметрами "@id/editPunkt" и android:imeOptions="actionDone" , а во всех моих editPar1-4 вставил android:nextFocusDown="@id/editPunkt" и всё работает.
это очень криво, может на каком то устройстве это сработает не так как нужно.
Вопрос: Программно создать EditText

Код Java(TM) 2 Platform Standard Edition 5.0
1
2
3
4
5
6
7
8
9
10
11
12
13
Ребят, как сделать так, что бы при нажатие появлялась не одна EditText, а что бы количество EditText соответствовало количеству нажатий на Button.  Т.е что бы если я 2 раза нажму на кнопку-столько и появилось едитов.
public void onClick(View arg0) {
        // TODO Auto-generated method stub
        switch (arg0.getId()) {
        case R.id.button1:
        
       setContentView(R.layout.activity_main);
        RelativeLayout rl= (RelativeLayout)findViewById(R.id.main_layout);
 
        EditText tv1 = new EditText(this);
        tv1.setWidth(200);
        tv1.setText("HELLO");
        rl.addView(tv1);
Ответ: Elias_smith, Если ты рисуешь на RelativeLayout, то каждый раз нужно задавать новый отступ, иначе у тебя EditText наложатся друг на друга.
Код Java(TM) 2 Platform Standard Edition 5.0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
private int positin=0;
 
public void onClick(View v) {
                RelativeLayout rl= (RelativeLayout)findViewById(R.id.main_layout);
 
                EditText tv1 = new EditText(ma);
                tv1.setText("HELLO");
 
                RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
                params.addRule(RelativeLayout.ALIGN_PARENT_TOP);
                params.topMargin = positin;
 
                tv1.setLayoutParams(params);
                positin=positin+20;
                rl.addView(tv1);
            }
Для LinearLayout этого не требуется.
Вопрос: Обработка нажатия EditText

Необходимо реализовать поля ввода дат для задания периода.
Так как надо по дизайну чтобы подсказка всплывала как в TextInputLayout, поэтому использую EditText.

Но при нажатии сначала появляется клавиатура а при втором нажатии выходит уже диалог выбора даты.


Не могу разобраться как это решить.
И поле FROM у меня сразу активно, хотелось бы до первого нажатия его не активировать. Подскажите?

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
26
<android.support.design.widget.TextInputLayout
            android:id="@+id/input_to"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginEnd="16dp"
            android:layout_marginLeft="16dp"
            android:layout_marginRight="16dp"
            android:layout_marginTop="4dp"
            android:orientation="horizontal"
            android:visibility="visible"
            app:layout_constraintLeft_toLeftOf="@+id/guideline2"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/choosePerson">
 
            <EditText
                android:id="@+id/to"
                style="@style/Widget.AppCompat.EditText"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:ems="10"
                android:hint="@string/hint_to"
                android:inputType="date"
                tools:layout_editor_absoluteX="8dp"
                tools:layout_editor_absoluteY="0dp" />
        </android.support.design.widget.TextInputLayout>
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
//EditText для ввода дат
        from = (EditText) view.findViewById(R.id.from);
        to = (EditText) view.findViewById(R.id.to);
        from.setOnClickListener(chooseDateClick);
        to.setOnClickListener(chooseDateClick);
 
//обработка нажатия EditText для выбора даты
    public View.OnClickListener chooseDateClick = new View.OnClickListener() {
        @Override
        public void onClick(final View view) {
            Calendar calendar = Calendar.getInstance();
            final SimpleDateFormat dateFormat = new SimpleDateFormat("dd.MM.yyyy");
            chooseDate = new DatePickerDialog(getActivity(), new DatePickerDialog.OnDateSetListener() {
                @Override
                public void onDateSet(DatePicker datePicker, int year, int monthOfYear, int dayOfMonth) {
                    Calendar newCalendar = Calendar.getInstance();
                    newCalendar.set(year, monthOfYear, dayOfMonth);
                    switch (view.getId()) {
                        case R.id.from:
                            Toast.makeText(getActivity(), "нажат фром", Toast.LENGTH_SHORT);
                            from.setText(dateFormat.format(newCalendar.getTime()));
                            break;
                        case R.id.to:
                            to.setText(dateFormat.format(newCalendar.getTime()));
                            break;
                    }
                }
            }, calendar.get(Calendar.YEAR), calendar.get(Calendar.MONTH), calendar.get(Calendar.DAY_OF_MONTH));
            chooseDate.show();
        }
    };
Ответ: мой вопрос: как сделать чтобы при переходе на вкладку ни одно из EditText не находилось в фокусе?
мой ответ: android:focusableInTouchMode="true" для лэйаута
Вопрос: Ошибка setText() в EditText

в toolbar в виде пункта меню есть EditText который виден всегда.

EditText
Кликните здесь для просмотра всего текста
XML
1
2
3
4
5
6
7
<EditText
        android:id="@+id/rate"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:maxLines="1"
        android:onClick="EditClick"
        android:hint="@string/kurs"/>

в меню
Кликните здесь для просмотра всего текста
XML
1
2
3
4
5
 <item
        android:id="@+id/menu_kurs"
android:title="265"
        app:actionLayout="@layout/edittext_kurs"
        app:showAsAction="always"/>


Java
Кликните здесь для просмотра всего текста
Java
1
2
3
4
5
6
7
8
9
 if (mSettings.contains(APP_PREFERENCES_COURSE)) {
            cursInt = mSettings.getInt(APP_PREFERENCES_COURSE, 0);
            if (mSettings.getInt(APP_PREFERENCES_COURSE, 0) != 0) {
               stringSP = String.valueOf(cursInt);
                Log.d("myLogs", stringSP );
                et = (EditText) findViewById(R.id.rate);
                et.setText(stringSP); //ВОТ ТУТ РУГАЕТСЯ
            }
        }

Ошибка
Кликните здесь для просмотра всего текста
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
E/AndroidRuntime: FATAL EXCEPTION: main
                  Process: com.dis.arsenalprice, PID: 24080
                  java.lang.RuntimeException: Unable to start activity ComponentInfo{com.dis.arsenalprice/com.dis.arsenalprice.MainActivity}: java.lang.NullPointerException
                      at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2184)
                      at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2233)
                      at android.app.ActivityThread.access$800(ActivityThread.java:135)
                      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
                      at android.os.Handler.dispatchMessage(Handler.java:102)
                      at android.os.Looper.loop(Looper.java:136)
                      at android.app.ActivityThread.main(ActivityThread.java:5001)
                      at java.lang.reflect.Method.invokeNative(Native Method)
                      at java.lang.reflect.Method.invoke(Method.java:515)
                      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
                      at dalvik.system.NativeStart.main(Native Method)
                   Caused by: java.lang.NullPointerException
                      at com.dis.arsenalprice.MainActivity.onCreate(MainActivity.java:130)
                      at android.app.Activity.performCreate(Activity.java:5231)
                      at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
                      at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2148)
                      at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2233)*
                      at android.app.ActivityThread.access$800(ActivityThread.java:135)*
                      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)*
                      at android.os.Handler.dispatchMessage(Handler.java:102)*
                      at android.os.Looper.loop(Looper.java:136)*
                      at android.app.ActivityThread.main(ActivityThread.java:5001)*
                      at java.lang.reflect.Method.invokeNative(Native Method)*
                      at java.lang.reflect.Method.invoke(Method.java:515)*
                      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)*
                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)*
                      at dalvik.system.NativeStart.main(Native Method)*
*


что может быть не так?
Ответ:
Java
1
2
3
4
5
6
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.some_menu, menu);
        EditText kursEditText = (EditText) menu.findItem(R.id.kurs_edit_text).getActionView();
        return true;
    }
название меню и id для этого EditText подставить свои
Вопрос: Что такое ems в editText?

Что такое ems в editText?
Ответ: Извиняюсь, что поднимаю старую тему... Я правильно понял, что ems устанавливает ширину поля равной суммарной ширине указанного количества букв М?
Мне как раз нужно установить ширину поля равной ширине 10-ти букв (typeface = monospace). Сделал так:
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
26
27
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">
 
    <EditText
        android:id="@+id/editText"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginLeft="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:layout_marginRight="8dp"
        android:layout_marginBottom="8dp"
        android:ems="10"
        android:inputType="textNoSuggestions"
        android:text="MMMMMMMMMM"
        android:typeface="monospace"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
</android.support.constraint.ConstraintLayout>
Но в результате поле у меня получается занятым чуть больше чем на половину поля. Ошибку я нигде не нашел, поэтому единственным вариантом я рассматриваю недостаточное или неправильное понимание атрибута ems. В чем моя ошибка?
Вопрос: EditText, кнопки вместо клавиатуры, использование курсора, вызов клавиатуры "вручную"

Ну, в общем, я постарался написать наиболее подходящее название темы.
Перекопал весь киберфорум, и ещё кучу сайтов в гугле, но нифига не нашёл про отключение клавиатуры для EditText от слова ВООБЩЕ.
То есть ни фокус, ни нажатие на поле ввода не должны в моём приложении открывать эту клавиатуру.
Зачем? Ну, насмотрелся я на стандартный гугловский калькулятор, в котором цифры вставлять можно и в середине поля ввода, и захотелось мне такой же велосипед изобрести.

Короче, хочу сделать клавиатуру калькулятора, поддерживающую курсор на поле ввода. И в мыслях было добавить специальную кнопку, которая всё же показывала стандартную клавиатуру для ввода имён переменных.

Как всё это сделать я не понимаю и не знаю. Интернет тоже молчит. Может кто уже делал подобные фичи?
Ответ: пробовал, но писал по-русски, всё что выдавалось это толпы хомячков, у которых клавиатура всплывала при автофокусе на EditText
мб в русском языке и дело...