2017-02-20 43 views
1

有一个GDI的StrokePath API可以允许使用this method模拟“抚摸”文本。我使用的是DrawString功能从GDI +绘制文本如何在使用GDI +中的DrawString函数绘制文本时描边文本?

void CCanvas::DrawOutlineText(CDC& dc, const CString& Text) 
{ 
    const int RestorePoint = dc.SaveDC(); 

    // Create new font 
    CFont NewFont; 
    NewFont.CreatePointFont(700, TEXT("Verdana"), &dc); 

    // Use this font 
    dc.SelectObject(&NewFont); 

    // Brush for pen 
    LOGBRUSH lBrushForPen = { 0 }; 
    lBrushForPen.lbColor = RGB(200, 150, 100); 
    lBrushForPen.lbHatch = HS_CROSS; 
    lBrushForPen.lbStyle = BS_SOLID; 

    // New pen for drawing outline text 
    CPen OutlinePen; 
    OutlinePen.CreatePen(PS_GEOMETRIC | PS_SOLID, 2, &lBrushForPen, 0, 0); 

    // Use this pen 
    dc.SelectObject(&OutlinePen); 

    dc.SetBkMode(TRANSPARENT); 

    dc.BeginPath(); 
    // This text is not drawn on screen, but instead each action is being 
    // recorded and stored internally as a path, since we called BeginPath 
    dc.TextOut(20, 20, Text); 
    // Stop path 
    dc.EndPath(); 

    // Now draw outline text 
    dc.StrokePath(); 

    dc.RestoreDC(RestorePoint); 
} 

在我的情况:我会在这里复制。

有没有人知道是否有替代BeginPath,EndPathStrokePath在GDI +模拟文本抚摸?

编辑:继以下jschroedl的建议,我试过如下:

CString str = L"Text"; 

Graphics grpx(dc.GetSafeHdc()); 

SolidBrush gdiBrush(Color(0xFF, 0xFF, 0, 0)); 

StringFormat gdiSF; 
gdiSF.SetAlignment(StringAlignmentNear); 
gdiSF.SetFormatFlags(StringFormatFlagsNoWrap | StringFormatFlagsNoFitBlackBox | 
    StringFormatFlagsNoFontFallback | StringFormatFlagsNoClip); 
gdiSF.SetHotkeyPrefix(HotkeyPrefixNone); 
gdiSF.SetTrimming(StringTrimmingNone); 

grpx.SetTextRenderingHint(TextRenderingHintAntiAlias); 
grpx.SetPixelOffsetMode(PixelOffsetModeNone); 
grpx.SetInterpolationMode(InterpolationModeHighQualityBicubic); 

GraphicsPath dd; 
FontFamily gdiFF(L"Segoe UI"); 
const PointF pntF(0, 0); 
dd.AddString(str, str.GetLength(), &gdiFF, FontStyleRegular, 58.0f, pntF, &gdiSF); 

Pen penFF(Color(0xFF, 0xFF, 0, 0), 1.0f); 
grpx.DrawPath(&penFF, &dd); 

所产生相当轮廓锯齿(扩大截图):

enter image description here

任何想法如何使它与抗锯齿渲染?

回答

0

我相信我们的代码会创建一个GraphicsPath对象,请致电GraphicsPath::AddString()获取文本的路径,然后使用Graphics::DrawPath()绘制路径。

更新:

基于块状文字,我尝试和认为这看起来有点顺畅。

grpx.SetTextRenderingHint(TextRenderingHintClearTypeGridFit); 
grpx.SetSmoothingMode(SmoothingModeHighQuality); 
grpx.SetPixelOffsetMode(PixelOffsetModeHalf); 

enter image description here

+0

嗯。有趣。谢谢。只是好奇,如果有一种方法来添加消除锯齿画笔。它看起来很矮胖。 – c00000fd

+0

看看我们的代码,我们似乎使用SetInterpolationMode(InterpolationModeHighQualityBicubic)在Graphics对象上设置了它,并且在我们调用graphics-> SetTextRenderingHint(TextRenderingHintAntiAlias)之前,有一条关于寻址'blocky text'的注释:然后SetPixelOffsetMode(PixelOffsetModeNone) – jschroedl

+0

你知道它没有改变任何东西。查看我更新的原始帖子w/code。 – c00000fd