1. public class VerticalSeekBar extends AbsSeekBar {
  2. private Drawable mThumb;
  3. public interface OnSeekBarChangeListener {
  4. void onProgressChanged(VerticalSeekBar VerticalSeekBar, int progress, boolean fromUser);
  5. void onStartTrackingTouch(VerticalSeekBar VerticalSeekBar);
  6. void onStopTrackingTouch(VerticalSeekBar VerticalSeekBar);
  7. }
  8. private OnSeekBarChangeListener mOnSeekBarChangeListener;
  9. public VerticalSeekBar(Context context) {
  10. this(context, null);
  11. }
  12. public VerticalSeekBar(Context context, AttributeSet attrs) {
  13. this(context, attrs, android.R.attr.seekBarStyle);
  14. }
  15. public VerticalSeekBar(Context context, AttributeSet attrs, int defStyle) {
  16. super(context, attrs, defStyle);
  17. }
  18. public void setOnSeekBarChangeListener(OnSeekBarChangeListener l) {
  19. mOnSeekBarChangeListener = l;
  20. }
  21. void onStartTrackingTouch() {
  22. if (mOnSeekBarChangeListener != null) {
  23. mOnSeekBarChangeListener.onStartTrackingTouch(this);
  24. }
  25. }
  26. void onStopTrackingTouch() {
  27. if (mOnSeekBarChangeListener != null) {
  28. mOnSeekBarChangeListener.onStopTrackingTouch(this);
  29. }
  30. }
  31. void onProgressRefresh(float scale, boolean fromUser) {
  32. Drawable thumb = mThumb;
  33. if (thumb != null) {
  34. setThumbPos(getHeight(), thumb, scale, Integer.MIN_VALUE);
  35. invalidate();
  36. }
  37. if (mOnSeekBarChangeListener != null) {
  38. mOnSeekBarChangeListener.onProgressChanged(this, getProgress(), isPressed());
  39. }
  40. }
  41. private void setThumbPos(int w, Drawable thumb, float scale, int gap) {
  42. int available = w - getPaddingLeft() - getPaddingRight();
  43. int thumbWidth = thumb.getIntrinsicWidth();
  44. int thumbHeight = thumb.getIntrinsicHeight();
  45. available -= thumbWidth;
  46. // The extra space for the thumb to move on the track
  47. available += getThumbOffset() * 2;
  48. int thumbPos = (int) (scale * available);
  49. int topBound, bottomBound;
  50. if (gap == Integer.MIN_VALUE) {
  51. Rect oldBounds = thumb.getBounds();
  52. topBound = oldBounds.top;
  53. bottomBound = oldBounds.bottom;
  54. } else {
  55. topBound = gap;
  56. bottomBound = gap + thumbHeight;
  57. }
  58. thumb.setBounds(thumbPos, topBound, thumbPos + thumbWidth, bottomBound);
  59. }
  60. @Override
  61. protected void onDraw(Canvas c) {
  62. c.rotate(-90);// 反转90度,将水平SeekBar竖起来
  63. c.translate(-getHeight(), 0);// 将经过旋转后得到的VerticalSeekBar移到正确的位置,注意经旋转后宽高值互换
  64. super.onDraw(c);
  65. }
  66. @Override
  67. protected synchronized void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  68. super.onMeasure(heightMeasureSpec, widthMeasureSpec);
  69. setMeasuredDimension(getMeasuredHeight(), getMeasuredWidth());// 宽高值互换
  70. }
  71. @Override
  72. public void setThumb(Drawable thumb) {
  73. mThumb = thumb;
  74. super.setThumb(thumb);
  75. }
  76. @Override
  77. protected void onSizeChanged(int w, int h, int oldw, int oldh) {
  78. super.onSizeChanged(h, w, oldw, oldh);// 宽高值互换
  79. }
  80. // 与源码完全相同,仅为调用宽高值互换处理的onStartTrackingTouch()方法
  81. @Override
  82. public boolean onTouchEvent(MotionEvent event) {
  83. if (!isEnabled()) {
  84. return false;
  85. }
  86. switch (event.getAction()) {
  87. case MotionEvent.ACTION_DOWN: {
  88. setPressed(true);
  89. onStartTrackingTouch();
  90. trackTouchEvent(event);
  91. break;
  92. }
  93. case MotionEvent.ACTION_MOVE: {
  94. trackTouchEvent(event);
  95. attemptClaimDrag();
  96. break;
  97. }
  98. case MotionEvent.ACTION_UP: {
  99. trackTouchEvent(event);
  100. onStopTrackingTouch();
  101. setPressed(false);
  102. // ProgressBar doesn't know to repaint the thumb drawable
  103. // in its inactive state when the touch stops (because the
  104. // value has not apparently changed)
  105. invalidate();
  106. break;
  107. }
  108. case MotionEvent.ACTION_CANCEL: {
  109. onStopTrackingTouch();
  110. setPressed(false);
  111. invalidate(); // see above explanation
  112. break;
  113. }
  114. default:
  115. break;
  116. }
  117. return true;
  118. }
  119. // 宽高值互换处理
  120. private void trackTouchEvent(MotionEvent event) {
  121. final int height = getHeight();
  122. final int available = height - getPaddingBottom() - getPaddingTop();
  123. int Y = (int) event.getY();
  124. float scale;
  125. float progress = 0;
  126. if (Y > height - getPaddingBottom()) {
  127. scale = 0.0f;
  128. } else if (Y < getPaddingTop()) {
  129. scale = 1.0f;
  130. } else {
  131. scale = (float) (height - getPaddingBottom() - Y) / (float) available;
  132. }
  133. final int max = getMax();
  134. progress = scale * max;
  135. setProgress((int) progress);
  136. }
  137. private void attemptClaimDrag() {
  138. if (getParent() != null) {
  139. getParent().requestDisallowInterceptTouchEvent(true);
  140. }
  141. }
  142. }

