MFC滚动条测试

一个滚动条的问题困扰我很久, 主要是掉进了设备坐标和逻辑坐标的误区, 以及滚动位置取值问题的误区.

测试代码承上做个纪念

Demo程序初始化代码不贴出来了, 过程很简单.

  • 创建一个对话框;
  • 设置对话框属性, 显示横向滚动条;
  • 拖进一个Button,并创建变量ct_btn_add_
  • 添加一个横向滚动的消息;

在对话框类里添加了如下变量

CArray<CButton*, CButton*> btns_;    // 用来存储创建的Button
int n_btn_id_;     // 用于累加Create Button的ID
CButton ct_btn_add_;    // 增加Button的按钮,这个是固定的,需要在资源编辑器里托到对话框里
const int BTN_SIZE_;    // Button的边长

对话框的初始化, 放在OnInitDialog即可

n_btn_id_ = 5000;
BTN_SIZE_ = 30;

CRect rt_dlg;
GetClientRect(rt_dlg);

CRect rt_btn;
for (int i = 0; i < 10; i++)
{
	rt_btn.left = rt_dlg.left + i*BTN_SIZE_;
	rt_btn.right = rt_btn.left + BTN_SIZE_;
	rt_btn.top = rt_dlg.top;
	rt_btn.bottom = rt_btn.top + BTN_SIZE_;
	CButton* p_btn = new CButton;
	CString cs_btn;
	cs_btn.Format(_T("%d"), i+1);
	p_btn->Create(cs_btn, 0, rt_btn, this, n_btn_id_++);
	p_btn->ShowWindow(SW_SHOW);
	btns_.Add(p_btn);
}

CRect rt_add(rt_btn);
rt_add.left = rt_btn.right;
rt_add.right = rt_add.left + BTN_SIZE_;
ct_btn_add_.MoveWindow(rt_add);

SCROLLINFO si;
si.cbSize = sizeof(si);
si.fMask = SIF_PAGE | SIF_RANGE;
si.nMin = 0;
si.nMax = (rt_add.right - rt_dlg.left) - 1;
si.nPage = rt_dlg.Width();
SetScrollInfo(SB_HORZ, &si);

OnHScroll()内容如下

	SCROLLINFO si;
	si.cbSize = sizeof(si);
	si.fMask = SIF_POS | SIF_RANGE | SIF_TRACKPOS | SIF_PAGE;
	GetScrollInfo(SB_HORZ, &si);
	int xPos = si.nPos;
	switch (nSBCode)
	{
 	case SB_LINELEFT:
 		break;
 	case SB_LINERIGHT:
 		break;
 	case SB_PAGELEFT:
 		break;
 	case SB_PAGERIGHT:
 		break;
	case SB_THUMBPOSITION:
	{
		si.nPos = si.nTrackPos;
		break;
	}
	default:
		return;
	}

	SetScrollInfo(SB_HORZ, &si);
	GetScrollInfo(SB_HORZ, &si);

	// If the position has changed, scroll the window.
	if (si.nPos != xPos)
	{
		ScrollWindow((xPos - si.nPos), 0);
	}

	CDialogEx::OnHScroll(nSBCode, nPos, pScrollBar);

增加按钮的Button单击事件OnBnClickedButtonAdd()内容如下

	SCROLLINFO si;
	si.cbSize = sizeof(si);
	si.fMask = SIF_PAGE | SIF_RANGE | SIF_POS;
	GetScrollInfo(SB_HORZ, &si);

	int n_btn_count = btns_.GetCount();
	CRect rt_dlg;
	GetClientRect(rt_dlg);

	CRect rt_btn;
	int n_test = n_btn_count*BTN_SIZE_;
	rt_btn.left = n_test - si.nPos;
	rt_btn.right = rt_btn.left + BTN_SIZE_;
	rt_btn.top = rt_dlg.top;
	rt_btn.bottom = rt_btn.top + BTN_SIZE_;
	CButton* p_btn = new CButton;
	CString cs_btn;
	cs_btn.Format(_T("%d"), n_btn_count+1);
	p_btn->Create(cs_btn, 0, rt_btn, this, n_btn_id_++);
	p_btn->ShowWindow(SW_SHOW);
	btns_.Add(p_btn);

	CRect rt_add(rt_btn);
	rt_add.left = rt_btn.right;
	rt_add.right = rt_add.left + BTN_SIZE_;
	ct_btn_add_.MoveWindow(rt_add);

	//
	n_btn_count = btns_.GetCount();
	si.fMask = SIF_PAGE | SIF_RANGE | SIF_POS;
	si.nMin = 0;
	si.nMax = n_btn_count*BTN_SIZE_ + BTN_SIZE_ - 1;
	si.nPage = rt_dlg.Width();
	si.nPos = si.nMax - si.nPage;
	SetScrollInfo(SB_HORZ, &si);
	ScrollWindow(-BTN_SIZE_, 0);

这样就可以了. 添加按钮后可以实现滚动.

调整对话框大小的功能可以添加在OnSize里, 没什么特别的了.

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MFC中,可以利用滚动条来实现对图片的浏览和滚动功能。 首先,我们需要在MFC应用程序中添加一个滚动条控件。可以在资源视图中的对话框资源上添加一个滚动条控件,然后在代码中声明和绑定该控件。 接下来,我们需要加载要显示的图片。可以使用CImage类来加载图片文件,或者使用其他类似的方法来获取需要显示的图片数据。 在将图片显示到MFC窗口的过程中,我们可以利用滚动条的滚动事件来实现图片的滚动功能。滚动条的范围可以根据图片的大小来确定,用户通过拖动滑块来改变滚动条的位置,从而实现图片的滚动。 在滚动条的滚动事件响应函数中,可以根据滚动条的当前位置来确定需要显示的图片的位置。可以使用CImage的Draw函数将需要显示的部分绘制到MFC窗口中。 需要注意的是,对于较大的图片,为了避免性能问题,可以在滚动过程中只绘制可见部分的图片,当滚动条的位置发生改变时再进行绘制,这样可以减少不必要的绘制操作,提高程序的效率。 另外,还可以根据需要添加其他功能,例如放大缩小图片、旋转图片等,以增加用户的交互体验。 总而言之,使用MFC滚动条来实现图片滚动功能可以让用户方便地浏览较大尺寸的图片,提升用户体验。以上是一个简单的实现思路,具体实现需要根据具体的需求和MFC版本进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值