Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
//
// TOOL.CPP
// Drawing Tools
//
// Copyright Microsoft 1998-
//
// PRECOMP
#include "precomp.h"
#include "draw.hpp"
//
//
// Function: WbTool
//
// Purpose: Constructors for tools
//
//
WbTool::WbTool(int toolType) { COLORREF defColor; UINT defWidth; int iIndex;
MLZ_EntryOut(ZONE_FUNCTION, "WbTool::WbTool");
// Save the tool type
m_toolType = toolType; m_selectedTool = TOOLTYPE_MAX;
m_uiWidthIndexCur = 0;
// Read the colors of the pen
if (toolType == TOOLTYPE_HIGHLIGHT) defColor = DEF_HIGHLIGHTCOLOR; else defColor = DEF_PENCOLOR; m_clrCur = defColor;
for (iIndex = 0; iIndex < NUM_OF_WIDTHS; iIndex++) { defWidth = (toolType == TOOLTYPE_HIGHLIGHT) ? g_HighlightWidths[iIndex] : g_PenWidths[iIndex];
m_uiWidths[iIndex] = defWidth; }
// Read the font details
LOGFONT lfont;
::GetObject(::GetStockObject(DEFAULT_GUI_FONT), sizeof(LOGFONT), &lfont); lfont.lfClipPrecision |= CLIP_DFA_OVERRIDE; lfont.lfCharSet = DEFAULT_CHARSET; m_hFont = ::CreateFontIndirect(&lfont); }
//
// WbTool::~WbTool
// Destructor
//
WbTool::~WbTool() { if (m_hFont != NULL) { ::DeleteFont(m_hFont); m_hFont = NULL; } }
//
//
// Function: HasColor
//
// Purpose: Return TRUE if the tool supports colors
//
//
BOOL WbTool::HasColor(void) { BOOL bResult = TRUE;
switch (m_toolType) { case TOOLTYPE_ERASER: bResult = FALSE; break;
}
return bResult; }
//
//
// Function: HasWidth
//
// Purpose: Return TRUE if the tool supports widths
//
//
BOOL WbTool::HasWidth(void) { BOOL bResult = FALSE;
switch (m_toolType) { case TOOLTYPE_PEN: case TOOLTYPE_HIGHLIGHT: case TOOLTYPE_LINE: case TOOLTYPE_BOX: case TOOLTYPE_ELLIPSE: bResult = TRUE; break;
// For the selector tool, it depends on the selected object type
case TOOLTYPE_SELECT: switch (m_selectedTool) { case TOOLTYPE_LINE: case TOOLTYPE_BOX: case TOOLTYPE_ELLIPSE: case TOOLTYPE_PEN: case TOOLTYPE_HIGHLIGHT: { bResult = TRUE; break; } } break;
default: // The rest don't support widths, including filled tools
break; }
return bResult; }
//
//
// Function: HasFont
//
// Purpose: Return TRUE if the tool supports fonts
//
//
BOOL WbTool::HasFont(void) { BOOL bResult = FALSE;
switch (m_toolType) { case TOOLTYPE_TEXT: bResult = TRUE; break;
// For the selector tool, it depends on the selected object type
case TOOLTYPE_SELECT: switch (m_selectedTool) { case TOOLTYPE_TEXT: bResult = TRUE; break;
default: break; } break;
default: break; }
return bResult; }
//
//
// Function: GetROP
//
// Purpose: Return the ROP for this tool
//
//
int WbTool::GetROP(void) { // If this is a highlight tool we use MASKPEN, else we use the standard
if (m_toolType == TOOLTYPE_HIGHLIGHT) return(R2_MASKPEN); else return(R2_COPYPEN); }
//
//
// Function: GetCursorForTool
//
// Purpose: Return the handle to the cursor for the tool
//
//
HCURSOR WbTool::GetCursorForTool(void) { int nName = -1;
switch(m_toolType) { case TOOLTYPE_SELECT: break; // use default arrow for select cursor (bug 439)
case TOOLTYPE_PEN: nName = PENFREEHANDCURSOR; break;
case TOOLTYPE_LINE: case TOOLTYPE_BOX: case TOOLTYPE_FILLEDBOX: case TOOLTYPE_ELLIPSE: case TOOLTYPE_FILLEDELLIPSE: nName = PENCURSOR; break;
case TOOLTYPE_HIGHLIGHT: nName = HIGHLIGHTFREEHANDCURSOR; break;
case TOOLTYPE_TEXT: nName = TEXTCURSOR; break; case TOOLTYPE_ERASER: nName = DELETECURSOR; break;
default: // Do nothing - the name pointer is NULL
break; }
HCURSOR hcursorResult = NULL;
if (nName == -1) { // Return the standard arrow cursor as a default
hcursorResult = ::LoadCursor(NULL, IDC_ARROW); } else { // Return the cursor for the tool
hcursorResult = ::LoadCursor(g_hInstance, MAKEINTRESOURCE( nName ) ); }
return hcursorResult; }
//
//
// Function: SetFont
//
// Purpoxse: Set the current font of the tool
//
//
void WbTool::SetFont(HFONT hFont) { MLZ_EntryOut(ZONE_FUNCTION, "WbTool::SetFont");
// Get the font details
LOGFONT lfont;
::GetObject(hFont, sizeof(LOGFONT), &lfont); //zap FontAssociation mode (bug 3258)
lfont.lfClipPrecision |= CLIP_DFA_OVERRIDE;
// Set the local font
if (m_hFont != NULL) { ::DeleteFont(m_hFont); m_hFont = NULL; } m_hFont = ::CreateFontIndirect(&lfont); }
//
//
// Function: SelectGraphic
//
// Purpose: Set the current selected graphic type, and copy the colors,
// widths and font into this tool's attributes.
//
//
void WbTool::SelectGraphic(T126Obj* pGraphic) { UINT uiIndex;
// Save the selected tool type
m_selectedTool = pGraphic->GraphicTool();
// Get the tool object for the selected tool type
WbTool* pTool = g_pMain->m_ToolArray[m_selectedTool];
if (HasColor()) { pGraphic->GetPenColor(&m_clrCur); }
if (HasWidth()) { for (uiIndex = 0; uiIndex < NUM_OF_WIDTHS; uiIndex++) { SetWidthAtIndex(uiIndex, pTool->GetWidthAtIndex(uiIndex)); }
// See if the object's width matches any of the available colors
// for this tool type
for (uiIndex = 0; uiIndex < NUM_OF_WIDTHS; uiIndex++) { if (pGraphic->GetPenThickness() == m_uiWidths[uiIndex]) { break; } }
SetWidthIndex(uiIndex); }
if (HasFont()) { if (pGraphic->GraphicTool() == TOOLTYPE_TEXT) { SetFont(((TextObj *)pGraphic)->GetFont()); } } }
//
// WbMainWindow::InitToolArray
// Create the array of WB tools
//
//
BOOL WbMainWindow::InitToolArray(void) { int tool; WbTool * pTool;
for (tool = TOOLTYPE_FIRST; tool < TOOLTYPE_MAX; tool++) { // Add the new tool to the array
DBG_SAVE_FILE_LINE pTool = new WbTool(tool); if (!pTool) { ERROR_OUT(("Can't create tool %d", tool)); return(FALSE); }
m_ToolArray[tool] = pTool; }
return(TRUE); }
//
// WbMainWindow::DestroyToolAray()
//
// Free the array of WB tools
//
void WbMainWindow::DestroyToolArray(void) { int tool; WbTool * pTool;
for (tool = TOOLTYPE_FIRST; tool < TOOLTYPE_MAX; tool++) { pTool = m_ToolArray[tool]; if (pTool != NULL) { m_ToolArray[tool] = NULL; delete pTool; } } }
|