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();
   }
}

为了方便大家了解整个过程,项目的源码:MFC实现滚动字幕

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • MFC对话框中实现走马灯效果

    本文实例为大家分享了MFC对话框中实现走马灯,文字信息循环播放显示效果,供大家参考,具体内容如下 CMFCDlg.h 对话框 // CMFCDlg.h 对话框 class CMFCDlg : public CDialogEx { // 构造 public: CMFCDlg(CWnd* pParent = nullptr); // 标准构造函数 // 对话框数据 #ifdef AFX_DESIGN_TIME enum { IDD = IDD_DLG_M }; #endif // 实现 protec

  • MFC实现字幕滚动效果

    本文实例为大家分享了MFC实现字幕滚动效果的具体代码,供大家参考,具体内容如下 1.创建对话框工程 这一步很简单,可以参考我之前的博客.这里可以先放出我程序运行的效果图.如果不是你所需要的可以直接关闭博客了. 2.添加控件 在界面上面主要用到的就是CStatic, Cedit,Cbutton这里给我我对话框的资源图: 3.添加消息 需要添加定时消息,背景颜色消息,添加消息: ON_WM_CTLCOLOR() ON_WM_TIMER() HBRUSH CDemoLEDDlg::OnCtlColor

  • Qt实现字幕滚动效果的示例代码

    目录 一.项目介绍 二.项目基本配置 三.UI界面设计 四.主程序实现 4.1 widget.h头文件 4.2 widget.cpp源文件 五.效果演示 一.项目介绍 利用QTimer实现字幕滚动功能,可以实现自行更改文本内容.自适应文本大小.自由调整速度等功能. 二.项目基本配置 新建一个Qt案例,项目名称为“TextScroll”,基类选择“QWidget”,取消创建UI界面复选框的选中状态,完成项目创建. 三.UI界面设计 无UI界面 四.主程序实现 4.1 widget.h头文件 声明私

  • Android实现字幕滚动的方法

    本文实例介绍了安卓Android实现字幕滚动效果的方法.主要是一个现成的Java类文件实现的,该程序由Android达人Tony编写,本次是转发,还望原作者Tony不要介意.这个Android字幕滚动类的自定义功能比较多,可定义当前滚动到结尾时的停顿时间,单位:毫秒,还可设置当前的滚动速度,值越小,速度越快. 主要实现代码如下: package com.tony.autoscroll; import android.content.Context; import android.os.Handl

  • Android编程实现类似天气预报图文字幕垂直滚动效果的方法

    本文实例讲述了Android编程实现类似天气预报图文字幕垂直滚动效果的方法.分享给大家供大家参考,具体如下: 在很多天气或者新闻的应用中,我们都能看到一些字幕滚动的效果,最简单的实现为跑马灯效果,用系统提供的属性即可实现. 复杂一些的就需要自己去用自定义控件实现. 比如 让TextView 实现垂直滚动. 这里我要讲的是垂直滚动的字幕效果,并且内容并不仅为文字,还可以加入图片或者其他元素. 废话不多说,还是直接上效果图: 首先还是看一下核心的实现: 目前我的做法是重写了ScrollView,对外

  • javascript 实现滚动效果代码整理

    1.先写两个最常用最简洁的滚动代码 代码如下: 水平滚动: <marquee direction="left" align="bottom" height="25" width="100%" onmouseout="this.start()" onmouseover="this.stop()" scrollamount="2" scrolldelay="

  • 微信小程序实现自上而下字幕滚动

    本文实例为大家分享了微信小程序实现字幕滚动的具体代码,供大家参考,具体内容如下 需求: 实现框内的文字自下而上的自动循环滚动. 解决方案: 第一种方法: 经查询,最一开始实现字幕滚动是使用的微信小程序的swiper组件,后来发现,使用swiper组件实现的效果类似于轮播图,不符合需求. <swiper class="swiper_container" vertical="true" autoplay="true" circular=&quo

  • js实现可控制左右方向的无缝滚动效果

    本文实例为大家分享了无缝滚动效果JavaScript代码实现,供大家参考,具体内容如下] 效果图: 实现代码: <!DOCTYPE html> <html> <head> <meta charset="gb2312" /> <title>zzzz</title> <style> *{ margin: 0; padding:0; } body{ width: 1000px; margin: 100px a

  • jquery实现的一个导航滚动效果具体代码

    在做校园网视频网站的时候,首页有一个导航页面要实现滚动效果,有样例,但代码是在难弄懂,貌似网页设计这块还是只有自己的代码自己懂,索性就仿造别人的效果自己做了一个,大体上还行,看起来还是比较流畅的,不次于原作的幺. 现在先把代码拷贝到这里,以后再逐一简化修改: 实现滚动效果,脚本代码如下: 复制代码 代码如下: var all=0; var no=0; var s_width=0; $(document).ready(function(){ all=$('.slide').length; s_wi

  • jquery实现网页的页面平滑滚动效果代码

    本文实例讲述了jquery实现网页的页面平滑滚动效果代码.分享给大家供大家参考,具体如下: 这款网页页面平滑滚动jquery代码,点击链接会让网页平滑滚动到链接对应的位置. 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js/2015/jquery-link-scroll-page-codes/ 具体代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" &quo

  • 简单易用的基于jQuery版仿新浪微博向下滚动效果(附DEMO)

    简单易用的jQuery 写的仿新浪微博 向下滚动效果 $(function(){ var scrtime; $("#con").hover(function(){ clearInterval(scrtime); },function(){ scrtime = setInterval(function(){ var $ul = $("#con ul"); var liHeight = $ul.find("li:last").height(); $u

随机推荐