MFC滚动字幕实现

MFC滚动字幕实现

1创建对话框工程

         这一步很简单,可以参考我之前的博客。这里可以先放出我程序运行的效果图。如果不是你所需要的可以直接关闭博客了。

2添加控件

         在界面上面主要用到的就是CStatic, Cedit,Cbutton这里给我我对话框的资源图:

3添加消息

         需要添加定时消息,背景颜色消息,添加消息:

ON_WM_CTLCOLOR()
ON_WM_TIMER()
HBRUSH CDemoLEDDlg::OnCtlColor(CDC*pDC, CWnd* pWnd, UINT nCtlColor)
{
         HBRUSH hbr = CDialogEx::OnCtlColor(pDC,pWnd, nCtlColor);
         if(nCtlColor== CTLCOLOR_STATIC) 
         { 
                   pDC->SetBkMode(TRANSPARENT); 
                   pDC->SetTextColor(RGB(255,0, 0));    
                   return(HBRUSH)::GetStockObject(NULL_BRUSH);    
         }
         returnhbr;
}

4字体初始化

在OnInitDialog()函数中设置我们字幕要使用的字体,这里采用最简单的字体设置方式。

m_font->CreatePointFont(160,_T("宋体"));

5字幕创建

         我们点击开始的时候,创建字幕的显示。首先获窗口的大小,设置字幕的static大小,并且在窗口最右边显示。设置字幕的字体。启动字幕移动的定时器。

void CDemoLEDDlg::OnBnClickedButton1()
{
         if(m_flag) {
                   SetTimer(1, 500, NULL);
                   m_flag = false;
                   return;
         }
 
         CString info;
         m_info.GetWindowTextW(info);
 
         CRect cRect;
         GetClientRect(cRect);     
<span style="white-space:pre">	</span> m_cx = cRect.Width();
         m_cy = cRect.Height();
 
         m_static->Create(info, WS_CHILD |WS_VISIBLE | SS_CENTER, CRect(m_cx - 30, 100, m_cx - 300 + 30, 140), this, IDC_STATIC_INFO);
         m_static->SetFont(m_font, FALSE);
 
         SetTimer(1, 500, NULL); 
}

6字幕滚动

         我们设置的定时器是500毫秒,也就是每500毫秒执行一次这个函数。在这个函数中,我们控制每次向左移动30,当移动完了之后,关闭定时器。重新从右边开始显示,并且重启开始定时器。

void CDemoLEDDlg::OnTimer(UINT_PTR nIDEvent)
{
         if (1== nIDEvent)
         {
                   m_static->SetWindowPos(NULL,m_cx - 30, 100, 300, 40, SWP_NOZORDER);
                   m_cx = m_cx - 30;
                   if(m_cx < -250) {
                            KillTimer(1);
                            m_cx = GetSystemMetrics(SM_CXSCREEN);
                            m_static->SetWindowPos(NULL,m_cx - 30, 100, 300, 40, SWP_NOZORDER);
                            SetTimer(1, 500,NULL);
                   }
         }
 
         CDialogEx::OnTimer(nIDEvent);
}

7字幕背景

         字幕的背景在OnPaint中设置,设置背景色为黑色。

void CDemoLEDDlg::OnPaint()
{
         if(IsIconic())
         {
                   SendMessage(WM_ICONERASEBKGND,reinterpret_cast<WPARAM>(dc.GetSafeHdc()),0);
                   intcxIcon = GetSystemMetrics(SM_CXICON);
                   intcyIcon = GetSystemMetrics(SM_CYICON);
                   CRect rect;
                   GetClientRect(&rect);
                   intx = (rect.Width() - cxIcon + 1) / 2;
                   inty = (rect.Height() - cyIcon + 1) / 2;
                   dc.DrawIcon(x, y, m_hIcon);
         }
         else
         {
                   CPaintDC dc(this);
                   CRect cRect;
                   GetClientRect(cRect);
                   CRect fRect(0, 90,cRect.Width(), 130);
                   dc.FillSolidRect(fRect,RGB(0, 0, 0));
                   CDialogEx::OnPaint();
         }
}

为了方便大家了解整个过程,项目的源码:http://download.csdn.net/detail/u012377333/9540980

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值