宽度全屏SeekBar实现

我们都知道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的属性处加入

                    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开发)