IndicatorSeekBar


Source link: https://github.com/warkiz/IndicatorSeekBar

IndicatorSeekBar

README: ?? | English

???SeekBar, ???????????(thumb)?????(tick)???????(text)??????(indicator)????????????????

????? IndicatorSeekBar, ?????? Star??????


1.??

2. ??

1. ?app/build.gradle?:

dependencies {

  compile 'com.github.warkiz.widget:indicatorseekbar:1.1.2' 
}

2. ??????java??:

xml

<com.warkiz.widget.IndicatorSeekBar
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:layout_marginTop="16dp"
  app:isb_max="78.8"
  app:isb_min="10.2"
  app:isb_progress="50.3"
  app:isb_progress_value_float="true"
  app:isb_show_indicator="true"/>
<com.warkiz.widget.IndicatorSeekBar
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  app:isb_indicator_custom_layout="@layout/custom_indicator"
  app:isb_indicator_type="custom"
  app:isb_max="189"
  app:isb_min="23"
  app:isb_progress="67"
  app:isb_seek_bar_type="discrete_ticks_texts"
  app:isb_show_indicator="true"
  app:isb_text_array="@array/tick_below_text_length_9"
  app:isb_text_color="@color/color_blue"
  app:isb_thumb_width="18dp"
  app:isb_tick_drawable="@mipmap/ic_launcher"
  app:isb_tick_num="9"
  app:isb_tick_on_thumb_left_hide="true"
  app:isb_track_background_bar_color="#FF00"
  app:isb_track_background_bar_size="2dp"
  app:isb_track_progress_bar_color="#FF0000"
  app:isb_track_progress_bar_size="5dp"/>

Java

IndicatorSeekBar indicatorSeekBar = new IndicatorSeekBar.Builder(this)
  .setMax(200)
  .setMin(0)
  .setProgress(35)
  .setSeekBarType(IndicatorSeekBarType.DISCRETE_TICKS)
  .setTickType(TickType.OVAL)
  .setTickColor(Color.parseColor("#0000FF"))
  .setTickSize(8)//dp size
  .setTickNum(8)
  .setBackgroundTrackSize(2)//dp size
  .setBackgroundTrackColor(Color.parseColor("#666666"))
  .setProgressTrackSize(3)//dp size
  .setProgressTrackColor(Color.parseColor("#0000FF"))
  .showIndicator(true)
  .setIndicatorType(IndicatorType.SQUARE_CORNERS)
  .setIndicatorColor(Color.parseColor("#0000FF"))
  .build();
????????? demo.apk.

3. ??

3.1 ???SeekBar??

IndicatorSeekBar ??????????:

  1. ???continuous????:   CONTINUOUS/ CONTINUOUS_TEXTS_ENDS.

  2. ????discrete????:   DISCRETE_TICKS/   DISCRETE_TICKS_TEXTS/   DISCRETE_TICKS_TEXTS_ENDS.

<com.warkiz.widget.IndicatorSeekBar
  app:isb_seek_bar_type="continuous"
  .../>

3.2 ??? ?????

SeekBar?????????????????

  • ??? track_background_bar
  • ??? track_progress_bar
  • ?? tick
  • ???? text
  • ?? thumb
  • ??? indicator
  • ????? indicator_text

3.3 ????tick

SeekBar???????????????????????

<com.warkiz.widget.IndicatorSeekBar
  app:isb_tick_both_end_hide="true"
  .../>  <com.warkiz.widget.IndicatorSeekBar
  app:isb_tick_on_thumb_left_hide="true"
  .../>

3.4 ?SeekBar????/??

????????????????

<com.warkiz.widget.IndicatorSeekBar
  app:isb_track_rounded_corners="true"
  .../>

3.5 ??thumb?????

? seekabr ???? CONTINUOUS or DISCRETE_TICKS? , ?????????????????

<com.warkiz.widget.IndicatorSeekBar
  app:isb_seek_bar_type="continuous"//discrete_ticks
  app:isb_thumb_progress_stay="true"
  .../>

3.6 ???SeekBar?????text

? seekabr ???? CONTINUOUS_TEXTS_ENDS ? DISCRETE_TICKS_TEXTS_ENDS ?, ?????????.

