用VC 6.0写flash播放器——5、全屏播放

简介: 用VC 6.0写flash播放器——5、全屏播放

为了让flash可以全屏显示,我们需要为播放窗口添加一个全屏播放按钮,同时为作为flash播放窗口的对话框添加一个BOOL型的成员变量m_IsFullScr,来记录是否为全屏状态。由于flash控件本身具有显示在其它控件前面的特性,因此我们只需要把flash控件大小设置为全屏,而不需要将其它的控件设置成隐藏。不过,由于程序使用定时器动态显示当前帧数的关系,因此当前帧数的信息还是会显示出来,影响flash的全屏播放的效果,所以我们要隐藏状态栏,或者Kill掉定时器。

当用户点击全屏播放按钮时的处理代码如下:

void CSwfPlayerDlg::OnbtnFullScr()//全屏播放
{
 // TODO: Add your control notification handler code here
 if(false==m_IsFullScr)
 {
  GetWindowPlacement(&m_DefDlgPos); 
  ::ShowWindow(m_hStatusWindow, SW_HIDE);//隐藏状态栏
  SetWindowLong(m_hDlg, GWL_STYLE, GetWindowLong(m_hDlg, GWL_STYLE) - WS_CAPTION);//去掉标题栏
  CClientDC dc(this);
  int horzres = dc.GetDeviceCaps(HORZRES);
  int vertres = dc.GetDeviceCaps(VERTRES);
  this->MoveWindow(0, 0, horzres, vertres);
  m_SwfBox.SetWindowPos(&CWnd::wndTop, 0, 0, horzres, vertres, SWP_SHOWWINDOW);//让flash全屏显示
  m_IsFullScr = true;
 } 
}

当播放窗口全屏显示时,为了能通过按下Esc键来退出全屏状态,我们为作为flash播放窗口的对话框添加一个PreTranslateMessage方法,代码如下:

BOOL CSwfPlayerDlg::PreTranslateMessage(MSG* pMsg) 
{
 if (pMsg->message == WM_KEYDOWN && pMsg->wParam==VK_ESCAPE)//如果按下Esc键
 {
  if (true==m_IsFullScr)//是全屏显示
  {
   SetWindowLong(m_hDlg, GWL_STYLE, GetWindowLong(m_hDlg, GWL_STYLE) + WS_CAPTION);//恢复标题栏
   ShowWindow(SW_HIDE);
   SetWindowPlacement(&m_DefDlgPos);
   m_IsFullScr = false;
   ::ShowWindow(m_hStatusWindow, SW_SHOW);//显示状态栏
  }
  return true;//防止按Esc键关闭对话框
 }
 return CDialog::PreTranslateMessage(pMsg);
}
相关文章
Qt类结构分析
Qt类结构分析
318 3
|
自然语言处理 JavaScript 前端开发
使用Pagefind为VitePress文档添加离线全文搜索能力
前言 VitePress 相信大家都或多或少听说过或者用过了 默认 UI相比 VuePress2.x 好看,启动速度也快(由Vite驱动,当然VuePress也可以切换构建引擎至Vite) 做内容定制也相对简单,笔者的很多静态文档站点(使用VuePress1.x),文章内容多的时候启动非常的慢,于是就从之前的 VuePress 迁移到了 VitePress,并做了一个博客主题 @sugarat/theme => 之前也有过介绍一个简约风的VitePress博客主题 但是 VitePress 官方目前还没有内置开箱即用的搜索能力(相关PR还在施工中)
1162 0
|
机器学习/深度学习 人工智能 安全
云工开物合作动态丨2025西安交通大学 -阿里云课程(第一批)上线
2025年春季学期,西安交通大学联合阿里云推出九门特色课程,涵盖工程、法律、生命科学、经济管理等领域。这些课程打破传统学科壁垒,提供AI实践工具、动手实验资源及专属算力支持,帮助学生在理论学习之余进行实际操作,提升能力。结课后还将颁发阿里云创作者证书,助力学生成长为跨领域复合型人才。无论专业背景如何,都能找到适合自己的AI进化路径。机会难得,不容错过!
|
9月前
|
机器学习/深度学习 监控 安全
基于YOLOv8的有无戴安全帽检测识别项目
本项目通过集成 YOLOv8 强大的目标检测能力与 PyQt5 的可视化界面,构建了一个 实用性强、易于部署、安全帽自动识别系统。无论是单张图片、视频监控,还是实时摄像头输入,该系统均可稳定工作,准确判断佩戴与未佩戴状态,极大减轻了传统人工巡查压力。
基于YOLOv8的有无戴安全帽检测识别项目
|
存储 API
vue3中如何动态自定义创建组件并挂载
vue3中如何动态自定义创建组件并挂载
1372 90
|
前端开发 数据可视化 JavaScript
表格中添加渐变色带,表格中添加多色色带,el-table中添加渐变色带,elementUI表格添加色带
写代码不能局限于使用他人或机构、组织封装的代码,而需要更多的去了解人家的底层设计,多尝试二次开发,比如这里的后端排序接口,只需要一点点思路上的变动就能变成前端的动态排序接口,这就是思路带来的改变,如果只会用官方文档提供的API,是做不来一个优质的程序员的。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要
|
数据库 数据库管理 索引
主键和唯一键有什么区别?
【8月更文挑战第1天】
1325 6
主键和唯一键有什么区别?
|
前端开发
ThreeJs通过canvas和Sprite添加标签
这篇文章介绍了在Three.js中利用Canvas和Sprite实现动态文本标签的方法,使得标签可以跟随模型并在3D空间中始终保持面向摄像机。
906 0
ThreeJs通过canvas和Sprite添加标签
Vue3标签页(Tabs)
该组件提供可自定义的标签页功能,支持居中显示、不同尺寸与样式,并能设置当前激活选项。其主要属性包括标签页数组、居中显示、尺寸、样式、间隙及激活键值。示例展示了基本使用、卡片式标签页、禁用选项、左右滑动等功能。组件基于Vue3开发,并利用`useResizeObserver`等技术实现。[在线预览](https://themusecatcher.github.io/vue-amazing-ui/guide/components/tabs.html)。
1194 0
Vue3标签页(Tabs)
|
安全 内存技术
【文件上传-配置文件】crossdomain.xml跨域策略配置文件上传
【文件上传-配置文件】crossdomain.xml跨域策略配置文件上传