android 폰트 편집 텍스트 커서 색상 변경




안드로이드 타이틀바 투명 (7)

이 문제를 해결할 방법을 찾았습니다. 가장 큰 해결책은 아니지만 작동합니다.

불행히도 커서 색상에 대해서만 고정 색상을 사용할 수 있습니다.

먼저 드로어 블에 검은 색 커서를 정의합니다.

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
    <solid android:color="#ff000000"/>
    <size android:width="1dp"/>
</shape>

다음으로 레이아웃의 샘플 EditText를 정의합니다.

<?xml version="1.0" encoding="utf-8"?>
<EditText xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textCursorDrawable="@drawable/blackpipe"
         >
    </EditText>

런타임에 EditText를 만들려면 다음을 사용합니다 :

AttributeSet editText30AttributeSet = null;
int res = getResources().getIdentifier("edit30", "layout", getPackageName());//edit30 is EditText layout
XmlPullParser parser = getResources().getXml(res);
int state=0;
do {
    try {
        state = parser.next();
    } catch (Exception e1) {
        e1.printStackTrace();
    }       
    if (state == XmlPullParser.START_TAG) {
        if (parser.getName().equals("EditText")) {
            editText30AttributeSet = Xml.asAttributeSet(parser);
            break;
        }
    }
} while(state != XmlPullParser.END_DOCUMENT);
EditText view = new EditText(getContext(),editText30AttributeSet);

이제 검은 커서가있는 EditText보기가 있습니다. 커서를 런타임에 변경할 수 있도록 누군가가 내 솔루션을 향상시킬 수 있습니다.

프로그래밍 방식으로 EditText's 커서 색상을 변경하려면 어떻게해야합니까?

android 4.0 이상에서는 커서 색상 이 흰색입니다. EditText 의 배경이 흰색이라면 보이지 않게됩니다.


android:textCursorDrawable 속성을 @null 설정하면 android:textCursorDrawable 를 커서 색상으로 사용할 수 있습니다.

특성 textCursorDrawable 은 API 레벨 12 이상에서 사용할 수 있습니다.

감사...


최종 버전이 있습니다. XML이 필요없고 @null로 작동하지만 프로그래밍 방식으로 작동합니다.

try {
    Field f = TextView.class.getDeclaredField("mCursorDrawableRes");
    f.setAccessible(true);
    f.set((TextView)yourEditText, 0);
} catch (Exception ignored) {
}

유일한 문제는 언젠가 새로운 Android 버전에서 작동을 멈출 수 있다는 것입니다.

추신 : 나는 그것을 4.1.2에서 5.1로 테스트했다.


AppCompat-v7을 사용하는 styles.xml 은 어떻습니까?

<item name="colorControlNormal">@color/accentColor</item>
<item name="colorControlActivated">@color/accentColor</item>
<item name="colorControlHighlight">@color/accentColor</item>

나를 위해 일합니다 (이 예제는 단순합니다).


EditText 속성에는 android:textCursorDrawable 속성이 있습니다 android:textCursorDrawable

이제 @null 처럼 설정하십시오.

android:textCursorDrawable="@null"

이제 EditText Cursor는 EditText TextColor와 동일합니다.

참조 EditText 커서 색상 설정


여기에, 제가 생각하기에, @Adem이 게시 한 것보다 나은 해결책이 있습니다.

자바:

try {
    // https://github.com/android/platform_frameworks_base/blob/kitkat-release/core/java/android/widget/TextView.java#L562-564
    Field f = TextView.class.getDeclaredField("mCursorDrawableRes");
    f.setAccessible(true);
    f.set(yourEditText, R.drawable.cursor);
} catch (Exception ignored) {
}

XML :

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >

    <solid android:color="#ff000000" />

    <size android:width="1dp" />

</shape>

AppTheme을 통해 설정

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar"><!-- Customize your theme here. -->
    <item name="windowNoTitle">true</item>
    <item name="windowActionBar">false</item>
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <item name="android:spinnerStyle">@style/spinner_style</item>
    <!--Add This-->
    <item name="editTextStyle">@style/EdittextStyle</item>
    <item name="android:dropDownListViewStyle">@style/SpinnerStyle</item>
</style>

<!--New EditText Style-->
<style name="EdittextStyle" parent="Widget.AppCompat.EditText">
    <item name="android:background">?attr/editTextBackground</item>
    <item name="android:textColor">?attr/editTextColor</item>
    <item name="android:textAppearance">?android:attr/textAppearanceMediumInverse</item>
    <!--<item name="android:textCursorDrawable">@drawable/abc_text_cursor_material</item>-->
    <item name="colorControlNormal">@color/colorAccent</item>
    <item name="colorControlActivated">@color/colorAccent</item>
    <item name="colorControlHighlight">@color/colorAccent</item>

</style>




user-interface