<com.warkiz.widget.IndicatorSeekBar
  app:isb_seek_bar_type="continuous_texts_ends"//discrete_ticks_texts_ends
  app:isb_text_left_end="last"
  app:isb_text_right_end="next"
  .../>

3.7 ?????????text

? seekabr ???? DISCRETE_TICKS_TEXTS , ????????????????????, ?????????????

<com.warkiz.widget.IndicatorSeekBar
  app:isb_text_array="@array/texts_below_tick_length_5"
  app:isb_tick_num="5" //???? , ?????????????????
  .../>
or indicatorSeekBar.setTextArray(R.array.texts_below_tick_length_5);

3.8 ?????thumb???

?????????????

<com.warkiz.widget.IndicatorSeekBar
  app:isb_thumb_drawable="@mipmap/ic_launcher"
  .../>

3.9 ?????tick???

????????????.

<com.warkiz.widget.IndicatorSeekBar
  app:isb_tick_drawable="@mipmap/ic_launcher"
  .../>

3.10 ??????indicator

IndicatorSeekbar???3???????? ROUNDED_CORNERS / SQUARE_CORNERS / CUSTOM,???????? CUSTOM ?, ?????????view.

<com.warkiz.widget.IndicatorSeekBar
  app:isb_indicator_type="custom"
  app:isb_indicator_custom_layout="@layout/indicator"
  .../>
or indicatorSeekBar.setCustomIndicator(R.layout.indicator);

?????????????????, ???????????TextView????id????? isb_progress.

3.11 ???????????

? indicator ???? ROUNDED_CORNERS ?? SQUARE_CORNERS , ??????????view.

<com.warkiz.widget.IndicatorSeekBar
  app:isb_indicator_type="rounded_corners"//square_corners
  app:isb_indicator_custom_top_content_layout="@layout/top_content_view"
  .../>
or indicatorSeekBar.getIndicator().setIndicatorTopContentLayout(R.layout.top_content_view);

??????????????view??????, ????view??????TextView????id????? isb_progress.

4. ??????

indicatorSeekBar.setOnSeekChangeListener(new IndicatorSeekBar.OnSeekBarChangeListener() {

@Override  public void onProgressChanged(IndicatorSeekBar seekBar, int progress, float progressFloat, boolean fromUserTouch) {

}

@Override  public void onSectionChanged(IndicatorSeekBar seekBar, int thumbPosOnTick, String textBelowTick, boolean fromUserTouch) {

//only callback on discrete series SeekBar type.  
}

@Override  public void onStartTrackingTouch(IndicatorSeekBar seekBar, int thumbPosOnTick) {
  
}

@Override  public void onStopTrackingTouch(IndicatorSeekBar seekBar) {

}
 
}
);

onSectionChanged: ?SeekBar??????? discrete?? ?, ???????????????????. ???? continuous???????

5. ????

-keep class com.warkiz.widget.** {
 *; 
}

6. ??

