我的activity_main.xml
是下面,你看,高度设为40浸。
在MyEclipse中,如下所示:
但是当我在手机上运行它时,如下所示:
所以我的问题是,为什么进度条的实际高度不是我设置的高度?如何增加进度条的高度?
Answers:
在本教程中:
<style name="CustomProgressBarHorizontal" parent="android:Widget.ProgressBar.Horizontal">
<item name="android:progressDrawable">@drawable/custom_progress_bar_horizontal</item>
<item name="android:minHeight">10dip</item>
<item name="android:maxHeight">20dip</item>
</style>
然后只需将样式应用于您的进度条或更好的样式,覆盖主题中的默认样式即可自动为所有应用程序的进度条设置样式。
您在屏幕快照中看到的差异是因为手机/仿真器使用的是Android版本(最新是ICS(Holo)中的主题,顶部是原始主题)。
我猜最简单的解决方案是:
mProgressBar.setScaleY(3f);
xml文件中的android:scaleY =“ 8”
用这个
style="@android:style/Widget.ProgressBar.Horizontal"
?android:attr/progressBarStyleHorizontal
,这并不工作
如其他答案所述,您似乎正在设置进度条的样式以使用Holo.Light:
style="@android:style/Widget.Holo.Light.ProgressBar.Horizontal"
如果这在您的手机上运行,则可能是3.0或更高版本的设备。但是,您的模拟器看起来像使用“默认”进度条的模拟器。
style="@android:style/Widget.ProgressBar.Horizontal"
也许您在创建屏幕截图之间将样式更改为“默认”进度条?不幸的是,如果您的项目使用Holo.Light进度栏,则2.x设备不会自动默认回到“默认”进度栏。它将崩溃。
如果您确实使用的是默认进度条,则按照建议设置最大/最小高度将可以正常工作。但是,如果您使用的是Holo.Light(或Holo)栏,则无法设置最大/最小高度。这是将最大/最小高度设置为25和100倾角的示例输出:
最大/最小设置为25度
最大/最小设置为100度
您会看到底层可绘制对象(progress_primary_holo_light.9.png)并未按预期缩放。其原因是9色块边框仅缩放顶部和底部几个像素:
当Android需要垂直调整.png大小时,以单像素黑色边框(绿色箭头)为边界的水平区域是被拉伸的部分。两个红色箭头之间的区域不会垂直拉伸。
解决此问题的最佳方法是更改9patch .png来拉伸栏而不是“画布区域”,然后创建自定义进度栏xml以使用这9patches。类似地在这里描述:https : //stackoverflow.com/a/18832349
这是我对非确定性的Holo.Light ProgressBar的实现。您必须为不确定性和Holo ProgressBars添加自己的9个补丁。理想情况下,我应该完全删除画布区域。相反,我离开了它,但是将“ bar”区域设置为可拉伸。 https://github.com/tir38/ScalingHoloProgressBar
这里有很多支持的解决方案对我来说不起作用,甚至不能接受答案。我通过设置scaleY来解决它,但是如果您需要太多高度,则不是一个好的解决方案,因为可绘制对象是像素化的。
以编程方式:
progressBar.setScaleY(2f);
XML布局:
android:scaleY="2"
<ProgressBar
android:minHeight="20dip"
android:maxHeight="20dip"/>
值-> styles.xml
<style name="tallerBarStyle" parent="@android:style/Widget.SeekBar">
<item name="android:indeterminateOnly">false</item>
<item name="android:progressDrawable">@android:drawable/progress_horizontal</item>
<item name="android:indeterminateDrawable">@android:drawable/progress_horizontal</item>
<item name="android:minHeight">8dip</item>
<item name="android:maxHeight">20dip</item>
</style>
然后在您的ProgressBar中添加:
style="@style/tallerBarStyle"
这是我使用的进度条。
<ProgressBar
android:padding="@dimen/dimen_5"
android:layout_below="@+id/txt_chklist_progress"
android:id="@+id/pb_media_progress"
style="@style/MyProgressBar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:progress="70"
android:scaleY="5"
android:max="100"
android:progressBackgroundTint="@color/white"
android:progressTint="@color/green_above_avg" />
这是我的风格标签
<style name="MyProgressBar" parent="@style/Widget.AppCompat.ProgressBar.Horizontal">
<item name="android:progressBackgroundTint">@color/white</item>
<item name="android:progressTint">@color/green_above_avg</item>
</style>