自定义ScrollView+自定义滚动条
来源:互联网 发布:手机域名价格 编辑:程序博客网 时间:2024/06/03 14:26
主题思路就是,通过scrollView的onScrollChanged的事件,去设置重绘cursor... 当然也可以直接用ScrollTo
先看主界面UserNoticeActivity
这里面有个自定义的控件,很简单。。。
package com.example.demo;import android.annotation.SuppressLint;import android.app.Activity;import android.os.Bundle;import android.view.View;import android.widget.RelativeLayout;import android.widget.TextView;import java.io.InvalidClassException;public class UserNoticeActivity extends Activity {CustomeUserNoticeScrollView user_notice_scroll;CustomeUserNoticeCursor user_notice_cursor;RelativeLayout start_virtual;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.user_notice);initRes();user_notice_scroll.setCursor(user_notice_cursor);}@SuppressLint("WrongViewCast")private void initRes() {user_notice_scroll = (CustomeUserNoticeScrollView) findViewById(R.id.user_notice_scroll);user_notice_cursor = (CustomeUserNoticeCursor) findViewById(R.id.user_notice_cursor);}}CustomeUserNoticeScrollView
package com.example.demo;import android.content.Context;import android.util.AttributeSet;import android.util.Log;import android.widget.ScrollView;public class CustomeUserNoticeScrollView extends ScrollView {CustomeUserNoticeCursor cursor;private float noticeScrollViewTotleHeight;private float noticeScrollViewVisibleHeight;private Context context;public CustomeUserNoticeScrollView(Context context) {this(context, null);}public CustomeUserNoticeScrollView(Context context, AttributeSet attrs,int defStyle) {super(context, attrs, defStyle);this.context = context;}public CustomeUserNoticeScrollView(Context context, AttributeSet attrs) {this(context, attrs, 0);}@Overrideprotected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {super.onMeasure(widthMeasureSpec, heightMeasureSpec);noticeScrollViewTotleHeight = this.getChildAt(0).getMeasuredHeight();noticeScrollViewVisibleHeight = this.getHeight();// 3683 900Log.i("TAG", "totle:" + noticeScrollViewTotleHeight + ",visible"+ noticeScrollViewVisibleHeight);}@Overrideprotected void onScrollChanged(int l, int t, int oldl, int oldt) {super.onScrollChanged(l, t, oldl, oldt);float currentScrollY = this.getScrollY();float proportionTotalHeight = currentScrollY/ (noticeScrollViewTotleHeight - noticeScrollViewVisibleHeight);float cursorMoveY = proportionTotalHeight* (noticeScrollViewVisibleHeight - dp2px(context, 30));Log.i("TAG", "currentScrollY:" + currentScrollY+ ",proportionVisibleHeight--" + cursorMoveY);// cursor.scrollTo(0, -(int) proportionVisibleHeight);cursor.SetOffSet(cursorMoveY);}public void setCursor(CustomeUserNoticeCursor user_notice_cursor) {this.cursor = user_notice_cursor;}public static int dp2px(Context context, float dpValue) {float scale = context.getResources().getDisplayMetrics().density;return (int) (dpValue * scale + 0.5f);}}
CustomeUserNoticeCursor
package com.example.demo;import android.content.Context;import android.graphics.Canvas;import android.graphics.Paint;import android.graphics.RectF;import android.util.AttributeSet;import android.util.Log;import android.view.View;public class CustomeUserNoticeCursor extends View {Paint mPaint;private Context context;private float userNoticeCursorWidth;public CustomeUserNoticeCursor(Context context, AttributeSet attrs,int defStyle) {super(context, attrs, defStyle);this.context = context;initRes();}private void initRes() {mPaint = new Paint();mPaint.setColor(getResources().getColor(R.color.contentPressColor));mPaint.setStyle(Paint.Style.FILL);mPaint.setAntiAlias(true);userNoticeCursorWidth = dp2px(context, 24);}public CustomeUserNoticeCursor(Context context, AttributeSet attrs) {this(context, attrs, 0);}public CustomeUserNoticeCursor(Context context) {this(context, null);}@Overrideprotected void onDraw(Canvas canvas) {super.onDraw(canvas);RectF rect3 = new RectF(userNoticeCursorWidth / 4, cursorMoveY,userNoticeCursorWidth / 4 * 2, cursorMoveY + dp2px(context, 30));canvas.drawRoundRect(rect3, 10, 10, mPaint);}private float cursorMoveY;public void SetOffSet(float cursorMoveY) {this.cursorMoveY = cursorMoveY;Log.i("TAG", ",proportionVisibleHeight:" + cursorMoveY);invalidate();}//public static int dp2px(Context context, float dpValue) {float scale = context.getResources().getDisplayMetrics().density;return (int) (dpValue * scale + 0.5f);}}
<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#7A000000" android:orientation="vertical" > <LinearLayout android:layout_centerInParent="true" android:layout_width="300dp" android:layout_height="300dp" android:background="@color/white" android:orientation="horizontal" > <com.example.demo.CustomeUserNoticeScrollView android:id="@+id/user_notice_scroll" android:layout_width="0dp" android:layout_height="fill_parent" android:layout_weight="1" android:scrollbars="none" > <TextView android:layout_width="fill_parent" android:layout_height="fill_parent" android:lineSpacingExtra="6dp" android:text="@string/user_notice" android:textColor="#333333" android:textSize="16dp" /> </com.example.demo.CustomeUserNoticeScrollView> <com.example.demo.CustomeUserNoticeCursor android:id="@+id/user_notice_cursor" android:layout_width="24dp" android:layout_height="300dp" android:layout_gravity="center" android:gravity="center_horizontal|top" > </com.example.demo.CustomeUserNoticeCursor> </LinearLayout></RelativeLayout>
还有那些测试数据。。。。。随便写点就行了
0 0
- 自定义ScrollView+自定义滚动条
- 自定义BODY滚动条
- 自定义滚动条
- 自定义datagridview滚动条
- 自定义滚动条
- JPanel自定义滚动条
- 自定义网页滚动条
- 自定义滚动条
- 自定义滚动条插件
- 自定义滚动条
- 自定义滚动条
- css3 自定义滚动条
- 滚动条的自定义
- 拖拽+自定义滚动条
- 自定义滚动条样式
- 自定义滚动条
- 自定义View 滚动条
- 自定义滚动条
- 如何安装配置gradle及eclipse的结合
- ACM输入问题以及矩阵最大路径累加和
- 【Vuforia】Vuforia实现自动对焦
- [leetcode]84. Largest Rectangle in Histogram c语言
- STL学习笔记
- 自定义ScrollView+自定义滚动条
- Akka并发编程——第五节:Actor模型(四)
- 适配器模式----类适配和对象适配
- [查异常网]-20160402-解决「问题」,不要解决问题
- svn1
- JAVA实现LDAP连接验证
- 学习计划
- mac版safari开启调试模式
- 安卓开发的有用网址持续更新中--