VC 屏幕相关操作

vc得到屏幕的当前分辨率方法:
1.Windows API调用
int width = GetSystemMetrics ( SM_CXSCREEN ); 
int height= GetSystemMetrics ( SM_CYSCREEN ); 
如果想动态自适应分辨率的变化,处理WM_DISPLAYCHANGE消息. 
2.获得分辨率
BOOL EnumDisplaySettings( 
LPCTSTR lpszDeviceName, // display device 
DWORD iModeNum, // graphics mode 
LPDEVMODE lpDevMode // graphics mode settings 
);

改变分辨率 
LONG ChangeDisplaySettings( 
LPDEVMODE lpDevMode, // graphics mode 
DWORD dwflags // graphics mode options 
); 
3.用GetDeviceCaps

int GetDeviceCaps( 
HDC hdc, // handle to the device context 
int nIndex // index of capability to query 
);

4.用GetDeviceCaps
HDC hdcScreen = GetDC( NULL ); 
int cx = GetDeviceCaps( hdcScreen, HORZRES ); 
int cy = GetDeviceCaps( hdcScreen, VERTRES ); 
DeleteObject( hdcScreen ); 
其中nIndex可以取: 
HORZRES VERTRES 或 
分别表示: 
HORZRES :Width, in pixels, of the screen. 
VERTRES :Height, in raster lines, of the screen.

也就是设备的分辨率了
5.得到桌面客户区的大小 
(1) 最简单,使用API 
RECT rc; 
SystemParametersInfo(SPI_GETWORKAREA, 0, (PVOID) &rc, 0); 
str.Format("%d*%d",rc.right-rc.left,rc.bottom-rc.top);
(2)间接计算得到:先用上面的3种方法得到这个屏幕的大小,再减去任务栏的大小(注意:要考虑任务栏是否隐藏的情况)
int cx = GetSystemMetrics(SM_CXSCREEN); 
int cy = GetSystemMetrics(SM_CYSCREEN); 
或 
HDC hdcScreen = GetDC( NULL ); 
int cx = GetDeviceCaps( hdcScreen, HORZRES ); 
int cy = GetDeviceCaps( hdcScreen, VERTRES ); 
DeleteObject( hdcScreen );

任务栏: 
CWnd* pTaskWnd = FindWindow( _T("Shell_TrayWnd"), NULL ); 
if( pTaskWnd ) pTaskWnd->ShowWindow( FALSE ); 
任务栏是否隐藏: 
LONG lStyle = GetWindowLong( pTaskWnd->GetSafeHwnd(), GWL_STYLE ); 
if( lStyle & WS_VISIBLE ) 

//可见 

else 

//隐藏 
}

/////////////////////////////////
VC获取屏幕大小
int with= GetSystemMetrics(SM_CXFULLSCREEN);

int heigh= GetSystemMetrics(SM_CYFULLSCREEN);

通过上边两个函数获取的是显示屏幕的大小,及不包括任务栏等区域。

int cx = GetSystemMetrics( SM_CXSCREEN ); 
int cy = GetSystemMetrics( SM_CYSCREEN );

这两个函数获取的是真正屏幕的大小。

