mfc ListControl 重绘网格线

.h文件

 //网格线设置 [yal 2013.10.08]
 int        m_nGridStyle;      //风格 PS_DASH,PS_SOLID,。。。
 COLORREF   m_GridColor;       //颜色
 int        m_nGridWeigth;     //粗度1,2,...

 void  setGridStyle(int nStyle);
 void  setGridWeight(int nWeight);
 void  setGridColor(COLORREF cr);

.cpp文件

CListCtrlCl::CListCtrlCl()
:m_nGridStyle(PS_SOLID)
,m_nGridWeigth(1)
,m_GridColor(RGB(255,255,255))
{
}
void CListCtrlCl::DrawItem(LPDRAWITEMSTRUCT lpDrawItemStruct)
{

 // TODO:  添加您的代码以绘制指定项

 // 重绘网格线 [7/12/2013 dell]
 const MSG *msg = GetCurrentMessage();
 DefWindowProc( msg->message, msg->wParam, msg->lParam );

 // Draw the lines only for LVS_REPORT mode
 if( (GetStyle() & LVS_TYPEMASK) == LVS_REPORT )
 {
  // Get the number of columns
  CClientDC dc(this );
  //yal 2013.10.08画有颜色的线
  CPen pen(m_nGridStyle,m_nGridWeigth,m_GridColor);
  CPen* oldpen=dc.SelectObject(&pen);

  CHeaderCtrl* pHeader = (CHeaderCtrl*)GetDlgItem(0);
  int nColumnCount = pHeader->GetItemCount();

  // The bottom of the header corresponds to the top of the line
  RECT rect, rectCol;
  pHeader->GetClientRect( &rect );
  int top = rect.bottom;

  // Now get the client rect so we know the line length and
  // when to stop
  GetClientRect( &rect );

  if( !GetItemRect( 1, &rectCol, LVIR_BOUNDS ))
   return;

  int height1 = rectCol.bottom - rectCol.top;

  // The border of the column is offset by the horz scroll
  int borderx = 0 - GetScrollPos( SB_HORZ );
  for( int i = 0; i < nColumnCount; i++ )
  {
   // Get the next border
   borderx += GetColumnWidth( i );

   // if next border is outside client area, break out
   if( borderx >= rect.right ) break;

   // Draw the line.
   dc.MoveTo( borderx-1, top/*top*/);
   dc.LineTo( borderx-1, height1+top+lpDrawItemStruct->itemID*height1/*nColumnCount*height1 + top*/);
  }

  // Draw the horizontal grid lines

  // First get the height
  if( !GetItemRect( 0, &rect, LVIR_BOUNDS ))
   return;

  int height = rect.bottom - rect.top;

  GetClientRect( &rect );
  int width = rect.right;

  for(unsigned int i = 1; i <= lpDrawItemStruct->itemID+1; i++ )
  {
   dc.MoveTo( 0, top + height*i);
   dc.LineTo( width, top + height*i );
  }

   dc.SelectObject(oldpen);
 }
}

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MFCListCtrl控件重绘是指在ListCtrl控件的显示区域需要进行重新绘制时,通过调用相关的函数来实现界面的更新和刷新。ListCtrl重绘可以分为两种情况:自动重绘和手动重绘。 自动重绘是指当ListCtrl控件的状态或内容发生改变时,系统会自动触发重绘操作。例如,当用户对ListCtrl进行增删改操作,或者ListCtrl接收到数据更新的消息时,系统会在适当的时候自动进行重绘,更新界面显示的内容。这种情况下,程序员只需确保控件的状态或内容正确,不需要手动干预重绘操作。 手动重绘是指在某些特殊情况下,程序员需要手动调用相关的函数来进行重绘操作。例如,当ListCtrl控件的背景颜色需要更改,或者需要添加特定的绘制效果时,就需要手动重绘。手动重绘的方法通常是通过重载ListCtrl绘制函数,如OnPaint或OnCustomDraw,然后在函数内部手动调用相关的绘制函数和绘制参数来实现重绘的效果。 无论是自动重绘还是手动重绘,都需要注意一些细节。首先,要确保在进行重绘操作时,不要对ListCtrl的数据进行修改,否则可能会导致不可预料的错误。其次,要注意控件的重绘区域,即只对需要重新绘制的区域进行操作,以提高绘制的效率。最后,要正确处理重绘操作的时机,避免过多的重复绘制,以提高程序的运行效率。 总的来说,ListCtrl重绘可以通过自动重绘和手动重绘两种方式来实现,具体的方法和操作根据具体需求和情况进行选择和调整。重绘操作的目的是为了实现界面的更新和刷新,提高用户体验和界面的美观性。 ### 回答2: MFC ListCtrl控件的重绘可以通过一些方法来实现。 首先,我们可以通过重新绘制列表的背景色来改变其外观。可以通过在ListCtrl的 WM_ERASEBKGND 消息中处理。在该消息的处理函数中,可以使用 CDC::FillSolidRect() 函数来绘制背景色。 其次,我们可以重写 CListCtrl 类的 DrawItem() 函数来自定义列表项的绘制。在这个函数中,可以根据需要绘制每一项的不同外观,例如不同的背景色、前景色等。我们可以使用 CDC::FillSolidRect() 函数来进行绘制。 另外,我们还可以通过重写 CListCtrl 类的 OnPaint() 函数来实现列表控件的重绘。在这个函数中,可以进行自定义绘制,例如绘制不同背景色、边框等。我们可以使用 CDC::FillSolidRect() 函数来进行绘制。 最后,我们也可以通过调用 CListCtrl 类的 Invalidate() 函数来强制重绘列表控件。可以在需要重绘的地方调用这个函数,然后通过处理 WM_PAINT 消息来进行重绘。 总之,MFC ListCtrl控件的重绘可以通过重写 DrawItem() 函数、OnPaint() 函数,处理 WM_ERASEBKGND 消息,以及调用 Invalidate() 函数来实现。我们可以根据需求选择适合的方法来实现列表控件的重绘
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值