Android调整TimePicker和DatePicker大小

原文地址 http://ziliao1.com/Article/Show/0DB02B87AFD7E9EB9AA6E15FB26250D5.html


最近写了个app,里面要将DatePicker和TimePicker并列显示。但是,Android内部把DatePicker和 TimePicker大小固定了,导致4.5寸手机屏幕一行只能显示出一个,另一个不能完全显示。在网上搜了一下,没有什么好的解决方案,看到了别人写的 一个自定义控件,研究了下,发现了一个方法来调整两个组件的大小。

没有调整之前效果如图:可以看到TimePicker只有很小一部分显示出来了

由于TimePicker和DatePicker里面的每一个选择框都是一个NumberPicker,而NumberPicker是可以改变LayoutParams的,所以可以有如下调整思路:

1.改变DatePicker和TimePicker里面字体的大小,目的是让DatePicker和TimePicker缩小了以后字能够完全显示出来。

2.得到DatePicker和TimePicker里面的NumberPicker

3.改变取得的NumberPicker的宽度,就大功告成了

 

1.改变字体大小

     改变字体大小有几种方法,为了统一,我是用的主题资源来改变字体大小的,代码如下:

 

    <style name="AppTheme" parent="AppBaseTheme">
        <!-- All customizations that are NOT specific to a particular API-level can go here. -->
        <item name="android:textSize">10sp</item>
    </style>

 

2.得到DatePicker和TimePicker里面的NumberPicker

    由于DatePicker和TimePicker都继承了FrameLayout类,所以函数可以定义为:

   

                /**
		 * 调整FrameLayout大小
		 * @param tp
		 */
		private void resizePikcer(FrameLayout tp){
			List<NumberPicker> npList = findNumberPicker(tp);
			for(NumberPicker np:npList){
				resizeNumberPicker(np);
			}
		}



这个函数很简单,参数是FrameLayout,调用时传入其子类即可。该函数调用了我自定义的findNumberPicker函数找到tp里面所有的NumberPicker,然后用自定义的resizeNumberPicker调整大小。

 

  其中:findNumberPicker定义如下:

		/**
		 * 得到viewGroup里面的numberpicker组件
		 * @param viewGroup
		 * @return
		 */
		private List<NumberPicker> findNumberPicker(ViewGroup viewGroup){
			List<NumberPicker> npList = new ArrayList<NumberPicker>();
			View child = null;
			if(null != viewGroup){
				for(int i = 0;i<viewGroup.getChildCount();i++){
					child = viewGroup.getChildAt(i);
					if(child instanceof NumberPicker){
						npList.add((NumberPicker)child);
					}
					else if(child instanceof LinearLayout){
						List<NumberPicker> result = findNumberPicker((ViewGroup)child);
						if(result.size()>0){
							return result;
						}
					}
				}
			}
			return npList;
		}



这个函数是遍历viewGroup的子元素,如果是NumberPicker则加入集合中。如果是一个LinearLayout布局,递归调用该函数,找布局里面的NumberPicker.

 

resizeNumberPicker定义如下:

		/*
		 * 调整numberpicker大小
		 */
		private void resizeNumberPicker(NumberPicker np){
			LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(50, LayoutParams.WRAP_CONTENT);
			params.setMargins(10, 0, 10, 0);
			np.setLayoutParams(params);
		}



该函数完成调整功能,也很简单,new一个布局参数,然后设置宽度为50,高度为wrap_content,再通过setMargins设置边距,把NumberPicker的布局参数设置为该值。

 

准备完这些后,就可以调用了,调用也很简单,就是得到DatePicker和TimePicker对象,然后用resizePicker(DatePicker)和resizePicker(TimePicker)即可。

下面贴出我的调用代码:

			DatePicker datePicker = (DatePicker)rootView.findViewById(R.id.date);//日期选择框
			TimePicker timePicker = (TimePicker)rootView.findViewById(R.id.time);//时间选择框
			resizePikcer(datePicker);//调整datepicker大小
			resizePikcer(timePicker);//调整timepicker大小



 

大功告成,所有步骤完成后,DatePicker和TimePicker就可以并列显示了,我的显示结果如下图:



DatePicker的分割线颜色设置


/**
     * 
     * 设置时间选择器的分割线颜色
     * @param datePicker
     */
    private void setDatePickerDividerColor(DatePicker datePicker){
        // Divider changing:
         
        // 获取 mSpinners
        LinearLayout llFirst       = (LinearLayout) datePicker.getChildAt(0);
        
        // 获取 NumberPicker 
        LinearLayout mSpinners      = (LinearLayout) llFirst.getChildAt(0);
        for (int i = 0; i < mSpinners.getChildCount(); i++) {
            NumberPicker picker = (NumberPicker) mSpinners.getChildAt(i); 
             
            Field[] pickerFields = NumberPicker.class.getDeclaredFields();
            for (Field pf : pickerFields) {
                if (pf.getName().equals("mSelectionDivider")) {
                    pf.setAccessible(true);
                    try {
                        pf.set(picker, new ColorDrawable(ResourceUtil.getColor(R.color.com_text_red)));
                    } catch (IllegalArgumentException e) {
                        e.printStackTrace();
                    } catch (NotFoundException e) {
                        e.printStackTrace();
                    } catch (IllegalAccessException e) {
                        e.printStackTrace();
                    }
                    break;
                }
            }
        }
    }




 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android中,可以通过设置DatePicker的样式来改变日期选择控件中文字的大小。可以使用以下代码来设置日期选择控件的文字大小: ```java DatePicker datePicker = (DatePicker) rootView.findViewById(R.id.date); int textSize = 20; // 设置文字大小为20 ((TextView) ((LinearLayout) ((LinearLayout) datePicker.getChildAt(0)).getChildAt(0)).getChildAt(0)).setTextSize(textSize); ``` 这段代码中,我们首先获取到DatePicker控件,然后通过getChildAt()方法获取到日期选择控件的子View,再通过getChildAt()方法获取到日期选择控件中的TextView,最后使用setTextSize()方法设置文字的大小为20。你可以根据需要调整textSize的值来改变文字的大小。\[2\] #### 引用[.reference_title] - *1* *3* [Android调整TimePickerDatePicker大小](https://blog.csdn.net/u010384174/article/details/38703597)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v12^insert_chatgpt"}} ] [.reference_item] - *2* [Android DatePicker spinner 样式设置(分割线颜色、位置等)](https://blog.csdn.net/kongqwesd12/article/details/119954636)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v12^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值