GetClientRect(HWND, RECT*) ---得到窗口的客户区大小,left,top总是0,bottom是客户区高度,right是客户区宽度

GetWindowRect(HWND, RECT*) ---得到窗口相对屏幕左上角(0,0)的坐标,即窗口左上角(left,top)和右下角(right,bottom)的坐标


ScreenToClient(HWND, POINT*) ---将一屏幕坐标转为相对于窗口客户区左上角的坐标。假设客户区屏幕坐标(110,120,400,400)
                                                       若p(100,100),则转换后p(-10, -20)
                                                       若p(150,150),则转换后p(40, 30)

ClientToScreen(HWND, POINT*) ---将一相对于窗口客户区左上角(始终假设)的坐标转为屏幕坐标。假设客户区屏幕坐标(110,120,400,400)
                                                       若p(5, 5),则转换后p(115,125)
                                                       若p(10, -20),则转换后p(120,100);

Windows并没有提供直接转换客户区RECT坐标/屏幕RECT坐标的函数,但是MFC中的CWindow类提供了ClientToScreen(RECT*) 和 ScreenToClient(RECT*)函数。
比如,当使用ClientToScreen(RECT *prc)时,传入的RECT坐标是假定为相对客户区左上角的,假设客户区屏幕坐标(110,120,400,400)
                                                若rc(2,2,4,4),则转换后rc(112,122,114,124)
                                                若rc(-5,-5,0,0),则转换后rc(105,115,110,120)
                                                若rc(0,0,290,280),则转换后rc(110,120,400,400)  >--->------->------->此例常用来获取客户区相对屏幕原点的坐标:

RECT rcClient;
GetClientRect(&rcClient); //0 0 宽 高
ClientToScreen(&rcClient); //客户区左上点和右下点的屏幕坐标
/*很常用,但不要误认为ClientToScreen的作用仅限于此*/

同理,当使用ScreenToClient(RECT *prc)时,传入的RECT坐标假定为屏幕坐标,假设客户区屏幕坐标(110,120,400,400)
                                                若rc(150,150,160,160),则转换后rc(40,30,50,40)
                                                若rc(100,100,120,120),则转换后rc(-10,-20,10,0)
                                                若rc(110,120,400,400),则转换后rc(0,0,290,280)


OffsetRect(RECT*, int dx, int dy)  ---移动矩形,从感官上:dx为正,右移,为负,则左移;dy为正,下移,为负,上移。若rc(100,100,150,150)
                                                         dx=0,dy=1,则转换后rc(100,101,150,151)
                                                         dx=-50,dy=-10,则转换后rc(50,90,100,140)
  使用1:将窗口相对屏幕坐标转为相对窗口左上角坐标(即0 0 宽 高)

RECT rc;
::GetWindowRect(hwnd, &rc);
::OffsetRect(&rc, -rc.left, -rc.top);
/*当然也可以
rc.right -= rc.left;
rc.bottom -= rc.top;
rc.left = rc.top = 0;
*/

  使用2:计算客户区相对窗口左上角的坐标

//MFC下
RECT rc, rcClient; GetWindowRect(&rc);//窗口的屏幕坐标 GetClientRect(&rcClient);
ClientToScreen(&rcClient);//客户区的屏幕坐标 ::OffsetRect(&rcClient, -rc.left, -rc.top);//客户区相对与窗口左上角的坐标

BOOL PtInRect(const RECT*lprc, POINT pt); 判断pt点是否在RECT内,是则返回非0;注意客户区和屏幕坐标使用时的转换。

BOOL AdjustWindowRect(RECT *prc /*in/out*/, DWORD dwStyle, BOOL bMenu)  --假设传入的RECT为客户区的屏幕坐标,然后返回计算后的窗口坐标
                                       --适用于需要客户区大小为固定的情况,比如扫雷游戏客户区宽高应为方块的倍数
                                      --因为MoveWindow或SetWindowPos需要的是窗口坐标,它们常结合起来用
                                    --参数没有窗口句柄,因此坐标是根据窗口风格来计算的。第2个参数应指定恰当的风格。
                                  --第3个参数:窗口是否有MENU,就是[文件-编辑-查看..]那条菜单栏

//一对话框程序
RECT rcc = {, , , };
::AdjustWindowRect(&rcc, GetWindowLong(hwnd, GWL_STYLE), FALSE);//rcc(-8, -30, 388, 268)
::SetWindowPos(hwnd, HWND_TOP, , , rcc.right-rcc.left, rcc.bottom-rcc.top, SWP_SHOWWINDOW);//客户区宽高依然为380 260
//或::MoveWindow(hwnd, 10, 10, rcc.right-rcc.left, rcc.bottom-rcc.top, TRUE);

还有AdjustWindowRectEx,多了第4个参数DWORD dwExStyle,例如创建窗口时指定了WS_EX_TOOLWINDOW扩展风格(该风格使标题栏更小),那你就应该使用AdjustWindowRectEx来指定该扩展风格以正确计算出窗口大小!