//seekBar <attr name="isb_max" format="float"/><!-- the max value of seekBar to seek, default 100--> <attr name="isb_min" format="float"/><!-- the min value of seekBar to seek, default 0 --> <attr name="isb_progress" format="float"/><!-- the current progress value of seekBar, default 0--> <attr name="isb_clear_default_padding" format="boolean"/><!-- set seekBar's leftPadding&rightPadding to zero, default false, default padding is 16dp--> <attr name="isb_progress_value_float" format="boolean"/><!--set the value of seekBar to float type, default false--> <attr name="isb_seek_bar_type"><!-- the type for seekBar, default 0.-->
  <enum name="continuous" value="0"/>
  <enum name="continuous_texts_ends" value="1"/>
  <enum name="discrete_ticks" value="2"/>
  <enum name="discrete_ticks_texts" value="3"/><!--has below text-->
  <enum name="discrete_ticks_texts_ends" value="4"/><!--has below text of both ends of seekBar--> </attr> //indicator <attr name="isb_indicator_type"><!-- the type for indicator, default square_corners/0.-->
  <enum name="square_corners" value="0"/>
  <enum name="rounded_corners" value="1"/>
  <!-- the attr:isb_indicator_custom_layout should be called to give a indicator view when you select custom indicator type -->
  <enum name="custom" value="2"/> </attr> <attr name="isb_show_indicator" format="boolean"/><!-- show indicator or not when seeking, default true--> <attr name="isb_indicator_color" format="color|reference"/><!-- set indicator's color, default #FF4081--> <attr name="isb_indicator_custom_layout" format="reference"/><!-- when you set indicator type to custom , you can set this layout for indicator view you want--> <attr name="isb_indicator_custom_top_content_layout" format="reference"/> <!--you can set this layout for indicator top view you want, no effect arrow below indicator, effect on indicator type : square_corners or rounded_corners--> <attr name="isb_indicator_text_color" format="color|reference"/><!-- set indicator's text color, default #FF4081 , work on indicator type : square_corners or rounded_corners--> <attr name="isb_indicator_text_size" format="dimension|reference"/><!-- set indicator's text size, default 13sp,  work on indicator type : square_corners or rounded_corners--> //track <attr name="isb_track_background_bar_size" format="dimension|reference"/><!-- set indicatorSeekBar's track background bar size, default 2dp--> <attr name="isb_track_background_bar_color" format="color|reference"/><!-- set indicatorSeekBar's track background bar color, default #D7D7D7--> <attr name="isb_track_progress_bar_size" format="dimension|reference"/><!-- set indicatorSeekBar's track progress bar size, default 2dp--> <attr name="isb_track_progress_bar_color" format="color|reference"/><!-- set indicatorSeekBar's track progress bar color, default #FF4081--> <attr name="isb_track_rounded_corners" format="boolean"/><!-- set indicatorSeekBar's track's both ends's corners to rounded/square, default false--> //thumb <attr name="isb_thumb_progress_stay" format="boolean"/><!-- set thumb below text to stay after seek, default false, work on seekBar type : continuous / discrete_ticks--> <attr name="isb_thumb_color" format="color|reference"/><!--set thumb's color, default #FF4081--> <attr name="isb_thumb_width" format="dimension|reference"/><!--set thumb's size, default 18dp, when custom thumb--> <attr name="isb_thumb_drawable" format="reference"/><!--set custom thumb's drawable you want, thumb size will be limited in 18dp no matter drawable size--> //tick <attr name="isb_tick_drawable" format="reference"/><!--set custom tick's drawable you want--> <attr name="isb_tick_color" format="color|reference"/><!--set tick's color, default #FF4081--> <attr name="isb_tick_num" format="integer"/><!--seekBar's tick count, default 5--> <attr name="isb_tick_size" format="dimension|reference"/><!--set the tick width, default 13dp,  custom drawable will be limited in 18dp no matter drawable size--> <attr name="isb_tick_both_end_hide" format="boolean"/><!--hide 2 ticks on the seekBar's both ends, default false--> <attr name="isb_tick_on_thumb_left_hide" format="boolean"/><!--hide the ticks on the seekBar's thumb left, default false--> <attr name="isb_tick_type"><!--select the tick shape type, default rectangle/1-->
  <enum name="none" value="0"/>
  <enum name="rec" value="1"/>
  <enum name="oval" value="2"/> </attr> //texts <attr name="isb_text_color" format="color|reference"/><!--set the color of text below tick, default #FF4081--> <attr name="isb_text_left_end" format="string|reference"/><!--set the text below seekBar left end, default min value string, work on seekBar type :CONTINUOUS_TEXTS_ENDS/DISCRETE_TICKS_TEXTS/DISCRETE_TICKS_TEXTS_ENDS--> <attr name="isb_text_right_end" format="string|reference"/><!--set the text below seekBar right end, default max value string, work on seekBar type :CONTINUOUS_TEXTS_ENDS/DISCRETE_TICKS_TEXTS/DISCRETE_TICKS_TEXTS_ENDS--> <attr name="isb_text_size" format="dimension|reference"/><!--set the text size of tick below text, default 13sp--> <attr name="isb_text_array" format="reference"/><!--set the texts below tick to replace default progress text, default string of progress, work on seekBar type :DISCRETE_TICKS_TEXTS-->

