如何解决我不知道为什么我的微调器关闭字体样式和颜色不同
在活动(主要)中,我有以下微调器;
ArrayAdapter.createFromResource(
this,R.array.difficulty_array,android.R.layout.simple_spinner_item
).also { adapter ->
// Specify the layout to use when the list of choices appears
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item)
// Apply the adapter to the spinner
dif_spinner.adapter = adapter
}
还有我的布局 XML
<Spinner
android:id="@+id/difficulty_spinner"
style="@style/Widget.AppCompat.Spinner.Underlined"
android:theme="@style/SpinnerTheme"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_marginStart="8dp"
android:layout_marginEnd="16dp"
android:gravity="center"
android:popupBackground="@color/PrimaryDark"
android:textAlignment="center"
app:autoSizeTextType="uniform"
app:layout_constraintBottom_toBottomOf="@+id/textview_difficultyTITLE"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.5"
app:layout_constraintStart_toEndOf="@+id/textview_difficultyTITLE"
app:layout_constraintTop_toTopOf="@+id/textview_difficultyTITLE" />
然后在一个片段中我有以下内容;
if (newContext != null) {
ArrayAdapter.createFromResource(
newContext,R.array.report_array,android.R.layout.simple_spinner_item
).also { adapter ->
// Specify the layout to use when the list of choices appears
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item)
// Apply the adapter to the spinner
reportSpinner.adapter = adapter
}
}
它是 xml
<Spinner
android:id="@+id/spinner_report"
style="@style/Widget.AppCompat.Spinner.Underlined"
android:theme="@style/SpinnerTheme"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_marginStart="8dp"
android:layout_marginEnd="16dp"
android:gravity="center"
android:popupBackground="@color/PrimaryDark"
android:textAlignment="center"
app:autoSizeTextType="uniform"
app:layout_constraintBottom_toBottomOf="@+id/textView"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.5"
app:layout_constraintHorizontal_chainStyle="spread"
app:layout_constraintHorizontal_weight="1"
app:layout_constraintStart_toEndOf="@+id/textView"
app:layout_constraintTop_toTopOf="@+id/textView" />
当我在代码中看不到任何差异时,我为微调器创建了一个样式并将其应用于两者,但仍然得到不同的结果。
<style name="SpinnerTheme">
<item name="android:textColor">@color/white</item>
<item name="android:fontFamily">@font/atma_medium</item>
</style>
基本上在第一个微调器上,所有文本都是白色的,并根据我预加载的字体系列进行样式设置。这是封闭的微调字体和弹出列表字体。
在片段内的第二个微调器上,只有弹出列表字体的样式正确(自从添加微调器样式之后),关闭的微调器文本颜色为黑色,字体看起来像标准的 android 股票字体。
从我所读到的样式在根据宿主活动的样式加载时应用于片段,实际上我可以从片段中的标准文本视图中看到它确实在选择我的主题样式,所以我不认为我根本不需要使用微调样式资源,相反,我认为我缺少其他东西??????
如果需要,请使用下面的基本主题
<resources xmlns:tools="http://schemas.android.com/tools">
<!-- Base application theme. -->
<style name="Theme.Home" parent="Theme.AppCompat">
<!-- Primary brand color. -->
<item name="colorPrimary">@color/PrimaryDark</item>
<item name="colorAccent">@color/white</item>
<item name="colorPrimaryVariant">@color/PrimaryLight</item>
<item name="colorOnPrimary">@color/white</item>
<!-- Secondary brand color. -->
<item name="colorSecondary">@color/PrimaryAccent</item>
<item name="colorSecondaryVariant">@color/PrimaryAccent</item>
<item name="colorOnSecondary">@color/white</item>
<item name="android:textColor">#ffffffff</item>
<item name="android:fontFamily">@font/atma_medium</item>
<!-- Status bar color. -->
<item name="android:statusBarColor" tools:targetApi="l">@color/PrimaryDark</item>
<!-- Customize your theme here. -->
<item name="android:windowBackground">@color/PrimaryLight</item>
<item name="actionBarSize">36dip</item>
</style>
</resources>
补充:
如果有人想知道我的片段数组适配器通过这个获取活动上下文
newContext = activity?.applicationContext
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。