| 首页 | 新闻 | 网页 | 设计 | 色彩 | 原创 | 视觉 | 素材 | 动漫 | 酷站 | 策划 | 文案 | 访谈 | 运营 | 编程 | 数据库 | 服务器 | 下载 | 图库 | 
您的位置: 幽幽天空 > 网页 > 编程开发 > Visual C++教程 > 文章正文 用户登录
插件PSD2FLA让Psd
使用Flex 2 Sdk编
DNS (domain Name
在 FreeBSD 下利用
FreeBSD ADSL 安装
FreeBSD的起源
使用FreeBSD配置基
小规模DDoS用Free
FreeBSD连载:作者
FreeBSD连载:Fre

SDK实现分隔条(续)           

SDK实现分隔条(续)

作者:佚名 来源:CSDN 作者: titilima 更新:2006-8-25 21:05:35 错误报告 我要投稿

  在《SDK实现分隔条》中,我介绍了如何实现动态的分隔条。本文将要介绍的,是如何实现静态的分隔条(即画线实现分隔的分隔条)。

  上边的分隔条是一种“动态”的分隔条,就是说在移动分隔条的同时窗口的大小也发生了改变。以下我再介绍一种“静态”的分隔条,即在拖动分隔条的时候出现一条竖线,由这一条线来指示分隔条的分隔结果。
  如果说动态的分隔条是在和矩形做游戏,那么静态的分隔条就是在和图形做游戏了。首先请大家看我的代码:
LRESULT CALLBACK ProcSplitter(HWND hwnd, UINT Msg, WPARAM wParam, LPARAM lParam)
{
  static int x;
  switch (Msg)
  {
  case WM_LBUTTONDOWN:
  {
    HDC hdc;
    RECT rectTree;
    SetCapture(hwnd);
    GetWindowRect(hTree, &rectTree);
    hdc = GetDC(GetParent(hwnd));
    SelectObject(hdc, CreatePen(PS_SOLID, 2, 0));
    SetROP2(hdc, R2_NOTXORPEN);
    x = rectTree.right - rectTree.left;
    MoveToEx(hdc, x, 0, NULL);
    LineTo(hdc, x, rectTree.bottom - rectTree.top);
    ReleaseDC(GetParent(hwnd), hdc);
  }
  break;
  case WM_LBUTTONUP:
  {
    HDWP hdwp;
    HDC hdc;
    RECT rect, rectTree, rectStatus;
    GetClientRect(GetParent(hwnd), &rect);
    GetWindowRect(hTree, &rectTree);
    GetClientRect(hStatus, &rectStatus);
    hdc = GetDC(GetParent(hwnd));
    SelectObject(hdc, CreatePen(PS_SOLID, 2, 0));
    SetROP2(hdc, R2_NOTXORPEN);
    MoveToEx(hdc, x, 0, NULL);
    LineTo(hdc, x, rectTree.bottom - rectTree.top);
    ReleaseDC(GetParent(hwnd), hdc);
    ReleaseCapture();
    hdwp = BeginDeferWindowPos(3);
    DeferWindowPos(hdwp, hTree, NULL, 0, 0, x, rect.bottom - rectStatus.bottom, SWP_NOMOVE | SWP_NOZORDER);
    DeferWindowPos(hdwp, hSplitter, NULL, x, 0, 0, 0, SWP_NOSIZE | SWP_NOZORDER);
    DeferWindowPos(hdwp, hList, NULL, x + 2, 0, rect.right - x - 2, rect.bottom - rectStatus.bottom, SWP_NOZORDER);
    EndDeferWindowPos(hdwp);
  }
  break;
  case WM_MOUSEMOVE:
  {
    if ((wParam & MK_LBUTTON) == MK_LBUTTON && GetCapture() == hwnd)
    {
      HDC hdc;
      RECT rectTree;
      GetWindowRect(hTree, &rectTree);
      hdc = GetDC(GetParent(hwnd));
      SelectObject(hdc, CreatePen(PS_SOLID, 2, 0));
      SetROP2(hdc, R2_NOTXORPEN);
      MoveToEx(hdc, x, 0, NULL);
      LineTo(hdc, x, rectTree.bottom - rectTree.top);
      x = rectTree.right - rectTree.left + (short)LOWORD(lParam);
      MoveToEx(hdc, x, 0, NULL);
      LineTo(hdc, x, rectTree.bottom - rectTree.top);
      ReleaseDC(GetParent(hwnd), hdc);
    }
  }
  break;
  default:
    return DefWindowProc(hwnd, Msg, wParam, lParam);
  }
  return 0;
}
  这段代码的核心部分,就是它的画线和擦线部分。在这里我玩弄了一个小把戏,就是利用了SetROP2函数的R2_NOTXORPEN模式:在这个模式下作图,只要在先前画过线的地方再画一道线,那么用户看到的效果就是原来的线被擦除了。这样一来,只需要再使用一个static变量x,就可以完成这个过程了。
  当然分隔条的种类有很多,例如VCL中的TSplitter中就包括了不同样式的分隔条,不过效果无非是改变了画线的样式之类,在此我就不多讨论了。

文章录入:skyuu    责任编辑:skyuu 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    发表评论:
    姓名:  评 分: 1分 2分 3分 4分 5分
     
  • 严禁发表危害国家安全、政治、黄色淫秽等内容的评论。
  • 用户需对自己在使用幽幽天空服务过程中的行为承担法律责任。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表机友个人观点,与本网站立场无关。