本文实例讲述了VC创建圆角dialog的实现方法。分享给大家供大家参考,具体如下:
我们有时候需要圆角的对话框,要实现这样的效果,一般包括两步工作,第一步:将原有对话框的直角裁剪掉,第二步:为对话框画上圆角或者为对话框贴上一个圆角的图片。
第一步:我们在OnCreate函数中来实现,代码量也不多。
int CTestDialog::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
if (CDialog::OnCreate(lpCreateStruct) == -1)
return -1;
HRGN hRgn;
RECT rect;
::GetWindowRect(hwnd, &rect);
hRgn = CreateRoundRectRgn(0, 0, rect.right - rect.left + 1, rect.bottom - rect.top + 1, 5,5);
::SetWindowRgn(hwnd, hRgn, TRUE);
}
如果对话框还支持Resize的话,那么需要在OnSize函数中拷贝一份上面的代码。
第二步:因为圆角部分的重绘属于对话框的非客户区,所以我们需要响应WM_NCPAINT消息,在消息响应函数中实现贴圆角图片的功能或者画上圆角线。
Void CTestDialog::OnNcPaint()
{
CWindowDC dc(this);
CRect rcWindow;
CRect rcClient;
this->GetClientRect(rcClient);
this->ClientToScreen(rcClient);
this->GetWindowRect(rcWindow);
CPoint point = rcWindow.TopLeft();
rcClient.OffsetRect(-point);
rcWindow.OffsetRect(-point);
int windowWidth = rcWindow.Width();
int windowHeight = rcWindow.Height();
HDC hMemDC = ::CreateCompatibleDC(dc.m_hDC);
HBITMAP hBmp = ::CreateCompatibleBitmap(dc.m_hDC, windowWidth, windowHeight);
::SelectObject(hMemDC, hBmp);
Graphics graphics(hMemDC);
graphics.Clear(Color(255, 255, 255, 255));
graphics.SetSmoothingMode(SmoothingModeHighQuality);
//TODO:使用GDI+的DrawImage函数来贴上圆角图片,或者使用RoundRect函数来为对话框画上圆角线
#if 0 /*使用DrawImage来绘制圆角图片*/
ImageAttributes ia;
ia.SetWrapMode( WrapModeTileFlipXY );
graphic.DrawImage(pImg_LTFrame,……….);
#endif
#if 0 /*使用RoundRect来绘制圆角线*/
RoundRect(hMemDC, rcWindow.left, rcWindow.top, rcWindow.right,rc.bottom, 5, 5 );
#endif
dc.IntersectClipRect(rcWindow);
dc.ExcludeClipRect(rcClient);
::BitBlt(dc.m_hDC, 0, 0, windowWidth, windowHeight, hMemDC, 0, 0, SRCCOPY);
::DeleteDC(hMemDC);
::DeleteObject(hBmp);
}
为了达到自己想要的效果,可能还要响应WM_NCACTIVE和WM_NOTIFY两个消息,在这两个消息响应函数中实现和OnNCPaint函数一样的功能。
还有一个重要的消息WM_NCCALCSIZE,在这个消息响应函数中,主要是重新计算对话框的非客户区的大小,这个函数中的LPNCCALCSIZE_PARAMS类型参数lpncsp的lpncsp->rgrc[0]设置的是客户区的大小,客户区的高度减小时,非客户区的高度就增加了,因为对话框的总高度是固定的。在创建圆角矩形后,可能会出现客户区区域大了或者小了,这时,就需要响应该消息,在这个消息响应函数中对非客户区的大小进行调整。
希望本文所述对大家VC程序设计有所帮助。
问题内容: 如何使用CSS创建圆角? 问题答案: 自从引入CSS3以来,使用CSS添加圆角的最佳方法是使用border-radius属性。您可以阅读有关该属性的规范,或获取有关MDN的一些有用的实现信息: 如果您使用的浏览器未 实现 border-radius(Chrome v4之前的版本,Firefox v4之前的版本,IE8,Opera v10.5之前的版本,Safari v5之前的版本),则
本文向大家介绍Android实现圆角矩形和圆形ImageView的方式,包括了Android实现圆角矩形和圆形ImageView的方式的使用技巧和注意事项,需要的朋友参考一下 Android中实现圆角矩形和圆形有很多种方式,其中最常见的方法有ImageLoader设置Option和自定义View。 1.ImageLoader加载图片 ImageLoader.getInstance().displa
本文向大家介绍Android开发实现图片圆角的方法,包括了Android开发实现图片圆角的方法的使用技巧和注意事项,需要的朋友参考一下 本文讲述了Android开发实现图片圆角的方法。分享给大家供大家参考,具体如下: 或者: 更多关于Android相关内容感兴趣的读者可查看本站专题:《Android图形与图像处理技巧总结》、《Android开发入门与进阶教程》、《Android调试技巧与常见问题解
本文向大家介绍Android编程自定义圆角半透明Dialog的方法,包括了Android编程自定义圆角半透明Dialog的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Android编程自定义圆角半透明Dialog的方法。分享给大家供大家参考,具体如下: 效果图如下: 只是在实例化的时候使用带样式的构造函数即可 在value文件夹中添加mydialogthemes.xml 其中@dr
我试图在android中创建一个具有圆形边缘的视图。到目前为止,我找到的解决方案是定义一个具有圆角的形状,并将其用作该视图的背景。 下面是我所做的,定义一个可绘制的,如下所示: 现在我用它作为我的布局背景,如下所示: 这工作非常好,我可以看到视图有圆形的边缘。 但是我的布局中有许多其他的子视图,比如ImageView或MapView。当我在上面的布局中放置时,图像的角落不会被裁剪/裁剪,而是显示为
本文向大家介绍jquery插件corner实现圆角边框的方法,包括了jquery插件corner实现圆角边框的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jquery插件corner实现圆角边框的方法。分享给大家供大家参考。具体如下: 这里测试了一下发现一个问题bug:若background-color:#eeeeee;写成background-color:red;或 backgr