用前两个函数获取的大小可能是1024*687 而用下边两个获取的就是1024*768
说明 
返回与windows环境有关的信息 
返回值 
Long,取决于具体的常数索引 
参数表 
参数 类型及说明 
nIndex Long,常数,指定欲获取的信息;如下表所示 
nIndex常数设置 
常数定义 取得信息 
SM_ARRANGE 设置windows如何排列最小化窗口的一个标志。参考api32.txt中的ARW常数 
SM_CLEANBOOT 指定启动模式。0=普通模式;1=带网络支持的安全模式 
SM_CMETRICS 可用系统环境的数量 
SM_CMOUSEBUTTON 鼠标按钮(按键)的数量。如没有鼠标,就为零 
SM_CXBORDER, SM_CYBORDER 尺寸不可变边框的大小 
SM_CXCURSOR, SM_CYCURSOR 标准指针大小 
SM_CXDLGFRAME, SM_CYDLGFRAME 对话框边框的大小 
SM_CXDOUBLECLK, SM_CYDOUBLECLK 双击区域的大小(参考注解) 
SM_CXFRAME, SM_CYFRAME 尺寸可变边框的大小(在win95和nt 4.0中使用SM_C?FIXEDFRAME) 
SM_CXFULLSCREEN, SM_CYFULLSCREEN 最大化窗口客户区的大小 
SM_CXHSCROLL, SM_CYHSCROLL 水平滚动条上的箭头大小 
SM_CXHTHUMB, SM_CYHTHUMB 滚动块在水平滚动条上的大小 
SM_CXICON, SM_CYICON 标准图标的大小 
SM_CXICONSPACING, SM_CYICONSPACING 桌面图标之间的间隔距离。在win95和nt 4.0中是指大图标的间距 
SM_CXMAXIMIZED, SM_CYMAXIMIZED 最大化窗口的默认尺寸 
SM_CXMAXTRACK, SM_CYMAXTRACK 改变窗口大小时,最大的轨迹宽度 
SM_CXMENUCHECK, SM_CYMENUCHECK 菜单复选号位图的大小 
SM_CXMENUSIZE, SM_CYMENUSIZE 菜单栏上的按钮大小 
SM_CXMIN, SM_CYMIN 窗口的最小尺寸 
SM_CXMINIMIZED, SM_CYMINIMIZED 最小化的窗口必须填充进去的一个矩形小于或等于SM_C?ICONSPACING 
SM_CXMINTRACK, SM_CYMINTRACK 窗口的最小轨迹宽度 
SM_CXSCREEN, SM_CYSCREEN 屏幕大小 
SM_CXSIZE, SM_CYSIZE 标题栏位图的大小 
SM_CXSIZEFRAME, SM_CYSIZEFRAME 具有WS_THICKFRAME样式的窗口的大小 
SM_CXSMICON, SM_CYSMICON 小图标的大小 
SM_CXSMSIZE, SM_CYSMSIZE 小标题按钮的大小 
SM_CXVSCROLL, SM_CYVSCROLL 垂直滚动条中的箭头按钮的大小 
SM_CYCAPTION 窗口标题的高度 
SM_CYKANJIWINDOW Kanji窗口的大小(Height of Kanji window) 
SM_CYMENU 菜单高度 
SM_CYSMCAPTION 小标题的高度 
SM_CYVTHUMB 垂直滚动条上滚动块的高度 
SM_DBCSENABLED 如支持双字节则为TRUE 
SM_DEBUG 如windows的调试版正在运行,则为TRUE 
SM_MENUDropALIGNMENT 如弹出式菜单对齐菜单栏项目的左侧,则为零 
SM_MIDEASTENABLED 允许了希伯来和阿拉伯语 
SM_MOUSEPRESENT 如安装了鼠标则为TRUE 
SM_MOUSEWHEELPRESENT 如安装了带轮鼠标则为TRUE;只适用于nt 4.0 
SM_NETWORK 如安装了网络,则设置位0。其他位保留未用 
SM_PENWINDOWS 如装载了支持笔窗口的DLL,则表示笔窗口的句柄 
SM_SECURE 如安装了安全(保密)机制,则为TRUE 
SM_SHOWSOUNDS 强制视觉提示播放声音 
SM_SLOWMACHINE 系统速度太慢,但仍在运行中(System is too slow for effective use but is being run anyway) 
SM_SWAPBUTTON 如左右鼠标键已经交换,则为TRUE ‘注意这里 
注解 
双击区域指定屏幕上一个特定的显示区域,只有在这个区域内连续进行两次鼠标单击,才有可能被当作双击事件处理 
其他 
常数 SM_ARRANGE, SM_CLEANBOOT, SM_CMETRICS, SM_C?MAXIMIZED, SM_C?MAXTRACK, SM_C?SIZEFRAME, SM_C?SMICON, SM_C?SMSIZE, SM_CYSMCAPTION, 
SM_SECURE, SM_SHOWSOUNDS, and SM_SLOWMACHINE 未获 NT 3.51 及更早版本的支持

时间: 2024-11-05 22:58:31

VC 屏幕相关操作的相关文章

WebView中的视频全屏的相关操作

最近工作中,基本一直在用WebView,今天就把它整理下: WebView 顾名思义,就是放一个网页,一个看起来十分简单,但是用起来不是那么简单的控件. 首先你肯定要定义,初始化一个webview,其实网上的例子很多,我这里就简单的把一些WebView 中可能会用到的的很重要的属性以及支持全屏播放视频该怎么实现的代码粘出来,直接放到项目中去就行了 <span style="white-space:pre"></span><pre name="co

