스피너 텍스트 크기와 텍스트 색상을 변경하는 방법은 무엇입니까?
Android 애플리케이션에서 스피너를 사용하고 있는데 SQLite 데이터베이스의 데이터를 스피너에 로드하면 제대로 작동합니다.여기 그것에 대한 코드가 있습니다.
Spinner spinner = (Spinner) this.findViewById(R.id.spinner1);
List<String> list = new ArrayList<String>();
ArrayAdapter<String> dataAdapter = new ArrayAdapter<String> (this,android.R.layout.simple_spinner_item, list);
cursor.moveToFirst();
list.add("All Lists");
if (cursor.getCount() > 0) {
for (int i = 0; i < cursor.getCount(); i++) {
keyList[i] = cursor.getString(cursor.getColumnIndex(AndroidOpenDbHelper.KEYWORD));
list.add(keyList[i]);
cursor.moveToNext();
}
}
Database.close();
cursor.close();
dataAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
spinner.setAdapter(dataAdapter);
이제 스피너 데이터의 텍스트 색상과 텍스트 크기를 변경하고 싶습니다.XML 파일의 스피너 태그에 다음 XML 행을 사용했지만 작동하지 않습니다.
android:textColor="@android:color/white"
android:textSize="11dp"
스피너의 텍스트 색상과 텍스트 크기를 변경하려면 어떻게 해야 합니까?
스피너 항목에 대한 사용자 지정 XML 파일을 만듭니다.
spinner_item.xml:
이 파일의 텍스트에 사용자 정의된 색상과 크기를 지정합니다.
<?xml version="1.0" encoding="utf-8"?>
<TextView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="20sp"
android:gravity="left"
android:textColor="#FF0000"
android:padding="5dip"
/>
이제 이 파일을 사용하여 다음과 같은 스피너 항목을 표시합니다.
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, R.layout.spinner_item,list);
드롭다운 리소스를 설정할 필요가 없습니다.시간이 걸릴 것입니다spinner_item.xml
당신의 아이템을 스피너로 보여줄 뿐입니다.
간단하고 바삭바삭한...:
private OnItemSelectedListener OnCatSpinnerCL = new AdapterView.OnItemSelectedListener() {
public void onItemSelected(AdapterView<?> parent, View view, int pos, long id) {
((TextView) parent.getChildAt(0)).setTextColor(Color.BLUE);
((TextView) parent.getChildAt(0)).setTextSize(5);
}
public void onNothingSelected(AdapterView<?> parent) {
}
};
모든 스피너가 TextView 항목에 대해 동일한 텍스트 색상을 가질 수 있는 경우 다른 방법은 스피너 드롭다운 항목에 대해 사용자 지정 스타일을 사용하는 것입니다.
res/values/styles.xml
:
<resources>
<style name="AppBaseTheme" parent="android:Theme.Light">
</style>
<style name="AppTheme" parent="AppBaseTheme">
<item name="android:spinnerDropDownItemStyle">@style/mySpinnerItemStyle</item>
</style>
<style name="mySpinnerItemStyle" parent="@android:style/Widget.Holo.DropDownItem.Spinner">
<item name="android:textColor">@color/my_spinner_text_color</item>
</style>
</resources>
그리고 res/values/colors.xml에서 사용자 지정 색상을 정의합니다.
<color name="my_spinner_text_color">#808080</color>
스피너의 색상을 변경하는 데 도움이 되는 링크는 다음과 같습니다.
<Spinner
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:id="@+id/spinner"
android:textSize="20sp"
android:entries="@array/planets"/>
스피너 항목 spinner_item.xml에 대한 사용자 정의를 사용하여 자체 레이아웃 파일을 생성해야 합니다.
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="20sp"
android:textColor="#ff0000" />
드롭다운 목록 항목을 사용자 지정하려면 새 레이아웃 파일을 만들어야 합니다.spinner_dropdown_item.xml:
<?xml version="1.0" encoding="utf-8"?>
<CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
style="?android:attr/spinnerDropDownItemStyle"
android:maxLines="1"
android:layout_width="match_parent"
android:layout_height="?android:attr/listPreferredItemHeight"
android:ellipsize="marquee"
android:textColor="#aa66cc"/>
그리고 마지막으로 스피너 선언의 또 다른 변화는 다음과 같습니다.
ArrayAdapter adapter = ArrayAdapter.createFromResource(this,
R.array.planets_array, R.layout.spinner_item);
adapter.setDropDownViewResource(R.layout.spinner_dropdown_item);
spinner.setAdapter(adapter);
바로 그겁니다.
안드로이드로 작업하는 경우.support.v7.vmdk입니다.AppCompSpinner는 다음과 같은 스타일을 사용하여 테스트된 가장 간단한 솔루션입니다.
<android.support.v7.widget.AppCompatSpinner
android:id="@+id/spefcialFx"
style="@style/Widget.AppCompat.Spinner.Underlined"
android:layout_width="200dp"
android:layout_height="wrap_content"
android:layout_marginLeft="4dp"
android:theme="@style/Spinner"
android:entries="@array/special_fx_arrays"
android:textSize="@dimen/text_size_normal"></android.support.v7.widget.AppCompatSpinner>
그리고 스타일:
<style name="Spinner" parent="Widget.AppCompat.Light.DropDownItem.Spinner">
<item name="android:paddingStart">0dp</item>
<item name="android:paddingEnd">0dp</item>
<item name="android:textColor">@color/white</item>
<item name="android:backgroundTint">@color/red</item>
<item name="android:textSize">14sp</item>
</style>
유일한 단점은 안드로이드입니다. backgroundTint는 드롭다운 화살표와 드롭다운 배경 모두에 색상을 설정합니다.
지연을 방지하려면 에서 텍스트 속성만 설정할 필요가 없습니다.onItemSelected
취자청에도 나활동의그onCreate
방법(하지만 좀 까다롭네요.
을 구적으로, 은이것넣합니다어에 넣어야 합니다.onCreate
어댑터를 설정한 후:
spinner.setSelection(0, true);
View v = spinner.getSelectedView();
((TextView)v).setTextColor(backgroundColor);
을 그고이것넣습다니을리넣에 넣습니다.onItemSelected
:
((TextView) view).setTextColor(backgroundColor);
다음은 전체 예입니다.
@Override
protected void onCreate(Bundle savedInstanceState)
{
Spinner spinner = (Spinner) findViewById(R.id.spinner);
//Set the choices on the spinner by setting the adapter.
spinner.setAdapter(new SpinnerAdapter(toolbar.getContext(), new String[]{"Overview", "Story", "Specifications", "Poll", "Video"}, accentColor, backgroundColor));
//Set the text color of the Spinner's selected view (not a drop down list view)
spinner.setSelection(0, true);
View v = spinner.getSelectedView();
((TextView)v).setTextColor(backgroundColor);
//Set the listener for when each option is clicked.
spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener()
{
@Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id)
{
//Change the selected item's text color
((TextView) view).setTextColor(backgroundColor);
}
@Override
public void onNothingSelected(AdapterView<?> parent)
{
}
});
}
자세한 내용은 제 질문을 참조하십시오.
선택한 항목에서만 텍스트 색상을 변경하려면 이 방법을 사용할 수 있습니다.그것은 나에게 효과가 있었고 당신에게도 효과가 있을 것입니다.
spinner.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
@Override
public void onGlobalLayout() {
((TextView) spinner.getSelectedView()).setTextColor(Color.WHITE);
}
});
스피너 텍스트 뷰 세트 테마의 스타일을 다음과 같이 변경할 수 있습니다.
styles.xml:
<style name="mySpinnerItemStyle" parent="@android:style/Widget.Holo.DropDownItem.Spinner">
<item name="android:textSize">@dimen/_11ssp</item>
<item name="android:textColor">@color/blue</item>
<item name=...</item>
</style>
그리고나서
<Spinner
android:theme="@style/mySpinnerItemStyle"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
스피너 텍스트 뷰 속성을 프로그래밍 방식으로 변경하려는 경우:
프로그래밍 방식:
val textView = (view.getChildAt(0) as TextView)
textView.setTextColor(resources.getColor(R.color.dark_mode))
오직 필요한 사람을 위해Style
을 위한 방법.AppCompat
.
styles.xml
<resources>
...
<style name="Spinner" parent="Widget.AppCompat.Light.DropDownItem.Spinner">
<item name="android:paddingStart">0dp</item>
<item name="android:paddingEnd">0dp</item>
<item name="android:textColor">@color/material_grey_700</item>
<item name="android:textSize">12sp</item>
</style>
</resources>
your_spinner_snmp.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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" />
...
<android.support.v7.widget.AppCompatSpinner
android:id="@+id/content_spinner"
style="@style/Widget.AppCompat.Spinner.Underlined"
android:layout_width="140dp"
android:layout_height="wrap_content"
android:entries="@array/shipping_tracking_carrier_names"
android:spinnerMode="dropdown"
android:theme="@style/Spinner" />
<EditText
android:id="@+id/content_input"
android:layout_width="140dp"
android:layout_height="wrap_content"
android:inputType="text"
android:maxLines="1"
android:paddingEnd="8dp"
android:paddingStart="8dp"
android:textColor="@color/material_grey_700"
android:textSize="12sp" />
...
</LinearLayout>
플러스
그리고 당신이 설정하고 싶다면.android:entries
정의된 스타일로 프로그래밍할 수 있습니다.
이거 먹어봐요.
AppCompatSpinner spinner = findViewById(R.id.content_spinner);
CharSequence[] entries = getResources().getTextArray(R.array.shipping_tracking_carrier_names);
ArrayAdapter<CharSequence> adapter = new ArrayAdapter<>(spinner.getContext(), android.R.layout.simple_spinner_item, entries);
adapter.setDropDownViewResource(android.support.v7.appcompat.R.layout.support_simple_spinner_dropdown_item);
spinner.setAdapter(adapter);
코드에서와 같이, 동일한 것을 사용합니다.Context
Spinner
가장 중요한 것입니다.
spinner.getContext()
변화를 원하는 사람들을 위해DrowDownIcon
할 수 는 ㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠ
spinner.getBackground().setColorFilter(Color.parseColor("#ffffff"), PorterDuff.Mode.SRC_ATOP);
스피너 텍스트 색상 변경하기
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
((TextView) parent.getChildAt(0)).setTextColor(Color.WHITE);}
간단한 방법을 원할 경우 드롭다운에 항목을 추가하기 위해 일반적으로 string.xml에 항목을 추가합니다.다음은 strings.xml 파일을 사용하여 색상을 추가하는 방법의 예입니다.
연령 범위 선택
<string-array name="age_array">
<item> 0-6 </item> //No custom colour
<item><font fgcolor='#FF4CD964'> 12+ </font></item> //With custom colour
</string-array>
다음과 같이 getView 메서드를 재정의하여 텍스트 색상을 변경할 수 있습니다.
new ArrayAdapter<String>(getContext(), android.R.layout.simple_spinner_dropdown_item, list()){
@Override
public View getView(int position, View convertView, @NonNull ViewGroup parent) {
View view = super.getView(position, convertView, parent);
//change the color to which ever you want
((CheckedTextView) view).setTextColor(Color.RED);
//change the size to which ever you want
((CheckedTextView) view).setTextSize(5);
//for using sp values use setTextSize(TypedValue.COMPLEX_UNIT_SP, 16);
return view;
}
}
작은 크기를 얻기 위해 사용자 지정 레이아웃을 만드는 대신 Android의 내부 작은 크기 레이아웃을 스피너에 사용하려면 다음을 사용해야 합니다.
"어쨌든."Android" 대신 R.layout.simple_gallery_item.R.layout.simple_spinner_item"입니다.
ArrayAdapter<CharSequence> madaptor = ArrayAdapter
.createFromResource(rootView.getContext(),
R.array.String_visitor,
android.R.layout.simple_gallery_item);
스피너 레이아웃의 크기를 줄일 수 있습니다.그냥 단순한 속임수야.
드롭다운 목록의 크기를 줄이려면 다음을 사용합니다.
madaptor.setDropDownViewResource(android.R.layout.simple_gallery_item);
안드로이드를 재사용/변경하는 가장 쉬운 방법.R.레이아웃 리소스는 기본적으로 필요합니다.Android Studio에서 Android에서 +를 수행합니다.R.layout.simple_spinner_item.xml.
리소스 파일로 이동합니다.리소스 파일을 복사하고 패키지에 새 레이아웃을 추가하기만 하면 됩니다.R.레이아웃 폴더를 선택하고 텍스트 보기의 textColor를 원하는 대로 변경한 다음 어댑터에서 다음과 같이 호출합니다.
ArrayAdapter<String> adapter = new ArrayAdapter<String(Context,R.layout.spinner_item, spinnerlist);
맨 위에 있는 정답에 작은 변화를 주고 싶을 뿐입니다.레이아웃 디렉토리 내에 스피너 항목에 대한 사용자 정의 XML 파일을 만듭니다.
spinner_style.xml:
이 파일의 텍스트에 사용자 정의된 색상과 크기를 지정합니다.
<?xml version="1.0" encoding="utf-8"?>
<TextView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
style="?android:attr/spinnerItemStyle"
android:singleLine="true"
android:ellipsize="marquee"
android:textAlignment="inherit"
android:textSize="15sp"
android:textColor="#FF0000"
android:padding="5dp"
/>
이제 이 파일을 사용하여 Java 파일 내의 스피너 항목을 표시합니다.
ArrayAdapter<String> adapter = new ArrayAdapter<>(this,R.layout.spinner_style,list);
adapter.setDropDownViewResource(R.layout.spinner_style);
가장 단순:내게 적합함
TextView spinnerText = (TextView) spinner.getChildAt(0);
spinnerText.setTextColor(Color.RED);
<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
style="?android:attr/spinnerItemStyle"
android:singleLine="true"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textColor="#fff"
android:ellipsize="marquee"
android:textAlignment="inherit"/>
그냥 이것을 사용하세요:
ArrayAdapter<String> adapter_category = new ArrayAdapter<String>(this,
R.layout.spinner_list_item, categories);
adapter_category
.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
Ashraf 솔루션의 또 다른 변형은 화면 크기를 고려하는 것입니다.어댑터를 설정한 후에 스피너를 Create에 연결하고 수신기를 설정해야 합니다.
//set your adapter with default or custom spinner cell, then://
serverSpinner.setOnItemSelectedListener(spinnerSelector);
serverSpinner.setSelection(defaultServer);
그런 다음 스피너를 클릭하기 전에 표시되는 보기의 텍스트 크기를 변경할 수 있습니다.
private AdapterView.OnItemSelectedListener spinnerSelector = new AdapterView.OnItemSelectedListener() {
public void onItemSelected(AdapterView<?> parent, View view, int pos, long id) {
boolean tabletSize = getResources().getBoolean(R.bool.isTablet);
boolean largeTablet = getResources().getBoolean(R.bool.isLargeTablet);
if (tabletSize) { ((TextView)parent.getChildAt(0)).setTextSize(16); }
else if (largeTablet) { ((TextView)parent.getChildAt(0)).setTextSize(18); }
else { ((TextView)parent.getChildAt(0)).setTextSize(12); }
}
public void onNothingSelected(AdapterView<?> parent) {
}
};
다음과 같은 레이아웃 관련 폴더를 만들기만 하면 됩니다.
values-sw360dp
values-sw600dp
values-sw800dp
그런 다음 "bool.xml"이라는 xml 파일을 각 폴더에 추가합니다.
<?xml version="1.0" encoding="utf-8"?>
<resources>
<bool name="isTablet">false</bool>
<bool name="isLargeTablet">false</bool>
</resources>
먼저 우리는 간단한 것을 만들어야 합니다.xml
의 리소스 파일textview
아래와 같이:
<?xml version="1.0" encoding="utf-8"?>
<TextView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="20sp"
android:gravity="left"
android:textColor="#FF0000"
android:padding="5dip"
/>
어댑터 목록에 설정한 후 저장합니다.
이러한 유형의 스피너용 어댑터를 완전히 사용자 지정할 수 있습니다.
ArrayAdapter<String> genderAdapter = new ArrayAdapter<String>(getActivity(), R.layout.spinner_text, genderList) {
public View getView(int position, View convertView, ViewGroup parent) {
View v = super.getView(position, convertView, parent);
((TextView) v).setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
((TextView) v).setTextColor(Color.parseColor("#676767"));
((TextView) v).setTypeface(vrFont);
return v;
}
public View getDropDownView(int position, View convertView, ViewGroup parent) {
View v = super.getDropDownView(position, convertView, parent);
((TextView) v).setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
((TextView) v).setTypeface(vrFont);
((TextView) v).setTextColor(Color.parseColor("#676767"));
if (position == 0) {
((TextView) v).setTextColor(Color.parseColor("#979797"));
}
return v;
}
R.layout.spinner_text는 다음과 같습니다.
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/text1"
style="?android:attr/spinnerItemStyle"
android:layout_width="fill_parent"
android:layout_height="40dp"
android:gravity="center_vertical|left"
android:ellipsize="marquee"
android:maxLines="1"
android:textColor="@color/whiteThree" />
이 방법을 사용해 보십시오.그것은 나에게 효과가 있습니다.
@Override
public void onItemSelected(AdapterView<?> adapterView, View view, int i, long l) {
TextView textView = (TextView) view;
((TextView) adapterView.getChildAt(0)).setTextColor(Color.RED);
((TextView) adapterView.getChildAt(0)).setTextSize(20);
Toast.makeText(this, textView.getText()+" Selected", Toast.LENGTH_SHORT).show();
}
String typeroutes[] = {"Select","Direct","Non Stop"};
Spinner typeroute;
typeroute = view.findViewById(R.id.typeroute);
final ArrayAdapter<String> arrayAdapter5 = new ArrayAdapter<String>(
getActivity(), android.R.layout.simple_spinner_item, typeroutes) {
@Override
public boolean isEnabled(int position) {
if (position == 0) {
// Disable the first item from Spinner
// First item will be use for hint
return false;
} else {
return true;
}
}
public View getView(int position, View convertView, ViewGroup parent) {
View v = super.getView(position, convertView, parent);
((TextView) v).setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
((TextView) v).setTextColor(Color.parseColor("#ffffff"));
return v;
} ---->in this line very important so add this
@Override
public View getDropDownView(int position, View convertView,
ViewGroup parent) {
View view = super.getDropDownView(position, convertView, parent);
TextView tv = (TextView) view;
if (position == 0) {
// Set the hint text color gray
tv.setTextColor(Color.GRAY);
} else {
tv.setTextColor(Color.BLACK);
}
return view;
}
};
arrayAdapter5.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
typeroute.setAdapter(arrayAdapter5);
그게 다 당신의 코딩을 즐기는 것입니다.
저는 이것을 다음과 같이 했습니다.getDropDownView() 메서드와 getView() 메서드를 사용했습니다.
사용하다getDropDownView()
오픈된 스피너를 위해.
@Override
public View getDropDownView(int position, View convertView, ViewGroup parent) {
View view = convertView;
if (view == null) {
LayoutInflater vi = (LayoutInflater) activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
view = vi.inflate(R.layout.context_row_icon, null);
}
TextView mTitle = (TextView) view.findViewById(R.id.context_label);
ImageView flag = (ImageView) view.findViewById(R.id.context_icon);
mTitle.setText(values[position].getLabel(activity));
if (!((LabelItem) getItem(position)).isEnabled()) {
mTitle.setTextColor(activity.getResources().getColor(R.color.context_item_disabled));
} else {
mTitle.setTextColor(activity.getResources().getColor(R.color.context_item));
}
return view;
}
및 사용getView()
폐쇄된 스피너를 위해.
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = convertView;
if (view == null) {
LayoutInflater vi = (LayoutInflater) activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
view = vi.inflate(R.layout.context_row_icon, null);
}
TextView mTitle = (TextView) view.findViewById(R.id.context_label);
ImageView flag = (ImageView) view.findViewById(R.id.context_icon);
mTitle.setText(values[position].getLabel(activity));
mTitle.setTextColor(activity.getResources().getColor(R.color.context_item_disabled));
return view;
}
다음과 같은 새로운 스타일을 추가합니다.
<style name="mySpinnerItemStyle" parent="ThemeOverlay.AppCompat.Dark">
<item name="android:textColor">#000</item>
<item name="android:color">#000</item>
</style>
사용:
<Spinner
android:id="@+id/spinnerCategories"
android:layout_width="match_parent"
android:layout_height="wrap_content"
style="@style/mySpinnerItemStyle"
android:layout_margin="5dp" />
언급URL : https://stackoverflow.com/questions/9476665/how-to-change-spinner-text-size-and-text-color
'programing' 카테고리의 다른 글
루비의 include와 require의 차이점은 무엇입니까? (0) | 2023.06.01 |
---|---|
URL/전화로 클릭할 수 있는 UI 레이블을 만드는 방법은 무엇입니까? (0) | 2023.06.01 |
인스턴스 메서드를 원숭이 패치할 때 새 구현에서 재정의된 메서드를 호출할 수 있습니까? (0) | 2023.06.01 |
jQuery 연기 및 약속 - .then() vs.done() (0) | 2023.06.01 |
테이블 셀에서 CSS 텍스트 오버플로? (0) | 2023.06.01 |