Dev TrackBar的使用--坐标轴反转以及滚轮反向解决

简介: Dev TrackBar的使用--坐标轴反转以及滚轮反向解决

最近,在用GDI+绘图的过程中,做了一个用滚动条控制刷新所绘区域的功能,因为滚动条改变,只重绘固定的区域,只显示该区域内的数据,所以选择了dev 的Track bar,其实,多数问题可能都是不了解属性所致,如下,直接给出关键的属性图,

1694152094464.png

从上图可以看出,通过属性,可以控制trackbar的轴方向以及轴上值得排列方向,而且可以通过自定义刻度,间距等,来绘制自己所需得样式。

另外,trackbar默认支持滚轮,但是,其滚轮得滚动方向和实际所需效果是相反的(即,往上滚动是,竖轴值向下移动,反之,向上移动),这于操作习惯不符,分析原因,我觉得可能是反转了坐标轴导致的,默认的横轴下的滚轮操作,左侧为小值,向上滚动时,值向右侧移动,当为竖轴时,小值在底部,向上滚动,值向上移动,值增大,当坐标轴反转后,顶部为小值,向上滚动时,值增大,于排列相反,如此,便导致这种现象。

解决办法时:

设置属性AllowMouseWheel为false,再添加trackbar的mousewheel事件来自定义滚动事件,如下:

private void trackBarControl1_Properties_MouseWheel(object sender, MouseEventArgs e)
        {
            if (e.Delta<0)
            {//往下滚动
                //MessageBox.Show("1");
                this.trackBarControl1.Value += 1;
                trackBarControl1.Refresh();
                trackBarControl1.Invalidate();
                trackBarControl1.Update();
            }
            else
            {//往上滚动
                //MessageBox.Show("2");
                trackBarControl1.Value -= 1;
            }
        }

如此,便可实现与其他滚动条相似的功能。


测试发现,刻度排列不可逆,暂时无其他方法可以解决这个问题,若有的话,还请大神告知,谢谢。

相关文章
G2Plot Tooltip 自定义头部、尾部、辅助线
G2Plot Tooltip 自定义头部、尾部、辅助线
253 0
|
4月前
|
JavaScript
js【图解】滚动条的位置(文档与屏幕间的距离),鼠标事件距离(位置),元素距离(位置)
js【图解】滚动条的位置(文档与屏幕间的距离),鼠标事件距离(位置),元素距离(位置)
96 7
G2Plot Line 线性 x 轴头尾两头不留空白(或指定留白范围)
G2Plot Line 线性 x 轴头尾两头不留空白(或指定留白范围)
109 0
|
6月前
|
前端开发 JavaScript
改变光标形状的多种方式
改变光标形状的多种方式
Range滑动条颜色分区问题
Range滑动条颜色分区问题
99 1
LeetCode-2038 如果相邻两个颜色均相同则删除当前颜色
LeetCode-2038 如果相邻两个颜色均相同则删除当前颜色
如何反转ggplot2中的图例键顺序
如何反转ggplot2中的图例键顺序
96 0
ENVI_IDL:如何对影像进行各种方式的上下左右的颠倒或者翻转.
ENVI_IDL:如何对影像进行各种方式的上下左右的颠倒或者翻转.
333 0
【IMAQ】imaqMakeRect() 返回指定位置和大小的矩形
【IMAQ】imaqMakeRect() 返回指定位置和大小的矩形