|
29 | 29 | import androidx.annotation.StyleRes; |
30 | 30 |
|
31 | 31 | @SuppressLint("MissingSuperCall") |
32 | | -public class FastScrollScrollView extends ScrollView implements SimpleFastScrollView { |
| 32 | +public class FastScrollScrollView extends ScrollView implements ViewHelperProvider { |
33 | 33 |
|
34 | 34 | @NonNull |
35 | | - private SimpleFastScrollViewMixin mMixin; |
| 35 | + private final ViewHelper mViewHelper = new ViewHelper(); |
36 | 36 |
|
37 | 37 | public FastScrollScrollView(@NonNull Context context) { |
38 | 38 | super(context); |
@@ -63,76 +63,79 @@ public FastScrollScrollView(@NonNull Context context, @Nullable AttributeSet att |
63 | 63 | private void init() { |
64 | 64 | setVerticalScrollBarEnabled(false); |
65 | 65 | setScrollContainer(true); |
66 | | - mMixin = new SimpleFastScrollViewMixin(new SimpleFastScrollViewMixin.ViewAccessor() { |
67 | | - @Override |
68 | | - public void superDraw(@NonNull Canvas canvas) { |
69 | | - FastScrollScrollView.super.draw(canvas); |
70 | | - } |
71 | | - @Override |
72 | | - public void superOnScrollChanged(int left, int top, int oldLeft, int oldTop) { |
73 | | - FastScrollScrollView.super.onScrollChanged(left, top, oldLeft, oldTop); |
74 | | - } |
75 | | - @Override |
76 | | - public boolean superOnInterceptTouchEvent(@NonNull MotionEvent event) { |
77 | | - return FastScrollScrollView.super.onInterceptTouchEvent(event); |
78 | | - } |
79 | | - @Override |
80 | | - public boolean superOnTouchEvent(@NonNull MotionEvent event) { |
81 | | - return FastScrollScrollView.super.onTouchEvent(event); |
82 | | - } |
83 | | - @Override |
84 | | - public int computeVerticalScrollRange() { |
85 | | - return FastScrollScrollView.this.computeVerticalScrollRange(); |
86 | | - } |
87 | | - @Override |
88 | | - public int computeVerticalScrollOffset() { |
89 | | - return FastScrollScrollView.this.computeVerticalScrollOffset(); |
90 | | - } |
91 | | - }); |
92 | 66 | } |
93 | 67 |
|
| 68 | + @NonNull |
94 | 69 | @Override |
95 | | - public void setOnPreDrawListener(@Nullable Runnable listener) { |
96 | | - mMixin.setOnPreDrawListener(listener); |
| 70 | + public FastScroller.ViewHelper getViewHelper() { |
| 71 | + return mViewHelper; |
97 | 72 | } |
98 | 73 |
|
99 | 74 | @Override |
100 | 75 | public void draw(@NonNull Canvas canvas) { |
101 | | - mMixin.draw(canvas); |
102 | | - } |
103 | | - |
104 | | - @Override |
105 | | - public void setOnScrollChangedListener(@Nullable Runnable listener) { |
106 | | - mMixin.setOnScrollChangedListener(listener); |
| 76 | + mViewHelper.draw(canvas); |
107 | 77 | } |
108 | 78 |
|
109 | 79 | @Override |
110 | 80 | protected void onScrollChanged(int left, int top, int oldLeft, int oldTop) { |
111 | | - mMixin.onScrollChanged(left, top, oldLeft, oldTop); |
112 | | - } |
113 | | - |
114 | | - @Override |
115 | | - public void setOnTouchEventListener(@Nullable Predicate<MotionEvent> listener) { |
116 | | - mMixin.setOnTouchEventListener(listener); |
| 81 | + mViewHelper.onScrollChanged(left, top, oldLeft, oldTop); |
117 | 82 | } |
118 | 83 |
|
119 | 84 | @Override |
120 | 85 | public boolean onInterceptTouchEvent(@NonNull MotionEvent event) { |
121 | | - return mMixin.onInterceptTouchEvent(event); |
| 86 | + return mViewHelper.onInterceptTouchEvent(event); |
122 | 87 | } |
123 | 88 |
|
124 | 89 | @Override |
125 | 90 | public boolean onTouchEvent(@NonNull MotionEvent event) { |
126 | | - return mMixin.onTouchEvent(event); |
| 91 | + return mViewHelper.onTouchEvent(event); |
127 | 92 | } |
128 | 93 |
|
129 | | - @Override |
130 | | - public int getScrollRange() { |
131 | | - return mMixin.getScrollRange() + getPaddingTop() + getPaddingBottom(); |
132 | | - } |
133 | | - |
134 | | - @Override |
135 | | - public int getScrollOffset() { |
136 | | - return mMixin.getScrollOffset(); |
| 94 | + private class ViewHelper extends SimpleViewHelper { |
| 95 | + |
| 96 | + @Override |
| 97 | + public int getScrollRange() { |
| 98 | + return super.getScrollRange() + getPaddingTop() + getPaddingBottom(); |
| 99 | + } |
| 100 | + |
| 101 | + @Override |
| 102 | + protected void superDraw(@NonNull Canvas canvas) { |
| 103 | + FastScrollScrollView.super.draw(canvas); |
| 104 | + } |
| 105 | + |
| 106 | + @Override |
| 107 | + protected void superOnScrollChanged(int left, int top, int oldLeft, int oldTop) { |
| 108 | + FastScrollScrollView.super.onScrollChanged(left, top, oldLeft, oldTop); |
| 109 | + } |
| 110 | + |
| 111 | + @Override |
| 112 | + protected boolean superOnInterceptTouchEvent(@NonNull MotionEvent event) { |
| 113 | + return FastScrollScrollView.super.onInterceptTouchEvent(event); |
| 114 | + } |
| 115 | + |
| 116 | + @Override |
| 117 | + protected boolean superOnTouchEvent(@NonNull MotionEvent event) { |
| 118 | + return FastScrollScrollView.super.onTouchEvent(event); |
| 119 | + } |
| 120 | + |
| 121 | + @Override |
| 122 | + protected int computeVerticalScrollRange() { |
| 123 | + return FastScrollScrollView.this.computeVerticalScrollRange(); |
| 124 | + } |
| 125 | + |
| 126 | + @Override |
| 127 | + protected int computeVerticalScrollOffset() { |
| 128 | + return FastScrollScrollView.this.computeVerticalScrollOffset(); |
| 129 | + } |
| 130 | + |
| 131 | + @Override |
| 132 | + protected int getScrollX() { |
| 133 | + return FastScrollScrollView.this.getScrollX(); |
| 134 | + } |
| 135 | + |
| 136 | + @Override |
| 137 | + protected void scrollTo(int x, int y) { |
| 138 | + FastScrollScrollView.this.scrollTo(x, y); |
| 139 | + } |
137 | 140 | } |
138 | 141 | } |
0 commit comments