teclado studio quitar ocultar foco edittext desactivar como cambiar abrir android android-edittext android-custom-view android-input-method

studio - quitar el foco de un edittext android



Custom EditText no muestra el teclado en foco (5)

Estoy creando una clase EditText personalizada porque necesito establecer algunas fuentes personalizadas; Sin embargo, ahora cuando hago clic en editText, el teclado de Android ya no aparece ...

aquí está mi clase:

package ro.gebs.captoom.utils.fonts; import android.content.Context; import android.content.res.TypedArray; import android.graphics.Rect; import android.graphics.Typeface; import android.util.AttributeSet; import android.view.inputmethod.InputMethodManager; import android.widget.EditText; import ro.gebs.captoom.R; public class CustomFontEditText extends EditText { private Context context; public CustomFontEditText(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); if (!isInEditMode()) { TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.CustomFontEditText, defStyle, 0); assert a != null; int fontId = a.getInteger(R.styleable.CustomFontEditText_fontNameEdit, -1); if (fontId == -1) { throw new IllegalArgumentException("The font_name attribute is required and must refer " + "to a valid child."); } a.recycle(); initialize(fontId); } this.context = context; } public CustomFontEditText(Context context, AttributeSet attrs) { this(context, attrs, 0); this.context = context; } public CustomFontEditText(Context context) { super(context); this.context = context; } @SuppressWarnings("ConstantConditions") public void initialize(int fontId) { Typeface tf = null; switch (fontId) { case 0: tf = Typeface.createFromAsset(getContext().getAssets(), "fonts/OpenSans-Regular.ttf"); break; case 1: tf = Typeface.createFromAsset(getContext().getAssets(), "fonts/OpenSans-Bold.ttf"); break; case 2: tf = Typeface.createFromAsset(getContext().getAssets(), "fonts/OpenSans-Semibold.ttf"); break; case 3: tf = Typeface.createFromAsset(getContext().getAssets(), "fonts/OpenSans-ExtraBold.ttf"); break; } setTypeface(tf); } }

y cómo lo uso en XML:

<ro.gebs.captoom.utils.fonts.CustomFontEditText android:id="@+id/add_details_txt_edit" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_marginLeft="10dip" android:hint="@string/type_here" android:inputType="textPersonName" custom:fontNameEdit="Regular" />

Pensé que los eventos de enfoque se manejaron por el hecho de que extiendo la clase EditText ...

¿Algún consejo?


Agrega esto

android:focusable="true"


intente hacer referencia para editar texto en tiempo de ejecución y llame al enfoque de solicitud ()

et.requestFocus()

y prueba

android:focusable="true"


implements KeyListener on your custom EditText Class and override methods of KeyListener


editText.setOnTouchListener(new OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { editText.setFocusableInTouchMode(true); return false; } });


Es una vieja pregunta, pero si a alguien le importa, el problema está en la implementación del constructor:

public CustomFontEditText(Context context, AttributeSet attrs) { this(context, attrs, 0); this.context = context; }

El último argumento ("defStyle") que establece como 0, debe ser el estilo predeterminado para un EditText. Si echas un vistazo al mismo constructor en la clase EditText:

public EditText(Context context, AttributeSet attrs) { this(context, attrs, com.android.internal.R.attr.editTextStyle); }

Como puede ver, se debe usar el estilo predeterminado para EditText, por lo que su constructor debería verse así:

public CustomFontEditText(Context context, AttributeSet attrs) { this(context, attrs, android.R.attr.editTextStyle); this.context = context; }