Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Configurable Thumbnail Width #190

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 4 additions & 5 deletions app/build.gradle
Original file line number Diff line number Diff line change
@@ -1,12 +1,11 @@
apply plugin: 'com.android.application'

android {
compileSdkVersion 27
buildToolsVersion '27.0.3'
compileSdkVersion 28
defaultConfig {
applicationId "com.warkiz.indicatorseekbar"
minSdkVersion 24
targetSdkVersion 27
targetSdkVersion 28
versionCode 3
versionName "2.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
Expand All @@ -21,6 +20,6 @@ android {

dependencies {
implementation project(':indicatorseekbar')
implementation 'com.android.support:appcompat-v7:27.1.1'
implementation 'com.android.support:design:27.1.1'
implementation 'com.android.support:appcompat-v7:28.0.0'
implementation 'com.android.support:design:28.0.0'
}
17 changes: 17 additions & 0 deletions app/src/main/res/layout/discrete.xml
Original file line number Diff line number Diff line change
Expand Up @@ -222,6 +222,23 @@
app:isb_tick_texts_array="@array/last_next_length_6"
app:isb_ticks_count="6" />

<TextView
style="@style/subtitle_text_style"
android:text="12. Modifying sensitivity of seekbar, specially useful when the seekbar is inside a RecyclerView (longClick, longClickTime (in ms))" />

<com.warkiz.widget.IndicatorSeekBar
android:id="@+id/long_click_drawable"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="18dp"
app:isb_progress="40"
app:isb_show_tick_marks_type="oval"
app:isb_show_tick_texts="true"
app:isb_tick_texts_array="@array/last_next_length_6"
app:isb_ticks_count="6"
app:isb_longclick="true"
app:isb_longclick_time="500"/>

<include layout="@layout/source_code_link" />
</LinearLayout>

Expand Down
6 changes: 3 additions & 3 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,9 @@ buildscript {
google()
}
dependencies {
classpath 'com.android.tools.build:gradle:3.1.0'
classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.7.3'
classpath 'com.github.dcendents:android-maven-gradle-plugin:2.0'
classpath 'com.android.tools.build:gradle:3.5.1'
classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.8.4'
classpath 'com.github.dcendents:android-maven-gradle-plugin:2.1'
}
}

Expand Down
2 changes: 1 addition & 1 deletion gradle/wrapper/gradle-wrapper.properties
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,4 @@ distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-4.4-all.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-5.6.2-all.zip
7 changes: 3 additions & 4 deletions indicatorseekbar/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -27,12 +27,11 @@ ext {
}

android {
compileSdkVersion 27
buildToolsVersion '27.0.3'
compileSdkVersion 28

defaultConfig {
minSdkVersion 14
targetSdkVersion 27
targetSdkVersion 28
versionCode 3
versionName VERSION_NAME
}
Expand All @@ -45,7 +44,7 @@ android {
}

dependencies {
compileOnly 'com.android.support:appcompat-v7:27.1.1'
compileOnly 'com.android.support:appcompat-v7:28.0.0'
}


Expand Down
24 changes: 24 additions & 0 deletions indicatorseekbar/src/main/java/com/warkiz/widget/Builder.java
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,8 @@ public class Builder {
boolean userSeekable = true;
boolean onlyThumbDraggable = false;
boolean clearPadding = false;
boolean longClick = false;
int longClickTime = 0;
//indicator
int showIndicatorType = IndicatorType.ROUNDED_RECTANGLE;
int indicatorColor = Color.parseColor("#FF4081");
Expand Down Expand Up @@ -173,6 +175,28 @@ public Builder clearPadding(boolean clearPadding) {
return this;
}

/**
* seek bar will respond only on longClick
*
* @param longClick true to set longClick behaviour
* @return Builder
*/
public Builder longClick(boolean longClick){
this.longClick = longClick;
return this;
}

/**
* seek bar will respond on longClick after a time expressed in ms
*
* @param longClickTime time (in ms) before to respond
* @return Builder
*/
public Builder longClickTime(int longClickTime){
this.longClickTime = longClickTime;
return this;
}

/**
* prevent user from touching to seek or not
*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.math.BigDecimal;
import java.util.Date;

/**
* created by zhuangguangquan on 2017/9/1
Expand All @@ -51,7 +52,6 @@
*/

public class IndicatorSeekBar extends View {
private static final int THUMB_MAX_WIDTH = 30;
private static final String FORMAT_PROGRESS = "${PROGRESS}";
private static final String FORMAT_TICK_TEXT = "${TICK_TEXT}";
private Context mContext;
Expand Down Expand Up @@ -83,6 +83,10 @@ public class IndicatorSeekBar extends View {
private boolean mSeekSmoothly;//seek continuously
private float[] mProgressArr;//save the progress which at tickMark position.
private boolean mR2L;//right to left,compat local problem.
private boolean mLongClick;//true if seekbar responds on longClick
private int mLongClickTime;//time (in ms) passed before responds onlongClick
private long startTime;
private long endTime;
//tick texts
private boolean mShowTickText;//the palace where the tick text show .
private boolean mShowBothTickTextsOnly;//show the tick texts on the both ends of seek bar before.
Expand Down Expand Up @@ -201,6 +205,8 @@ private void initAttrs(Context context, AttributeSet attrs) {
mOnlyThumbDraggable = ta.getBoolean(R.styleable.IndicatorSeekBar_isb_only_thumb_draggable, builder.onlyThumbDraggable);
mSeekSmoothly = ta.getBoolean(R.styleable.IndicatorSeekBar_isb_seek_smoothly, builder.seekSmoothly);
mR2L = ta.getBoolean(R.styleable.IndicatorSeekBar_isb_r2l, builder.r2l);
mLongClick = ta.getBoolean(R.styleable.IndicatorSeekBar_isb_longclick, builder.longClick);
mLongClickTime = ta.getInteger(R.styleable.IndicatorSeekBar_isb_longclick_time, builder.longClickTime);
//track
mBackgroundTrackSize = ta.getDimensionPixelSize(R.styleable.IndicatorSeekBar_isb_track_background_size, builder.trackBackgroundSize);
mProgressTrackSize = ta.getDimensionPixelSize(R.styleable.IndicatorSeekBar_isb_track_progress_size, builder.trackProgressSize);
Expand Down Expand Up @@ -254,13 +260,13 @@ private void initParams() {
mThumbRadius = mThumbSize / 2.0f;
mThumbTouchRadius = mThumbRadius * 1.2f;
} else {
mThumbRadius = Math.min(SizeUtils.dp2px(mContext, THUMB_MAX_WIDTH), mThumbSize) / 2.0f;
mThumbRadius = mThumbSize / 2.0f;
mThumbTouchRadius = mThumbRadius;
}
if (mTickMarksDrawable == null) {
mTickRadius = mTickMarksSize / 2.0f;
} else {
mTickRadius = Math.min(SizeUtils.dp2px(mContext, THUMB_MAX_WIDTH), mTickMarksSize) / 2.0f;
mTickRadius = mTickMarksSize / 2.0f;
}
mCustomDrawableMaxHeight = Math.max(mThumbTouchRadius, mTickRadius) * 2.0f;
initStrokePaint();
Expand Down Expand Up @@ -725,7 +731,7 @@ private Bitmap getDrawBitmap(Drawable drawable, boolean isThumb) {
}
int width;
int height;
int maxRange = SizeUtils.dp2px(mContext, THUMB_MAX_WIDTH);
int maxRange = mThumbSize;
int intrinsicWidth = drawable.getIntrinsicWidth();
if (intrinsicWidth > maxRange) {
if (isThumb) {
Expand Down Expand Up @@ -1214,18 +1220,43 @@ public boolean onTouchEvent(MotionEvent event) {
if (mSeekChangeListener != null) {
mSeekChangeListener.onStartTrackingTouch(this);
}
refreshSeekBar(event);
if(!mLongClick) {
refreshSeekBar(event);
}
else{
startTime = event.getEventTime();
}
return true;
}
break;
case MotionEvent.ACTION_MOVE:
refreshSeekBar(event);
if(mLongClick) {
endTime = event.getEventTime();
if (endTime - startTime > mLongClickTime) {
refreshSeekBar(event);
}
}
else{
refreshSeekBar(event);
}
break;
case MotionEvent.ACTION_UP:
case MotionEvent.ACTION_CANCEL:
mIsTouching = false;
if (mSeekChangeListener != null) {
mSeekChangeListener.onStopTrackingTouch(this);

if(mLongClick) {
endTime = event.getEventTime();
if (endTime - startTime > mLongClickTime) {
refreshSeekBar(event);
if (mSeekChangeListener != null) {
mSeekChangeListener.onStopTrackingTouch(this);
}
}
}
else{
if (mSeekChangeListener != null) {
mSeekChangeListener.onStopTrackingTouch(this);
}
}
if (!autoAdjustThumb()) {
invalidate();
Expand Down Expand Up @@ -1703,7 +1734,7 @@ public void setThumbDrawable(Drawable drawable) {
this.mPressedThumbBitmap = null;
} else {
this.mThumbDrawable = drawable;
this.mThumbRadius = Math.min(SizeUtils.dp2px(mContext, THUMB_MAX_WIDTH), mThumbSize) / 2.0f;
this.mThumbRadius = mThumbSize / 2.0f;
this.mThumbTouchRadius = mThumbRadius;
this.mCustomDrawableMaxHeight = Math.max(mThumbTouchRadius, mTickRadius) * 2.0f;
initThumbBitmap();
Expand Down Expand Up @@ -1773,7 +1804,7 @@ public void setTickMarksDrawable(Drawable drawable) {
this.mSelectTickMarksBitmap = null;
} else {
this.mTickMarksDrawable = drawable;
this.mTickRadius = Math.min(SizeUtils.dp2px(mContext, THUMB_MAX_WIDTH), mTickMarksSize) / 2.0f;
this.mTickRadius = mTickMarksSize / 2.0f;
this.mCustomDrawableMaxHeight = Math.max(mThumbTouchRadius, mTickRadius) * 2.0f;
initTickMarksBitmap();
}
Expand Down
2 changes: 2 additions & 0 deletions indicatorseekbar/src/main/res/values/attr.xml
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@
<attr name="isb_user_seekable" format="boolean" /><!--prevent user from seeking,only can be change thumb location by setProgress(), default false-->
<attr name="isb_clear_default_padding" format="boolean" /><!-- set seekBar's leftPadding&rightPadding to zero, default false, default padding is 16dp-->
<attr name="isb_only_thumb_draggable" format="boolean" /><!--user change the thumb's location by touching thumb/touching track,true for touching track to seek. false for touching thumb; default false-->
<attr name="isb_longclick" format="boolean" />
<attr name="isb_longclick_time" format="integer" />
//indicator
<attr name="isb_show_indicator"><!-- the type of indicator, default rectangle_rounded_corner/0.-->
<enum name="none" value="0" />
Expand Down