用vc++做滚动条控件
时间:2022-04-22
本文章向大家介绍用vc++做滚动条控件,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
首先用应用向导产生一名为scro的基于对话框的应用,再利用对话框编辑器加入两个一样的水平滚动条,两个滚动条的id分别取idc—scr1和idc—scr2,结果如下图,将其作为本文的示例。
对话框编辑器虽然允许将滚动条控件加进对话框中,而且,类向导允许加入数据成员,但要使这两个水平滚动条工作,还必须加进一些代码。就本例程序,当用户拖动滚动块或用鼠标滚动箭头时,滚动条就会向对话框发送WM_HSCROLL消息,对话框消息控制函数必须对这一消息进行处理,然后将滚动块定位到相应的位置上。 一般情况下,对话框中的每一控件都有自己独立的消息控制函数,但滚动条控件则有点不同,因为对话框中所有的水平滚动条都只有一个WM_HSCROLL消息控制函数,而所有的垂直滚动条都只有一个WM_HSCROLL消息控制函数。如果对话框中只有一个水平(或垂直)滚动条,则不会出现什么问题,问题是本例程序有一特殊之处,笔者有意设置了两个水平滚动条,可按前述都用一个WM_HSCROLL消息控制函数,所以程序必须能识别出哪个滚动条在发送消息。下面是具体步骤。 1.定义滚动范围的最大值和最小值。 在scrodlg.h类声明中的最上面加入下面两行。
enum {nmin=0};
enum {nmax=100};
2.修改oninitdialog函数,初始化滚动范围,决定那一个滚动条发送消息。
// todo: add extra initialization here
cscrollbar* psb = (cscrollbar*) getdlgitem(idc—scr1);
psb-〉setscrollrange(nmin, nmax);
psb = (cscrollbar*) getdlgitem(idc_scr2);
psb-〉setscrollrange(nmin, nmax);
3.利用classwizard在cscrodlg中加入滚动条消息控制函数,即选择wm—hscroll消息,然后加进onhscroll成员函数,并在其中加入如下代码:
void cscrodlg::onhscroll(uint nsbcode, uint npos, cscrollbar* pscrollbar)
{// todo: add your message handler code here and/or call default
int ntemp1, ntemp2;
ntemp1 = pscrollbar-〉getscrollpos();
switch(nsbcode)
{
case sb—thumbposition:
pscrollbar-〉setscrollpos(npos);
break;
case sb—lineleft: // 左按钮
ntemp2 = (nmax - nmin) / 10; //划为10等份
if ((ntemp1 - ntemp2) 〉 nmin)
{
ntemp1 -= ntemp2;
}
else
{
ntemp1 = nmin;
}
pscrollbar-〉setscrollpos(ntemp1);
break;
case sb—lineright: // 右箭头按钮
ntemp2 = (nmax - nmin) / 10;
if ((ntemp1 + ntemp2) 〈 nmax)
{
ntemp1 += ntemp2;
}
else
{
ntemp1 = nmax;
}
pscrollbar-〉setscrollpos(ntemp1);
break;
}
cdialog::onhscroll(nsbcode, npos, pscrollbar);}
4.现在可以编译、测试程序了。
- Java之StringBuffer,StringBuilder,Math,Date,SimpleDateFormat,UUID,File
- React编程思想
- 前台分页,以及类别选择
- 使用angular4和asp.net core 2 web api做个练习项目(二), 这部分都是angular
- 数据库 105道题目整理与吐血总结
- 使用angular4和asp.net core 2 web api做个练习项目(一)
- =.=
- JavaScript经典面试题之for循环click
- 学习docker on windows (1): 为什么要使用docker
- 使用VS Code开发asp.net core (下)
- 使用VS Code开发asp.net core (上)
- 小程序开发总结
- Silverlight Load Client Image 加载客户端图片
- 使用xUnit为.net core程序进行单元测试(4)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Linux文件访问控制列表、su命令与sudo服务
- GPS之 NMEA-0183协议
- Zeppelin 安装与初体验
- Hive 安装与配置
- 如何将SAP Cloud for Customer的扩展字段放置到Embedded Component中
- pthread的使用
- shell程序设计
- SAP CDS view权限控制实现原理介绍
- shell程序设计的流程控制
- SAP CRM数据库表CRMD_SRV_REFOBJ和CRMD_SRV_OSSET
- 堆和栈的区别
- 用ABAP模拟JavaScript的柯里化语言特性(Curry)
- 使用ABAP并发编程解决一个实际应用场景中的性能瓶颈问题
- SAP Cloud for Customer Oberon视图里的Ruby Scrip
- 干了SAP开发这么多年,我都积累了哪些程序调试技巧