我们在3.0中获得了一个NumberPicker小部件,但似乎无法修改此小部件的textSize。我错过了什么或是这样吗?我真的想增加字体大小,它的默认值非常小。但是我看不到它的textSize属性。
答案 0 :(得分:89)
我能够通过扩展默认的NumberPicker来实现这一目标。不理想,但它有效。
public class NumberPicker extends android.widget.NumberPicker {
public NumberPicker(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
public void addView(View child) {
super.addView(child);
updateView(child);
}
@Override
public void addView(View child, int index, android.view.ViewGroup.LayoutParams params) {
super.addView(child, index, params);
updateView(child);
}
@Override
public void addView(View child, android.view.ViewGroup.LayoutParams params) {
super.addView(child, params);
updateView(child);
}
private void updateView(View view) {
if(view instanceof EditText){
((EditText) view).setTextSize(25);
((EditText) view).setTextColor(Color.parseColor("#333333"));
}
}
}
然后在布局xml中引用此类。
<com.yourpackage.NumberPicker
android:id="@+id/number_picker"
android:layout_width="43dp"
android:layout_height="wrap_content" />
答案 1 :(得分:6)
只为您的NumberPicker设置此信号:
<style name="AppTheme.Picker" parent="Theme.AppCompat.Light.NoActionBar" >
<item name="android:textColorPrimary">@android:color/white</item>
<item name="android:textSize">20dp</item>
</style>
<NumberPicker
android:theme="@style/AppTheme.Picker"
android:id="@+id/yearNumberPicker"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
和<item name="android:textColorPrimary">@android:color/white</item>
更改textcolor:
答案 2 :(得分:4)
以下对我有用(在API 15 / 4.0.3中)
注意: aheuermann的解决方案可以安全地防止不同Android版本NumberPicker
布局中的潜在实施差异(也就是说,TextView
可能并不总是在孩子身上位置1)。
TextView tv1 = (TextView)_numberPicker.getChildAt(1);
tv1.TextSize = 10;
答案 3 :(得分:4)
我遇到了同样的问题,我想增加NumberPicker的文本大小,却找不到办法将其作为Widget的一部分。以上所有答案都很棒,但我选择了满足我需求的以下解决方案:
<NumberPicker
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:scaleX="1.5"
android:scaleY="1.5"/>
这基本上放大了整个Widget。
答案 4 :(得分:2)
我们遇到了同样的问题,最终在本地重新创建了NumberPicker。还有一个更深入的教程here。
答案 5 :(得分:2)
跳到API 23,aheuermann提出的解决方案似乎有问题。在NumberPicker的源中,文本大小是在初始化时根据EditText子项设置的。如果您稍后尝试更改它,EditText字段将变大,但窗口小部件直接绘制的所有其他数字仍然很小。
我遇到的解决方案的缺点是它必须以编程方式实例化,而不是通过布局,但除此之外,它似乎按预期工作。首先,将以下内容添加到styles.xml文件中:
<style name="NumberPickerText">
<item name="android:textSize">40dp</item>
</style>
然后,您可以使用
实例化NumberPicker ContextThemeWrapper cw = new ContextThemeWrapper(this, R.style.NumberPickerText);
NumberPicker np = new NumberPicker(cw);
假设它是在一个活动中完成的。如果没有,请更换&#34;此&#34;无论你有什么上下文。此代码相当于设置一个主题,该主题覆盖Activity中的所有TextView大小,但仅将其应用于NumberPicker及其子代。
答案 6 :(得分:0)
我们可以在NumberPicker中自定义视图。
它有三个观点 -
2 ImageButttons和1 EditText。
if(numberPicker.getChildAt(1) instanceOf EditText)
{
EditText edt=(EditText)numberPicker.getChildAt(1);
//do customizations here
}
Android源代码中的NumberPicker完整布局
<?xml version="1.0" encoding="utf-8"?>
<!--
**
** Copyright 2008, The Android Open Source Project
**
** Licensed under the Apache License, Version 2.0 (the "License");
** you may not use this file except in compliance with the License.
** You may obtain a copy of the License at
**
** http://www.apache.org/licenses/LICENSE-2.0
**
** Unless required by applicable law or agreed to in writing, software
** distributed under the License is distributed on an "AS IS" BASIS,
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
** See the License for the specific language governing permissions and
** limitations under the License.
*/
-->
<merge xmlns:android="http://schemas.android.com/apk/res/android">
<ImageButton android:id="@+id/increment"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@android:drawable/numberpicker_up_btn"
android:paddingTop="22dip"
android:paddingBottom="22dip"
android:contentDescription="@string/number_picker_increment_button" />
<EditText
android:id="@+id/numberpicker_input"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:textAppearance="@style/TextAppearance.Large.Inverse.NumberPickerInputText"
android:gravity="center"
android:singleLine="true"
android:background="@drawable/numberpicker_input" />
<ImageButton android:id="@+id/decrement"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@android:drawable/numberpicker_down_btn"
android:paddingTop="22dip"
android:paddingBottom="22dip"
android:contentDescription="@string/number_picker_decrement_button" />
</merge>