7. License

Apache License 2.0

8. ???

???????????????????????

  1. ?issue.
  2. ????? http://weibo.com/warkiz
  3. ???, "warkiz".concat("4j").concat("@").concat("gmail.com")

Resources

A circular seekbar for Android, with a control knob! (for the lack of a better word).

A customizable number picker based on Material guidelines.

It is a recycler view adapter that supports multiview holders, filters, and child view click events.

CFAlertDialog is a library that helps you display super awesome dialogs on Android. It offers an adaptive UI support with tons of customisation options. This will save a lot of time for you.

An Android list dialog showing list of items, with an EditText to filter items given in the list.

similarLoadingView is a custom loading view for Android. It is very easy to use and customize. It draws your drawable on canvas with stylish design.

Topics


2D Engines   3D Engines   9-Patch   Action Bars   Activities   ADB   Advertisements   Analytics   Animations   ANR   AOP   API   APK   APT   Architecture   Audio   Autocomplete   Background Processing   Backward Compatibility   Badges   Bar Codes   Benchmarking   Bitmaps   Bluetooth   Blur Effects   Bread Crumbs   BRMS   Browser Extensions   Build Systems   Bundles   Buttons   Caching   Camera   Canvas   Cards   Carousels   Changelog   Checkboxes   Cloud Storages   Color Analysis   Color Pickers   Colors   Comet/Push   Compass Sensors   Conferences   Content Providers   Continuous Integration   Crash Reports   Credit Cards   Credits   CSV   Curl/Flip   Data Binding   Data Generators   Data Structures   Database   Database Browsers   Date &   Debugging   Decompilers   Deep Links   Dependency Injections   Design   Design Patterns   Dex   Dialogs   Distributed Computing   Distribution Platforms   Download Managers   Drawables   Emoji   Emulators   EPUB   Equalizers &   Event Buses   Exception Handling   Face Recognition   Feedback &   File System   File/Directory   Fingerprint   Floating Action   Fonts   Forms   Fragments   FRP   FSM   Functional Programming   Gamepads   Games   Geocaching   Gestures   GIF   Glow Pad   Gradle Plugins   Graphics   Grid Views   Highlighting   HTML   HTTP Mocking   Icons   IDE   IDE Plugins   Image Croppers   Image Loaders   Image Pickers   Image Processing   Image Views   Instrumentation   Intents   Job Schedulers   JSON   Keyboard   Kotlin   Layouts   Library Demos   List View   List Views   Localization   Location   Lock Patterns   Logcat   Logging   Mails   Maps   Markdown   Mathematics   Maven Plugins   MBaaS   Media   Menus   Messaging   MIME   Mobile Web   Native Image   Navigation   NDK   Networking   NFC   NoSQL   Number Pickers   OAuth   Object Mocking   OCR Engines   OpenGL   ORM   Other Pickers   Parallax List   Parcelables   Particle Systems   Password Inputs   PDF   Permissions   Physics Engines   Platforms   Plugin Frameworks   Preferences   Progress Indicators   ProGuard   Properties   Protocol Buffer   Pull To   Purchases   Push/Pull   QR Codes   Quick Return   Radio Buttons   Range Bars   Ratings   Recycler Views   Resources   REST   Ripple Effects   RSS   Screenshots   Scripting   Scroll Views   SDK   Search Inputs   Security   Sensors   Services   Showcase Views   Signatures   Sliding Panels   Snackbars   SOAP   Social Networks   Spannable   Spinners   Splash Screens   SSH   Static Analysis   Status Bars   Styling   SVG   System   Tags   Task Managers   TDD &   Template Engines   Testing   Testing Tools   Text Formatting   Text Views   Text Watchers   Text-to   Toasts   Toolkits For   Tools   Tooltips   Trainings   TV   Twitter   Updaters   USB   User Stories   Utils   Validation   Video   View Adapters   View Pagers   Views   Watch Face   Wearable Data   Wearables   Weather   Web Tools   Web Views   WebRTC   WebSockets   Wheel Widgets   Wi-Fi   Widgets   Windows   Wizards   XML   XMPP   YAML   ZIP Codes