垂直的SeekBar:VerticalSeekBar的更多相关文章

  1. 垂直的seekbar

    看下效果: 1 package org.qianyukun.core.views; import android.content.Context; import android.graphics.Ca ...

  2. android 垂直 SeekBar 源代码(VerticalSeekBar)[转]

    主要是继承 AbsSeekBar 然后修改下面这些方法 onProgressRefresh() //当进度条数据更新的时候,例如我们拖动滑动条的时候,这个方法被调用 setThumbPos() //这 ...

  3. 自定义垂直拖动的seekbar进度条

    系统自定义的seekbar为横向拖动的样式,需要纵向的时则需要自己定义,网上很多说了重写系统SeekBar中onDraw()的方法,但是我使用的时候不知道为什么拖动条和点偏离了,不在一条直线上,好气. ...

  4. android 基础控件(EditView、SeekBar等)的属性及使用方法

        android提供了大量的UI控件,本文将介绍TextView.ImageView.Button.EditView.ProgressBar.SeekBar.ScrollView.WebView ...

  5. Android 自定义seekbar中,thumb被覆盖掉一部分问题

    (图一)  (图二)    (图三) 做一个自定义的seekbar,更改其背景图片: <com.android.Progress android:id="@+id/focus_seek ...

  6. Android SeekBar 和 draw9patch 的使用

    今天要使用一个SeekBar控件,其实我觉得Android默认样式已经很不错了,无奈设计不同意,而且SeekBar左右两边也有图片,默认样式和图片也确实不协调,因此这里使用图片自定义SeekBar样式 ...

  7. 自定义seekbar中,thumb被覆盖掉一部分问题

  8. [Android学习笔记]SeekBar的使用

    一.SeekBar滑动条的使用 xml声明: <SeekBar android:id="@+id/seekbar" android:layout_width="20 ...

  9. android 打造不同的Seekbar

    最近项目需要用到双向的seekbar,网上找了好多野不能达到要求,偶然一次机会看到了大众点评的例子,然后我最他做了优化,并对常用的seekbar做了总结. 向上两张图: 比如双向seekbar pub ...

随机推荐

  1. Common Subsequence(dp)

    Common Subsequence Time Limit: 2 Sec  Memory Limit: 64 MBSubmit: 951  Solved: 374 Description A subs ...

  2. Linux 中的 wheel 组和 staff 组

    wheel 组的概念 wheel 组的概念继承自 UNIX.当服务器需要进行一些日常系统管理员无法执行的高级维护时,往往就要用到 root 权限:而“wheel” 组就是一个包含这些特殊权限的用户池: ...

  3. Linux下建立软链接

    实例:ln -s /home/gamestat    /gamestat Linux下的软链接类似于windows下的快捷方式 ln -s a b 中的 a 就是源文件,b是链接文件名,其作用是当进入 ...

  4. HDU 1878 欧拉回路 图论

    解题报告:题目大意,给出一个无向图,判断图中是否存在欧拉回路. 判断一个无向图中是否有欧拉回路有一个充要条件,就是这个图中不存在奇度定点,然后还要判断的就是连通分支数是否为1,即这个图是不是连通的,这 ...

  5. [LA4108]SKYLINE

    [LA4108]SKYLINE 试题描述 The skyline of Singapore as viewed from the Marina Promenade (shown on the left ...

  6. Coursera台大机器学习技法课程笔记04-Soft-Margin Support Vector Machine

    之前的SVM非常的hard,要求每个点都要被正确的划分,这就有可能overfit,为此引入了Soft SVM,即允许存在被错分的点,将犯的错放在目 标函数中进行优化,非常类似于正则化. 将Soft S ...

  7. Maven使用常见问题整理

    Maven使用常见问题整理  1.更新eclipse的classpath加入新依赖  1.在dependencyManagement里面加入包括版本在内的依赖信息,如:   <dependenc ...

  8. 已知局域网IP地址,如何查看mac

    arp -a 加对方IP是查对方的MAC地址 转自: http://zhidao.baidu.com/link?url=8sRdpGcjfGQ-C1F9zNub49Mxe3DAR-RCAHDkHvKC ...

  9. 61. 从1到n,共有n个数字,每个数字只出现一次。从中随机拿走一个数字x,请给出最快的方法,找到这个数字。如果随机拿走k(k>=2)个数字呢?[find k missing numbers from 1 to n]

    [本文链接] http://www.cnblogs.com/hellogiser/p/find-k-missing-numbers-from-1-to-n.html  [题目] 从1到n,共有n个数字 ...

  10. iOS 使用UIWebView把oc代码和javascript相关联

    首先请参看一篇文章,作者写的很明白,请参看原地址 http://blog.163.com/m_note/blog/static/208197045201293015844274/. 其实,oc和js的 ...