MFC 打印相关操作

虽说现在已经有越来越多的人转向用C#来做界面的开发,但是对于一个习惯了C++这种半面向对象语言的人来说,MFC依然是难割舍的存在.最近在做些数据库相关的事,因为是数据库,自然离不开打印报表之类的东西,所以顺带的也去研究了下如何用MFC来进行打印相关的的操作. 本篇文章参考的比较多的是这篇文章和MSDN的示例代码,另外这篇文章也提供了很多有用的参考,如果想看原文的话可以去看看. 直接用微软提供的CPrintDialog类进行打印的相关操作是非常简单的,本人将代码封装成为两个函数,除了实际往一页纸上

JS中字符串的相关操作

(转自:http://www.cnblogs.com/zhaoxinxin/articles/1402733.html) 一.字符串的创建 创建一个字符串有几种方法. 最简单的是用引号将一组字符包含起来,可以将其赋值给一个字符串变量. var myStr = "Hello, String!"; 可以用双引号或单引号将字符串包含,但要注意,作为界定字符串的一对引号必须是相同的,不能混用. 像var myString = "Fluffy is a pretty cat.'; 这样

VC++中文件操作(一)---CFileFind,CFileDialog,CFile,CArchive,CStdioFile

各种关于文件的操作在程序设计中是十分常见,如果能对其各种操作都了如指掌,就可以根据实际情况找到最佳的解决方案,从而在较短的时间内编写出高效的代码,因而熟练的掌握文件操作是十分重要的.本文将对Visual C++中有关文件操作进行全面的介绍,并对在文件操作中经常遇到的一些疑难问题进行详细的分析. VC++中文件操作(一) ***************************************************************************××××××××××第一.V

二叉树的相关操作

#include<stdio.h> #include<malloc.h> #define MAXSIZE 20 typedef char TEelemtype; typedef struct BiTNode{ TEelemtype data; struct BiTNode *lchild,*rchild; }BiTNode,*BiTree; //队列的方式 typedef struct queueelem { BiTNode* b[MAXSIZE]; int front,rear;

(二十四)linux新定时器:timefd及相关操作函数

timerfd是Linux为用户程序提供的一个定时器接口.这个接口基于文件描述符,通过文件描述符的可读事件进行超时通知,所以能够被用于select/poll的应用场景. 一,相关操作函数 #include <sys/timerfd.h> int timerfd_create(int clockid, int flags); int timerfd_settime(int fd, int flags, const struct itimerspec *new_value, struct itim

二叉树各种相关操作(建立二叉树、前序、中序、后序、求二叉树的深度、查找二叉树节点,层次遍历二叉树等)(C语言版)

将二叉树相关的操作集中在一个实例里,有助于理解有关二叉树的相关操作: 1.定义树的结构体: 1 typedef struct TreeNode{ 2 int data; 3 struct TreeNode *left; 4 struct TreeNode *right; 5 }TreeNode; 2.创建根节点: 1 TreeNode *creatRoot(){ 2 TreeNode * root =(TreeNode *)malloc(sizeof(TreeNode)); 3 if(NULL=

linux下进程相关操作

一.定义和理解 狭义定义:进程是正在运行的程序的实例. 广义定义:进程是一个具有一定独立功能的程序关于某个数据集合的一次运行活动. 进程的概念主要有两点: 第一,进程是一个实体.每一个进程都有它自己的地址空间,一般情况下,包括文本区域.数据区域和堆栈区域.文本区域存储处理器执行的代码:数据区域存储变量和进程执行期间使用的动态分配的内存:堆栈区域存储着活动过程调用的指令和本地变量. 第二,进程是一个“执行中的程序”.程序是一个没有生命的实体,只有处理器赋予程序生命时,它才能成为一个活动的实体,我们

android DataBase的相关操作(建立表结构和创建表)

先建立一个table的基类: public abstract class DbBaseTable { private static final String TAG = "DbBaseTable"; /** * @return the DB table name */ abstract String getName(); /** * Creates the DB table according to the DB scheme * * @param db */ abstract voi