14 个解决方案
#1
如果你编程时未使用动态屏幕设计,那就只有逐个修改资源,再重新编译了。
#2
最快捷的办法就是弄一个2880*1800的显示器,话说lz使用这么高分辨率的显示器,很多很多的电脑都没有使用
#3
最快捷的办法就是弄一个2880*1800的显示器,话说lz使用这么高分辨率的显示器,很多很多的电脑都没法使用
#4
// 加段代码吧。动态布置控件位置和大小。
// 在InitDialog的时候,获取所有窗口的位置大小
// 在onsize中重新布置。
// 大概就这样
CList<CRect, CRect> m_listRect;
// 在InitDialog的时候,获取所有窗口的位置大小
CRect rect;
GetWindowRect(&rect);
m_listRect.AddTail(rect);//对话框的区域
CWnd* pWnd = GetWindow(GW_CHILD);//获取子窗体
while (pWnd)
{
pWnd->GetWindowRect(rect);//子窗体的区域
m_listRect.AddTail(rect); //CList<CRect,CRect> m_listRect成员变量
pWnd = pWnd->GetNextWindow();//取下一个子窗体
}
// 在onsize中重新布置。
if (m_listRect.GetCount() > 0)
{
CRect dlgNow;
GetWindowRect(&dlgNow);
POSITION pos = m_listRect.GetHeadPosition();//第一个保存的是对话框的Rect
CRect dlgSaved;
dlgSaved = m_listRect.GetNext(pos);
ScreenToClient(dlgNow);
double x = dlgNow.Width() * 1.0 / dlgSaved.Width();//根据当前和之前保存的对话框的宽高求比例
double y = dlgNow.Height() *1.0 / dlgSaved.Height();
ClientToScreen(dlgNow);
CRect childSaved;
CWnd* pWnd = GetWindow(GW_CHILD);
while (pWnd)
{
childSaved = m_listRect.GetNext(pos);//依次获取子窗体的Rect
childSaved.left = (LONG)(dlgNow.left + (childSaved.left - dlgSaved.left)*x);//根据比例调整控件上下左右距离对话框的距离
childSaved.right = (LONG)(dlgNow.right + (childSaved.right - dlgSaved.right)*x);
childSaved.top = (LONG)(dlgNow.top + (childSaved.top - dlgSaved.top)*y);
childSaved.bottom = (LONG)(dlgNow.bottom + (childSaved.bottom - dlgSaved.bottom)*y);
ScreenToClient(childSaved);
pWnd->MoveWindow(childSaved);
CRect rect;
if (IDC_STATIC_KEY == pWnd->GetDlgCtrlID())
{
rect.top = 0;
rect.bottom = childSaved.bottom - childSaved.top;
rect.left = 0;
rect.right = childSaved.right - childSaved.left;
m_flueDlg.MoveWindow(&rect);
m_flueDlg.ShowWindow(SW_SHOW);
}
pWnd = pWnd->GetNextWindow();
}
// 大概就这样
#5
膜拜9楼!
#6
确实好用
#7
咋变成4楼了呢?是我当时笔误还是前面的帖子有被版主删掉了?
膜拜
“lfchen 版主
一条晚起的虫”
这回不会再错了吧。
#8
IDC_STATIC_KEY
m_flueDlg
这两个是什么东东?编译说未定义。
m_flueDlg
这两个是什么东东?编译说未定义。
#9
我也遇到过这样问题,屏幕长宽比相差不多时转换还好。
否则会比较难看。
下面是在程序运行时转换一次,后面设置对话框不能改变大小了。
否则会比较难看。
下面是在程序运行时转换一次,后面设置对话框不能改变大小了。
class CTestDlg
{
public:
POINT old; //保存原屏幕客户区大小,调整窗口大小用
}
BOOL CTestDlg::OnInitDialog()
{
AdjustWindowsSize( ); //调整窗口大小与桌面工作区相同
ReSize( ); //调整当前窗口中所有控件大小,以适应当前屏幕分辨率
}
//调整窗口大小与桌面工作区相同
void CTestDlg::AdjustWindowsSize(void)
{
CRect rect;
GetClientRect(&rect); //取客户区大小
old.x=rect.right-rect.left;
old.y=rect.bottom-rect.top;
int cx = GetSystemMetrics(SM_CXFULLSCREEN);
int cy = GetSystemMetrics(SM_CYFULLSCREEN);
CRect rt;
SystemParametersInfo(SPI_GETWORKAREA,0,&rt,0); //获得桌面工作区大小,即不包括任务栏的大小
cy = rt.bottom;
MoveWindow(0, 0, cx, cy);
}
//调整当前窗口中所有控件大小,以适应当前屏幕分辨率
void CTestDlg::ReSize(void)
{
float fsp[2];
POINT Newp; //获取现在对话框的大小
CRect recta;
GetClientRect(&recta); //取客户区大小
Newp.x=recta.right-recta.left;
Newp.y=recta.bottom-recta.top;
fsp[0]=(float)Newp.x/old.x;
fsp[1]=(float)Newp.y/old.y;
CRect Rect;
int woc;
CPoint OldTLPoint,TLPoint; //左上角
CPoint OldBRPoint,BRPoint; //右下角
HWND hwndChild=::GetWindow(m_hWnd,GW_CHILD); //列出所有控件
while(hwndChild)
{
woc=::GetDlgCtrlID(hwndChild);//取得ID
GetDlgItem(woc)->GetWindowRect(Rect);
ScreenToClient(Rect);
OldTLPoint = Rect.TopLeft();
TLPoint.x = long(OldTLPoint.x*fsp[0]);
TLPoint.y = long(OldTLPoint.y*fsp[1]);
OldBRPoint = Rect.BottomRight();
BRPoint.x = long(OldBRPoint.x *fsp[0]);
BRPoint.y = long(OldBRPoint.y *fsp[1]);
Rect.SetRect(TLPoint,BRPoint);
GetDlgItem(woc)->MoveWindow(Rect,TRUE);
hwndChild=::GetWindow(hwndChild, GW_HWNDNEXT);
}
old=Newp;
}
#10
十分感谢,不过请问
IDC_STATIC_KEY 指的是窗口内控件ID号码?
m_flueDlg指的是什么?
#11
我试了一下,原高分辨率打开变成了全屏,控件和图片大小不符,变乱了。
放到低分辨率机器上,程序全屏后竟然差不多了。。。请问代码是专为1980*1080写的还是碰巧而已。。。
#12
你读读代码,没有针对具体分辨率。你可以多找几台电脑试试。
#13
具体应用时,要调整一下,比如控件尺寸过大,或过小,要调整一下比例。
字体大小要不要修改等。
字体大小要不要修改等。
#14
还有一点要注意;每一个控件的ID要唯一,比如静态文本,起名IDC_STATIC1、IDC_STATIC2、IDC_STATIC3、。。。等等,否则会乱套。
#1
如果你编程时未使用动态屏幕设计,那就只有逐个修改资源,再重新编译了。
#2
最快捷的办法就是弄一个2880*1800的显示器,话说lz使用这么高分辨率的显示器,很多很多的电脑都没有使用
#3
最快捷的办法就是弄一个2880*1800的显示器,话说lz使用这么高分辨率的显示器,很多很多的电脑都没法使用
#4
// 加段代码吧。动态布置控件位置和大小。
// 在InitDialog的时候,获取所有窗口的位置大小
// 在onsize中重新布置。
// 大概就这样
CList<CRect, CRect> m_listRect;
// 在InitDialog的时候,获取所有窗口的位置大小
CRect rect;
GetWindowRect(&rect);
m_listRect.AddTail(rect);//对话框的区域
CWnd* pWnd = GetWindow(GW_CHILD);//获取子窗体
while (pWnd)
{
pWnd->GetWindowRect(rect);//子窗体的区域
m_listRect.AddTail(rect); //CList<CRect,CRect> m_listRect成员变量
pWnd = pWnd->GetNextWindow();//取下一个子窗体
}
// 在onsize中重新布置。
if (m_listRect.GetCount() > 0)
{
CRect dlgNow;
GetWindowRect(&dlgNow);
POSITION pos = m_listRect.GetHeadPosition();//第一个保存的是对话框的Rect
CRect dlgSaved;
dlgSaved = m_listRect.GetNext(pos);
ScreenToClient(dlgNow);
double x = dlgNow.Width() * 1.0 / dlgSaved.Width();//根据当前和之前保存的对话框的宽高求比例
double y = dlgNow.Height() *1.0 / dlgSaved.Height();
ClientToScreen(dlgNow);
CRect childSaved;
CWnd* pWnd = GetWindow(GW_CHILD);
while (pWnd)
{
childSaved = m_listRect.GetNext(pos);//依次获取子窗体的Rect
childSaved.left = (LONG)(dlgNow.left + (childSaved.left - dlgSaved.left)*x);//根据比例调整控件上下左右距离对话框的距离
childSaved.right = (LONG)(dlgNow.right + (childSaved.right - dlgSaved.right)*x);
childSaved.top = (LONG)(dlgNow.top + (childSaved.top - dlgSaved.top)*y);
childSaved.bottom = (LONG)(dlgNow.bottom + (childSaved.bottom - dlgSaved.bottom)*y);
ScreenToClient(childSaved);
pWnd->MoveWindow(childSaved);
CRect rect;
if (IDC_STATIC_KEY == pWnd->GetDlgCtrlID())
{
rect.top = 0;
rect.bottom = childSaved.bottom - childSaved.top;
rect.left = 0;
rect.right = childSaved.right - childSaved.left;
m_flueDlg.MoveWindow(&rect);
m_flueDlg.ShowWindow(SW_SHOW);
}
pWnd = pWnd->GetNextWindow();
}
// 大概就这样
#5
膜拜9楼!
#6
确实好用
#7
咋变成4楼了呢?是我当时笔误还是前面的帖子有被版主删掉了?
膜拜
“lfchen 版主
一条晚起的虫”
这回不会再错了吧。
#8
IDC_STATIC_KEY
m_flueDlg
这两个是什么东东?编译说未定义。
m_flueDlg
这两个是什么东东?编译说未定义。
#9
我也遇到过这样问题,屏幕长宽比相差不多时转换还好。
否则会比较难看。
下面是在程序运行时转换一次,后面设置对话框不能改变大小了。
否则会比较难看。
下面是在程序运行时转换一次,后面设置对话框不能改变大小了。
class CTestDlg
{
public:
POINT old; //保存原屏幕客户区大小,调整窗口大小用
}
BOOL CTestDlg::OnInitDialog()
{
AdjustWindowsSize( ); //调整窗口大小与桌面工作区相同
ReSize( ); //调整当前窗口中所有控件大小,以适应当前屏幕分辨率
}
//调整窗口大小与桌面工作区相同
void CTestDlg::AdjustWindowsSize(void)
{
CRect rect;
GetClientRect(&rect); //取客户区大小
old.x=rect.right-rect.left;
old.y=rect.bottom-rect.top;
int cx = GetSystemMetrics(SM_CXFULLSCREEN);
int cy = GetSystemMetrics(SM_CYFULLSCREEN);
CRect rt;
SystemParametersInfo(SPI_GETWORKAREA,0,&rt,0); //获得桌面工作区大小,即不包括任务栏的大小
cy = rt.bottom;
MoveWindow(0, 0, cx, cy);
}
//调整当前窗口中所有控件大小,以适应当前屏幕分辨率
void CTestDlg::ReSize(void)
{
float fsp[2];
POINT Newp; //获取现在对话框的大小
CRect recta;
GetClientRect(&recta); //取客户区大小
Newp.x=recta.right-recta.left;
Newp.y=recta.bottom-recta.top;
fsp[0]=(float)Newp.x/old.x;
fsp[1]=(float)Newp.y/old.y;
CRect Rect;
int woc;
CPoint OldTLPoint,TLPoint; //左上角
CPoint OldBRPoint,BRPoint; //右下角
HWND hwndChild=::GetWindow(m_hWnd,GW_CHILD); //列出所有控件
while(hwndChild)
{
woc=::GetDlgCtrlID(hwndChild);//取得ID
GetDlgItem(woc)->GetWindowRect(Rect);
ScreenToClient(Rect);
OldTLPoint = Rect.TopLeft();
TLPoint.x = long(OldTLPoint.x*fsp[0]);
TLPoint.y = long(OldTLPoint.y*fsp[1]);
OldBRPoint = Rect.BottomRight();
BRPoint.x = long(OldBRPoint.x *fsp[0]);
BRPoint.y = long(OldBRPoint.y *fsp[1]);
Rect.SetRect(TLPoint,BRPoint);
GetDlgItem(woc)->MoveWindow(Rect,TRUE);
hwndChild=::GetWindow(hwndChild, GW_HWNDNEXT);
}
old=Newp;
}
#10
十分感谢,不过请问
IDC_STATIC_KEY 指的是窗口内控件ID号码?
m_flueDlg指的是什么?
#11
我试了一下,原高分辨率打开变成了全屏,控件和图片大小不符,变乱了。
放到低分辨率机器上,程序全屏后竟然差不多了。。。请问代码是专为1980*1080写的还是碰巧而已。。。
#12
你读读代码,没有针对具体分辨率。你可以多找几台电脑试试。
#13
具体应用时,要调整一下,比如控件尺寸过大,或过小,要调整一下比例。
字体大小要不要修改等。
字体大小要不要修改等。
#14
还有一点要注意;每一个控件的ID要唯一,比如静态文本,起名IDC_STATIC1、IDC_STATIC2、IDC_STATIC3、。。。等等,否则会乱套。