本文整理汇总了C++中CGridListCtrlEx::GetCellRect方法的典型用法代码示例。如果您正苦于以下问题:C++ CGridListCtrlEx::GetCellRect方法的具体用法?C++ CGridListCtrlEx::GetCellRect怎么用?C++ CGridListCtrlEx::GetCellRect使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类CGridListCtrlEx
的用法示例。
在下文中一共展示了CGridListCtrlEx::GetCellRect方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: IsCellReadOnly
//------------------------------------------------------------------------
//! Check if current image index blocks for editing of cell label
//!
//! @param owner The list control starting edit
//! @param nRow The index of the row for the cell
//! @param nCol The index of the column for the cell
//! @param pt The position clicked, in client coordinates.
//! @return Is cell read only ? (true / false)
//------------------------------------------------------------------------
bool CGridColumnTraitImage::IsCellReadOnly(CGridListCtrlEx& owner, int nRow, int nCol, CPoint pt) const
{
if (!m_ColumnState.m_Editable)
return true;
// Check if current cell image blocks for starting cell editor
if (m_ImageCellEdit.GetSize() != 0)
{
int nCurImageIdx = -1;
for (int i = 0; i < m_ImageCellEdit.GetSize(); ++i)
{
if (!m_ImageCellEdit.GetValueAt(i))
{
if (nCurImageIdx == -1)
{
if (pt != CPoint(-1, -1))
{
CRect rect;
VERIFY(owner.GetCellRect(nRow, nCol, LVIR_LABEL, rect));
if (!rect.PtInRect(pt))
break;
}
nCurImageIdx = owner.GetCellImage(nRow, nCol);
if (nCurImageIdx == -1)
break;
}
if (nCurImageIdx == m_ImageCellEdit.GetKeyAt(i))
return true;
}
}
}
return false; // editable
}
示例2: GetCellEditRect
//------------------------------------------------------------------------
//! Returns the proper rectangle, which an editor should fit in
//------------------------------------------------------------------------
CRect CGridColumnTraitText::GetCellEditRect(CGridListCtrlEx& owner, int nRow, int nCol)
{
// Find the required height according to font
int requiredHeight = GetCellFontHeight(owner);
// Get position of the cell to edit
CRect rectCell;
VERIFY( owner.GetCellRect(nRow, nCol, LVIR_LABEL, rectCell) );
// Adjust position to font height
if (!owner.UsingVisualStyle())
{
if ((requiredHeight + 2*::GetSystemMetrics(SM_CXEDGE)) > rectCell.Height())
{
rectCell.top -= ::GetSystemMetrics(SM_CXEDGE);
rectCell.bottom += ::GetSystemMetrics(SM_CXEDGE);
}
}
if (owner.GetExtendedStyle() & LVS_EX_GRIDLINES)
{
if ((requiredHeight + 2*::GetSystemMetrics(SM_CXEDGE) + ::GetSystemMetrics(SM_CXBORDER)) < rectCell.Height())
rectCell.bottom -= ::GetSystemMetrics(SM_CXBORDER);
}
if (owner.GetExtendedStyle() & LVS_EX_SUBITEMIMAGES)
{
if (owner.GetImageList(LVSIL_SMALL)!=NULL && owner.GetCellImage(nRow,nCol)>=0)
rectCell.left += ::GetSystemMetrics(SM_CXBORDER);
}
return rectCell;
}
示例3: GetCellEditRect
//------------------------------------------------------------------------
//! Returns the proper rectangle, which a cell value editor should fit in
//!
//! @param owner The list control for the inplace cell value editor
//! @param nRow The index of the row
//! @param nCol The index of the column
//! @return Rectangle where the inplace cell value editor should be placed.
//------------------------------------------------------------------------
CRect CGridColumnTraitText::GetCellEditRect(CGridListCtrlEx& owner, int nRow, int nCol)
{
// Get position of the cell to edit
CRect rectCell;
VERIFY( owner.GetCellRect(nRow, nCol, LVIR_LABEL, rectCell) );
// Adjust cell rectangle according to grid-lines
if (owner.GetExtendedStyle() & LVS_EX_GRIDLINES)
rectCell.bottom -= ::GetSystemMetrics(SM_CXBORDER);
if (owner.GetExtendedStyle() & LVS_EX_SUBITEMIMAGES)
{
// Add margin to cell image
if (owner.GetImageList(LVSIL_SMALL)!=NULL && owner.GetCellImage(nRow,nCol)!=I_IMAGECALLBACK)
rectCell.left += ::GetSystemMetrics(SM_CXBORDER);
}
// Check if there is enough room for normal margin
int requiredHeight = GetCellFontHeight(owner);
requiredHeight += 2*::GetSystemMetrics(SM_CXEDGE);
if (requiredHeight > rectCell.Height())
rectCell.bottom = rectCell.top + requiredHeight;
return rectCell;
}
示例4: GetTextRect
//------------------------------------------------------------------------
//! Returns dimensions of the cell text clicked
//!
//! @param owner The list control being clicked
//! @param nRow The index of the row
//! @param nCol The index of the column
//! @param cellText The contents of the cell clicked
//! @return The dimensions of the cell text
//------------------------------------------------------------------------
CRect CGridColumnTraitHyperLink::GetTextRect(CGridListCtrlEx& owner, int nRow, int nCol, const CString& cellText)
{
CRect rect;
ASSERT(nRow != -1);
CDC* pDC = owner.GetDC();
CFont* pOldFont = pDC->SelectObject(owner.GetCellFont());
CSize size = pDC->GetTextExtent(cellText);
pDC->SelectObject(pOldFont);
owner.ReleaseDC(pDC);
owner.GetCellRect(nRow, nCol, LVIR_LABEL, rect);
HDITEM hditem = { 0 };
hditem.mask = HDI_FORMAT;
owner.GetHeaderCtrl()->GetItem(nCol, &hditem);
// First item (Label) doesn't have a margin (Subitems does)
if (nCol != 0 && !(hditem.fmt & HDF_CENTER))
{
if (hditem.fmt & HDF_RIGHT)
rect.OffsetRect(-7, 0);
else
rect.OffsetRect(4, 0);
}
if (hditem.fmt & HDF_CENTER)
rect.DeflateRect((rect.Width() - size.cx) / 2, 0);
else if (hditem.fmt & HDF_RIGHT)
rect.left = rect.right - size.cx;
else
rect.right = rect.left + size.cx;
return rect;
}
示例5: OnClickEditStart
//------------------------------------------------------------------------
//! Checks if the mouse click should start the cell editor (OnEditBegin)
//! Normally the cell needs to have focus first before cell editor can be started
//! - Except when using ToggleSelection, and have clicked a checkbox (image)
//! - Except when using SingleClickEdit, which makes it impossible to do double click
//!
//! @param owner The list control being clicked
//! @param nRow The index of the row
//! @param nCol The index of the column
//! @param pt The position clicked, in client coordinates.
//! @param bDblClick Whether the position was double clicked
//! @return How should the cell editor be started (0 = No editor, 1 = Start Editor, 2 = Start Editor and block click-event)
//------------------------------------------------------------------------
int CGridColumnTraitImage::OnClickEditStart(CGridListCtrlEx& owner, int nRow, int nCol, CPoint pt, bool bDblClick)
{
// Begin edit if the cell has focus already
bool startEdit = false;
if (nRow != -1 && nCol != -1 && !bDblClick)
{
if (m_SingleClickEdit)
startEdit = true;
else
if (owner.GetFocusRow() == nRow && owner.GetFocusCell() == nCol)
startEdit = true;
}
// Check if the cell-image / cell-checkbox can be edited without having focus first
if (m_ToggleSelection)
{
if (nCol == 0 && owner.GetExtendedStyle() & LVS_EX_CHECKBOXES)
{
CRect iconRect;
if (!owner.GetCellRect(nRow, nCol, LVIR_ICON, iconRect) || !iconRect.PtInRect(pt))
{
CRect labelRect;
if (owner.GetCellRect(nRow, nCol, LVIR_LABEL, labelRect) && !labelRect.PtInRect(pt))
return 1; // Clicked the checkbox for the label-column
}
}
if (m_ImageCellEdit.GetSize()>1)
{
CRect iconRect;
if (owner.GetCellRect(nRow, nCol, LVIR_ICON, iconRect) && iconRect.PtInRect(pt))
return 2; // Clicked the image-icon (Don't change focus or change selection)
}
}
return startEdit ? 1 : 0;
}
示例6: OnClickEditStart
//------------------------------------------------------------------------
//! Checks if the mouse click should start the cell editor (OnEditBegin)
//! Validates that the click was on the text-link within the label-part
//!
//! @param owner The list control being clicked
//! @param nRow The index of the row
//! @param nCol The index of the column
//! @param pt The position clicked, in client coordinates.
//! @param bDblClick Whether the position was double clicked
//! @return How should the cell editor be started (0 = No editor, 1 = Start Editor, 2 = Start Editor and block click-event)
//------------------------------------------------------------------------
int CGridColumnTraitHyperLink::OnClickEditStart(CGridListCtrlEx& owner, int nRow, int nCol, CPoint pt, bool bDblClick)
{
int startEdit = CGridColumnTraitImage::OnClickEditStart(owner, nRow, nCol, pt, bDblClick);
if (startEdit)
{
// Check if mouse click was inside the label-part of the cell
CRect labelRect;
if (owner.GetCellRect(nRow, nCol, LVIR_LABEL, labelRect) && labelRect.PtInRect(pt))
{
// Check if mouse click was inside the text-link of the cell
CString cellText = owner.GetItemText(nRow, nCol);
if (GetTextRect(owner, nRow, nCol, cellText).PtInRect(pt))
return startEdit;
else
return 0;
}
}
return startEdit;
}
示例7: OnCustomDraw
//.........这里部分代码省略.........
if (pImageList==NULL)
break;
COLORREF backColor = COLORREF(-1);
if (owner.GetExtendedStyle() & LVS_EX_TRACKSELECT && owner.GetHotItem()==nRow)
{
#if(WINVER >= 0x0500)
backColor = ::GetSysColor(COLOR_HOTLIGHT);
#else
if (owner.IsRowSelected(nRow))
backColor = ::GetSysColor(COLOR_HIGHLIGHT);
else
break;
#endif
}
else
if (owner.IsRowSelected(nRow))
{
if (!(owner.GetExtendedStyle() & LVS_EX_FULLROWSELECT))
break; // No drawing of selection color without full-row-select
if (m_InvertCellSelection && owner.GetFocusRow()==nRow && owner.GetFocusCell()==nCol)
{
// No drawing of selection color for focus cell
if (pLVCD->clrTextBk > RGB(255,255,255))
break;
backColor = pLVCD->clrTextBk;
}
else
{
if (owner.GetFocus()!=&owner && !owner.IsCellEditorOpen())
{
// Selection color is different when not having focus
if (owner.GetStyle() & LVS_SHOWSELALWAYS)
backColor = ::GetSysColor(COLOR_BTNFACE);
else
break; // no drawing of selection color when not in focus
}
else
{
backColor = ::GetSysColor(COLOR_HIGHLIGHT);
}
}
}
else
{
// Redraw with the given background color
if (pLVCD->clrTextBk > RGB(255,255,255))
break; // If a color is more than white, then it is invalid
backColor = pLVCD->clrTextBk;
}
CDC* pDC = CDC::FromHandle(pLVCD->nmcd.hdc);
CRect rcIcon, rcCell;
VERIFY( owner.GetCellRect(nRow, nCol, LVIR_ICON, rcIcon) );
VERIFY( owner.GetCellRect(nRow, nCol, LVIR_BOUNDS, rcCell) );
// When the label column is placed first it has a left-margin
if (nCol==0 && nCol==owner.GetFirstVisibleColumn())
{
int cxborder = ::GetSystemMetrics(SM_CXBORDER);
rcCell.left += cxborder*2;
}
// Remove white margin between cell-image and cell-text
rcCell.right = rcIcon.right + 2;
CBrush brush(backColor);
pDC->FillRect(&rcCell, &brush);
// Draw icon
COLORREF oldBkColor = pImageList->SetBkColor(backColor);
pImageList->Draw ( pDC,
nImage,
rcIcon.TopLeft(),
ILD_NORMAL );
pImageList->SetBkColor(oldBkColor);
if (nCol==0 && owner.GetExtendedStyle() & LVS_EX_CHECKBOXES)
{
CImageList* pStateImageList = owner.GetImageList(LVSIL_STATE);
if (pImageList==NULL)
break;
int checkState = owner.GetCheck(nRow);
COLORREF oldStateBkColor = pStateImageList->SetBkColor(backColor);
pStateImageList->Draw ( pDC,
checkState,
rcCell.TopLeft(),
ILD_NORMAL );
pStateImageList->SetBkColor(oldStateBkColor);
}
} break;
}
// Perform standard drawing
CGridRowTraitText::OnCustomDraw(owner, pLVCD, pResult);
}
示例8: OnCustomDraw
//.........这里部分代码省略.........
if (owner.GetFocus() != &owner)
break;
// If drawing focus row, then remove focus state and request to draw it later
// - Row paint request can come twice, with and without focus flag
// - Only respond to the one with focus flag, else DrawFocusRect XOR will cause solid or blank focus-rectangle
if (owner.GetFocusRow() == nRow)
{
if (owner.GetFocusCell() >= 0)
{
// We want to draw a cell-focus-rectangle instead of row-focus-rectangle
pLVCD->nmcd.uItemState &= ~CDIS_FOCUS;
*pResult |= CDRF_NOTIFYPOSTPAINT;
}
else if (owner.GetExtendedStyle() & LVS_EX_GRIDLINES)
{
// Avoid bug where bottom of focus rectangle is missing when using grid-lines
// - Draw the focus-rectangle for the entire row (explicit)
pLVCD->nmcd.uItemState &= ~CDIS_FOCUS;
*pResult |= CDRF_NOTIFYPOSTPAINT;
}
}
}
}
break;
// After painting a row
case CDDS_ITEMPOSTPAINT:
{
if (m_pOldFont!=NULL)
{
// Restore the original font
CDC* pDC = CDC::FromHandle(pLVCD->nmcd.hdc);
CFont* pNewFont = pDC->SelectObject(m_pOldFont);
if (m_FontAllocated)
{
m_FontAllocated = false;
delete pNewFont;
}
m_pOldFont = NULL;
}
if (CRect(pLVCD->nmcd.rc)==CRect(0,0,0,0))
break;
if (owner.GetFocusRow()!=nRow)
break;
if (owner.GetFocus() != &owner)
break;
// Perform the drawing of the focus rectangle
if (owner.GetFocusCell() >= 0)
{
// Draw the focus-rectangle for a single-cell
CRect rcHighlight;
CDC* pDC = CDC::FromHandle(pLVCD->nmcd.hdc);
VERIFY( owner.GetCellRect(nRow, owner.GetFocusCell(), LVIR_BOUNDS, rcHighlight) );
int cxborder = ::GetSystemMetrics(SM_CXBORDER);
// When the label column is placed first it has a left-margin
if (owner.GetFocusCell()==0 && owner.GetFocusCell()==owner.GetFirstVisibleColumn())
{
rcHighlight.left += cxborder*2;
}
else
// Prevent focus rectangle to overlap with cell-image (Only room for this when not first column)
if (owner.GetFirstVisibleColumn()!=owner.GetFocusCell())
{
rcHighlight.left -= cxborder;
}
// Adjust rectangle according to grid-lines
if (owner.GetExtendedStyle() & LVS_EX_GRIDLINES)
{
rcHighlight.bottom -= cxborder;
}
pDC->DrawFocusRect(rcHighlight);
}
else if (owner.GetExtendedStyle() & LVS_EX_GRIDLINES)
{
// Avoid bug where bottom of focus rectangle is missing when using grid-lines
// - Draw the focus-rectangle for the entire row (explicit)
CRect rcHighlight;
CDC* pDC = CDC::FromHandle(pLVCD->nmcd.hdc);
// Using LVIR_BOUNDS to get the entire row-rectangle
VERIFY( owner.GetItemRect(nRow, rcHighlight, LVIR_BOUNDS) );
// Adjust rectangle according to grid-lines
int cxborder = ::GetSystemMetrics(SM_CXBORDER);
rcHighlight.bottom -= cxborder;
pDC->DrawFocusRect(rcHighlight);
}
}
break;
}
}