From a7b142e8b8cde8828cdd3ff6bc654085dd43e747 Mon Sep 17 00:00:00 2001 From: Chan Date: Mon, 12 Oct 2015 21:35:00 -0700 Subject: [PATCH] Bug fixes when setting layout params. --- .../channguyen/rsv/RangeSliderView.java | 60 +++++++++++++++---- .../com/chan/rsv/sample/MainActivity.java | 2 +- sample/src/main/res/layout/activity_main.xml | 53 ++++++++++++++-- 3 files changed, 97 insertions(+), 18 deletions(-) diff --git a/library/src/main/java/com/github/channguyen/rsv/RangeSliderView.java b/library/src/main/java/com/github/channguyen/rsv/RangeSliderView.java index 08e4f9f..b8103b6 100644 --- a/library/src/main/java/com/github/channguyen/rsv/RangeSliderView.java +++ b/library/src/main/java/com/github/channguyen/rsv/RangeSliderView.java @@ -36,6 +36,8 @@ public class RangeSliderView extends View { private static final int DEFAULT_RANGE_COUNT = 5; + private static final int DEFAULT_HEIGHT_IN_DP = 50; + protected Paint paint; protected Paint ripplePaint; @@ -46,8 +48,6 @@ public class RangeSliderView extends View { private int currentIndex; - private int height; - private float currentSlidingX; private float currentSlidingY; @@ -86,6 +86,8 @@ public class RangeSliderView extends View { private float sliderRadiusPercent = DEFAULT_SLIDER_RADIUS_PERCENT; + private int layoutHeight; + public RangeSliderView(Context context) { this(context, null); } @@ -100,7 +102,7 @@ public RangeSliderView(Context context, AttributeSet attrs, int defStyleAttr) { TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.RangeSliderView); TypedArray sa = context.obtainStyledAttributes(attrs, new int[]{android.R.attr.layout_height}); try { - height = sa.getDimensionPixelSize( + layoutHeight = sa.getLayoutDimension( 0, ViewGroup.LayoutParams.WRAP_CONTENT); rangeCount = a.getInt( R.styleable.RangeSliderView_rangeCount, DEFAULT_RANGE_COUNT); @@ -127,13 +129,7 @@ public RangeSliderView(Context context, AttributeSet attrs, int defStyleAttr) { setSlotRadiusPercent(slotRadiusPercent); setSliderRadiusPercent(sliderRadiusPercent); - barHeight = (int) (height * barHeightPercent); - radius = height * sliderRadiusPercent; - slotRadius = height * slotRadiusPercent; - currentIndex = 0; - slotPositions = new float[rangeCount]; - paint = new Paint(Paint.ANTI_ALIAS_FLAG); paint.setStrokeWidth(DEFAULT_PAINT_STROKE_WIDTH); paint.setStyle(Paint.Style.FILL_AND_STROKE); @@ -146,10 +142,24 @@ public RangeSliderView(Context context, AttributeSet attrs, int defStyleAttr) { @Override public boolean onPreDraw() { getViewTreeObserver().removeOnPreDrawListener(this); + + // Update radius after we got new height + updateRadius(getHeight()); + + // Compute drawing position again preComputeDrawingPosition(); + + // Ready to draw now return true; } }); + currentIndex = 0; + } + + private void updateRadius(int height) { + barHeight = (int) (height * barHeightPercent); + radius = height * sliderRadiusPercent; + slotRadius = height * slotRadiusPercent; } public int getRangeCount() { @@ -300,6 +310,14 @@ private int measureHeight(int measureSpec) { if (specMode == MeasureSpec.EXACTLY) { result = specSize; } else { + final int height; + if (layoutHeight == ViewGroup.LayoutParams.WRAP_CONTENT) { + height = dpToPx(getContext(), DEFAULT_HEIGHT_IN_DP); + } else if (layoutHeight == ViewGroup.LayoutParams.MATCH_PARENT) { + height = getMeasuredHeight(); + } else { + height = layoutHeight; + } result = height + getPaddingTop() + getPaddingBottom() + (2 * DEFAULT_PAINT_STROKE_WIDTH); if (specMode == MeasureSpec.AT_MOST) { result = Math.min(result, specSize); @@ -321,7 +339,7 @@ private int measureWidth(int measureSpec) { if (specMode == MeasureSpec.EXACTLY) { result = specSize; } else { - result = getSuggestedMinimumWidth() + getPaddingLeft() + getPaddingRight() + (2 * DEFAULT_PAINT_STROKE_WIDTH) + (int) (2 * radius); + result = specSize + getPaddingLeft() + getPaddingRight() + (2 * DEFAULT_PAINT_STROKE_WIDTH) + (int) (2 * radius); if (specMode == MeasureSpec.AT_MOST) { result = Math.min(result, specSize); } @@ -549,6 +567,26 @@ public SavedState[] newArray(int size) { }; } + /** + * Helper method to convert pixel to dp + * @param context + * @param px + * @return + */ + static int pxToDp(final Context context, final float px) { + return (int)(px / context.getResources().getDisplayMetrics().density); + } + + /** + * Helper method to convert dp to pixel + * @param context + * @param dp + * @return + */ + static int dpToPx(final Context context, final float dp) { + return (int)(dp * context.getResources().getDisplayMetrics().density); + } + /** * Interface to keep track sliding position */ @@ -557,7 +595,7 @@ public interface OnSlideListener { /** * Notify when slider change to new index position * - * @param index + * @param index The index value of range count [0, rangeCount - 1] */ void onSlide(int index); } diff --git a/sample/src/main/java/com/chan/rsv/sample/MainActivity.java b/sample/src/main/java/com/chan/rsv/sample/MainActivity.java index 655e094..106bbad 100644 --- a/sample/src/main/java/com/chan/rsv/sample/MainActivity.java +++ b/sample/src/main/java/com/chan/rsv/sample/MainActivity.java @@ -32,4 +32,4 @@ public void onSlide(int index) { smallSlider.setOnSlideListener(listener); largeSlider.setOnSlideListener(listener); } -} +} \ No newline at end of file diff --git a/sample/src/main/res/layout/activity_main.xml b/sample/src/main/res/layout/activity_main.xml index 7fee40a..3f08984 100644 --- a/sample/src/main/res/layout/activity_main.xml +++ b/sample/src/main/res/layout/activity_main.xml @@ -19,11 +19,9 @@ @@ -32,7 +30,7 @@ android:id="@+id/rsv_custom" android:layout_marginTop="50dp" android:layout_width="match_parent" - android:layout_height="100dp" + android:layout_height="wrap_content" android:layout_marginLeft="30dp" android:layout_marginRight="30dp" rsv:filledColor="#00cbff" @@ -41,4 +39,47 @@ rsv:barHeightPercent="0.1" /> - + + + + +