FrameRect(HDC, const RECT*, HBRUSH) --画1逻辑单位宽度的边框,坐标由RECT指定
FillRect(HDC, const RECT*, HBRUSH)--填充矩形

----------因为画刷句柄直接传给第三个参数了,因此,用CreateSolidBrush等创建的画刷是不需要SelectObject的。当然还是需要DeleteObject删除该句柄的--------

 

Client Window坐标 RECT相关函数的更多相关文章

  1. canvas中window坐标转换为canvas坐标

    function getMousePos(canvas, evt) { var rect = canvas.getBoundingClientRect(); return { x: evt.clien ...

  2. VNCServer,SSH Secure Shell Client,window远程控制linux

    1.VNC远程连接linux图形化桌面 2.SSH Secure Shell Client连接linux终端 3.设置FTP与linux传输文件 1.VNC远程连接linux图形化桌面 在centos ...

  3. X Window 程式设计

    X Window 程式设计 转   http://www.cppblog.com/zmj/archive/2007/05/18/24331.html X Window 程式设计 X Window 程式 ...

  4. 一个view相对于屏幕或者另外一个view 的坐标

    如果想知道一个view相对于屏幕或者另外一个view 的坐标,那么可以通过如下的方法得到: UIWindow * window=[[[UIApplication sharedApplication] ...

  5. unity3d创建window

    unity3d创建windwo的方法如下: GUILayout.Window (, new Rect (50, 50, 200, 100), Func1, "窗口1"); 第一个参 ...

  6. Unity3D 一个较常见的错误信息“rect[2] == rt->GetGLWidth() && rect[3] == rt->GetGLHeight()”

    rect[2] == rt->GetGLWidth() && rect[3] == rt->GetGLHeight() 这个错误信息的具体含义我还不太清楚.它出现以后会不停 ...

  7. X Window 设定介绍

    在 Unix Like 上面的图形用户接口 (GUI) 被称为 X 或 X11 X11 是一个『软件』而不是一个操作系统: X11 是利用网络架构来进行图形接口的执行与绘制: 最著名的 X 版本为 X ...

  8. nuxt Window 或 Document未定义解决方案

    概述 在用nuxt开发服务端渲染项目并引入第三方库的时候,经常会遇到window或document未定义的情况,原因是这个第三方库里面用到了window或者document,然后在服务端打包的时候,n ...

  9. u3d中 rect[2] == rt->GetGLWidth() && rect[3] == rt->GetGLHeight()错误的原因及解决方法

    原文:http://blog.csdn.net/wolf96/article/details/38363161 官方是这么解释的 http://issuetracker.unity3d.com/iss ...

随机推荐

  1. andriod逆向实验截图

  2. php识别中文编码并自动转换为UTF-8

    原文地址:http://www.codefans.net/articles/1272.shtml php自动识别编码,若里面有中文的话,将其转换为UTF-8就最好了,因为中文在Gbk编辑情况情况下,有 ...

  3. Intellij Idea 工具在java文件中如何避免 import .*包

    Intellij Idea工具在java文件中怎么避免import java.utils.*这样的导入方式,不推崇导入*这样的做法!Editor->Code Style->Java-> ...

  4. JAVASE02-Unit04: 集合框架 、 集合操作 —— 线性表

    Unit04: 集合框架 . 集合操作 -- 线性表 操作集合元素相关方法 package day04; import java.util.ArrayList; import java.util.Co ...

  5. iOS中的__typeof与typeof

    做SDK开发引入AFNetworking那么多的文件不太合适,所以这几天在精简AFNetworking,并共享中github上,https://github.com/yjh4866/Simplifie ...

  6. 区间重叠计算及IntervalTree初识

    最近被人问到这样一个问题的解决方案:在一个餐馆的预定系统中,接受用户在未来任意一段时间内的预订用餐,用户在预订的时候需要提供用餐的开始时间和结束,餐馆的餐桌是用限的,问题是,系统要在最快的时间段计算出 ...

  7. Wampserver 2.5 多站点配置方法

    写在开头:本文适用于wampserver2.5版本,和wamp的老版本配置有语法上的区别,笔者正是因为被老版本的配置办法给整迷糊了所以才总结了一篇针对2.5版本的配置方法,如果您还停留在1.x或着已经 ...

  8. JDBC数据库1

    数据库(Database)是按照数据结构来组织,存储,和管理数据的仓库.数据库有很多类型,从简单存储各种数据的的表格到能够储存大型数据的系统,在各方面得到了广泛的应用.数据库简介J.Martin给 数 ...

  9. 搜索引擎Solr系列(一): Solr6.2.1环境搭建

     一:Solr简介 Solr是一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口.用户可以通过http请求,向搜索引擎服务器提交一定格式的XML文件,生成索引:也可以通 ...

  10. c++友元函数

    c++友元函数分两类: 一://友员全居函数 /*#include <iostream>using namespace std;class aaa{    friend void prin ...