我们都知道android的seekbar左右两边都是有留一些空间。http://
现在项目要求宽度全屏的seekbar。
分析源码 得知
seekbar --》AbsSeekar--》ProgressSeekar 继承关系。
用idea 的debug工具单步调试SDK 中的源码
最后在Progress的onDraw方法中
if(isLayoutRtl() && mMirrorForRtl) {
canvas.translate(getWidth() - mPaddingRight, mPaddingTop);
canvas.scale(-1.0f, 1.0f);
} else {
canvas.translate(mPaddingLeft, mPaddingTop);
}
将mPaddingLeft 设为0,seekbar左边空隙消失,左边顶到屏幕最边缘处。
View的绘制过程可以参考老罗讲的这篇文章
Android应用程序窗口(Activity)的测量(Measure)、布局(Layout)和绘制(Draw)过程分析
引用文章中所说
其中,(mPaddingLeft,mPaddingRight,mPaddingTop,mPaddingBottom )表示当前视图的内容区域的左右上下四条边分别到当前视图的左右上下四条边的距离
就是android:padding属性
所以我们在seekbar的属性处加入
<SeekBar
android:id="@android:id/progress"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:paddingLeft="0dp"
android:paddingRight="0dp"
android:layout_marginBottom="116dp"
android:progressDrawable="@drawable/seekbar"
android:thumb="@drawable/processbar_point"
android:thumbOffset="5dip"/>
搞定。来张图
本文介绍了如何在Android中实现宽度全屏的SeekBar。通过分析 SeekBar 的源码,特别是 ProgressSeekBar 的 onDraw 方法,发现可以通过设置 padding 为 0 来消除 SeekBar 两侧的空隙。通过在 XML 布局文件中调整 SeekBar 的 padding 属性,成功实现了全屏效果。此外,文章还提及了 View 的绘制过程,引用了Android应用程序窗口的测量、布局和绘制过程分析的相关内容。
2045

被折叠的 条评论
为什么被折叠?



