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

1й вариант с background - нормально показывает

design_bg
XML
1
2
3
4
5
<?xml version="1.0" encoding="utf-8"?>
<shape android:shape="rectangle" xmlns:android="http://schemas.android.com/apk/res/android">
<corners android:radius="30dp"/>
    <stroke android:width="1.5dp"  android:color="@color/design_text_bg_color"/>
</shape>
XML
1
2
3
4
5
6
7
8
9
10
11
 <EditText
                android:layout_width="match_parent"
                android:layout_height="40dp"
                android:text="Мамаев"
                android:inputType="textCapWords|textPersonName"
                android:ems="10"
                android:id="@+id/editText"
                android:paddingLeft="25dp"
                android:background="@drawable/design_bg"
                android:layout_marginBottom="30dp"
                android:textSize="18.5sp"/>



2й вариант с custom view extends EditText - показывает не нормально


XML
1
2
3
4
5
6
7
8
9
10
11
12
13
<su.we.DesignEdit
                android:text="Мамаев"
                android:layout_width="match_parent"
                android:layout_height="40dp"
                android:id="@+id/last"
                android:ems="10"
                android:textColor="@color/des_Black"
                android:inputType="textCapWords|textPersonName"
                app:strokeWidth="1.5dp"
                app:strokeColor="@color/color"
                android:paddingLeft="25dp"
                android:layout_marginBottom="30dp"
                android:textSize="18.5sp" />

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
public class DesignEdit extends EditText {
    private HelperClass helperClass;
 
    public DesignEdit(Context context, AttributeSet attrs) {
        super(context, attrs);
        helperClass = new HelperClass(context);
        TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.DesignEdit);
 
 
 
 
        final int backgroundColor = a.getColor(R.styleable.DesignEdit_backgroundColor, Color.TRANSPARENT); // по дефолту типа черный
        final int strokeColor = a.getColor(R.styleable.DesignEdit_strokeColor, Color.TRANSPARENT); // по дефолту типа черный
        final int strokeWidth = a.getDimensionPixelSize(R.styleable.DesignEdit_strokeWidth, 0); // по дефолту, от балды 4 пикселя
        final int cornerRadius = a.getDimensionPixelSize(R.styleable.DesignEdit_cornerRadius, 60);
 
 
         a.recycle();
        final GradientDrawable gd = new GradientDrawable();
        gd.setCornerRadius(cornerRadius);
        gd.setColor(backgroundColor);
 
        if (strokeWidth>0) {
            gd.setStroke(strokeWidth, strokeColor);
        }
        if (Build.VERSION.SDK_INT >= 16) {
            setBackground(gd);
        } else {
            setBackgroundDrawable(gd);
        }
 
      
 
    }
}
Ответ: в моей вселенной если задать стандартному EditText даже 44dp то текст начнет уходить вверх
то есть поведение такое же как и в кастомном
Вопрос: Что такое 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

Всем здравствуйте.
Я начал недавно программировать под 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

Необходимо реализовать поля ввода дат для задания периода.
Так как надо по дизайну чтобы подсказка всплывала как в 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" для лэйаута
Вопрос: Программно создать 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 при нажатии кнопки

Программа при нажатии на Button, должна выводить в EditText символ, например нажимаем на Button ooo, и в EditText появляется буква 'k', но при нажатии на другую кнопку, символ 'k' стирается из EditText, и появляется другой символ допустим 'т'. Как сделать так чтобы символ не стирался, а оставался на месте, получается нужен маленький прототип Keyboard.

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
public void onClick(View v) {
        switch(v.getId()) {
            case R.id.ooo:
 
                userFilter.setText("к");
                break;
            case R.id.yyy:
                userFilter.setText("и");
                break;
            case R.id.nnn:
                userFilter.setText("т");
                break;
            default:
                break;
 
        }
        }
Ответ: Спасибо большое, такую мелочь не знал
Вопрос: EditText долго отображается

Добрый день! Делаю для себя редактор, заодно и учусь писать приложения для Android, и столкнулся с такой проблемой, при открытии файла большого размера (например 17Кб отображается примерно черзе 25 секунд, а 35Кб - через 3 минуты). Вывод делаю в стандартный EditText (MultiLine text). Проверяю всё на Lenovo A820.
Буду рад любой помощи!
Ответ: Интересная задумка.... Я правильно понял, что в EditText выводить только то, что сейчас отображено на экране в TextView? Если да, то как понять какие строки сейчас на экран отображены?

Добавлено через 4 часа 14 минут
Днем не получилось отписаться... Таки да, если использовать TextView, то грузиться моментально. Проблема именно в EditText
Вопрос: Ошибка 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 подставить свои
Вопрос: Передать номер из 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 смещение области выделения в левый угол, как исправить

Своя клавиатура, в текстовом поле область выделения стремится в левый верхний угол. Картинку прилагаю



Разметка
Код XML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<EditText
            android:id="@+id/et_uemail"
            android:layout_width="775dp"
            android:layout_height="50dp"
            android:background="@drawable/box_shadow"
            android:cursorVisible="true"
            android:ems="23"
            android:inputType="textEmailAddress"
            android:paddingLeft="6dp"
            android:textColor="@color/label"
            android:textCursorDrawable="@null"
            android:textSize="23sp"
            android:imeOptions="flagNoExtractUi">
            </EditText>
Есть ли мысли, как это исправить?

Добавлено через 22 часа 35 минут
Итак. Проблема в полноэкранном режиме клавиатуры, который стоит по умолчанию в альбомной ориентации. В классе extends InpetMethodService переписала метод

Код Java(TM) 2 Platform Standard Edition 5.0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
@Override
public boolean onEvaluateFullscreenMode() {
    DisplayMetrics dm = getResources().getDisplayMetrics();
    float displayHeight = dm.heightPixels;
    // If the display is more than X inches high, don't go to fullscreen
    // mode
    float dimen = getResources().getDimension(
            R.dimen.max_height_for_fullscreen);
    if (displayHeight > dimen) {
        return false;
    } else {
        return super.onEvaluateFullscreenMode();
    }
}
В @Override onStartInputView() на всякий случай вызвала updateFullscreenMode(); При таком раскладе на планшете свои клавиатура работает аналогично стандартной - является панель копирования-вставки, адекватно выделяется слово, без сдвигов, как на скрине.
Ответ: Свое приложение, своя клавиатура. Запускаю на устройстре, апи минимум для 4.0.2. Тестируется на 4.2.2 на планшете.
Так как стандартная клавиатура в приложении работает адекватно, имела основание предположить, что проблема в моей клавиатуре. Ну и отсутствие панельки копировать-вставить заставило меня читать документацию и выяснить, что эта панелька по умолчанию работает на всех клавиатурах. Это действительно так, я поставила свою клавиатуру себе на телефон (5.0.2) и там все чудненько работает. Так же нечаянно покрутила экран у планшета и обнаружила, что в портретной ориентации панелько копипаст имеет место быть в любых приложениях. Таким образом пришла к выводу, что клавиатура не корректно видит размеры альбомного экрана (или что то типа того), и снова документация в помощь - режим у клавиатуры есть fullscreen. Вот.