0

次のコードのように、mpDC を使用してマウス ポイントに十字線を描画したいのですが、マウスを移動すると、マウス ポイントで十字線が移動します。

しかし、BitBlt の使用方法がわからないため、描画領域 (rectRange) に線が表示されない可能性があります。

    CWnd *pWnd;
    CRect rect;
    CDC mShowDC;
    CBitmap mShowBmp;
    CPen mpen;
    CPen *mOldpen;

    CDC *mpDC;

    mpDC = GetDC();

    mShowDC.CreateCompatibleDC(mpDC);
    mShowBmp.CreateCompatibleBitmap(mpDC,rectRange.Width(),rectRange.Height());
    mShowDC.SelectObject(mShowBmp);

    BitBlt(mShowDC,0,0,rectRange.Width(),rectRange.Height(),
        mbkCurveDC,0,0,SRCCOPY);

    //InvalidateRect(rectRange);
    if(boolShowMouseLine)
    {
        mpen.CreatePen(PS_SOLID,1,RGB(0,0,0));
        mOldpen = mShowDC.SelectObject(&mpen);

        mShowDC.MoveTo(rectRange.left,mMousePoint.y);
        mShowDC.LineTo(mMousePoint.x - 1,mMousePoint.y);

        mShowDC.MoveTo(mMousePoint.x + 1,mMousePoint.y);
        mShowDC.LineTo(rectRange.bottom,mMousePoint.y);

        mShowDC.MoveTo(mMousePoint.x,rectRange.top);
        mShowDC.LineTo(mMousePoint.x,mMousePoint.y - 1);

        mShowDC.MoveTo(mMousePoint.x,mMousePoint.y + 1);
        mShowDC.LineTo(mMousePoint.x,rectRange.right);

        mpen.DeleteObject();
        mShowDC.SelectObject(mOldpen);
    }

    mpDC->BitBlt(rectRange.left, rectRange.top,
        rectRange.Width(), rectRange.Height(), 
        &mShowDC, rectRange.left, rectRange.top, SRCCOPY);

コードに従ってクロスラインを描画する別の方法

 CDC *cdc;
cdc = GetDC();

if(boolShowMouseLine)
{
    cdc->MoveTo(rectRange.left,mMousePoint.y);
    cdc->LineTo(mMousePoint.x - 1,mMousePoint.y);

    cdc->MoveTo(mMousePoint.x + 1,mMousePoint.y);
    cdc->LineTo(rectRange.right,mMousePoint.y);

    cdc->MoveTo(mMousePoint.x,rectRange.top);
    cdc->LineTo(mMousePoint.x,mMousePoint.y - 1);

    cdc->MoveTo(mMousePoint.x,mMousePoint.y + 1);
    cdc->LineTo(mMousePoint.x,rectRange.bottom);
}

現状は写真ですここに画像の説明を入力

しかし、このコードでは、マウスの位置をずらすと多くの十字線が描画されます。

前のクロスラインをクリアするにはどうすれば...

4

3 に答える 3

0

私は次のコードとして使用します

CClientDC dc(this);
int oldmode=dc.SetROP2(R2_NOTXORPEN);
        COLORREF color;

        color = RGB(0,0,0);

        CPen pen(PS_DASH, 2, color), *oldpen;
        oldpen = dc.SelectObject(&pen);

        dc.MoveTo(rectRange.left, mMousePoint.y);
        dc.LineTo(mMousePoint.x - 1, mMousePoint.y);

        dc.MoveTo(mMousePoint.x + 1, mMousePoint.y);
        dc.LineTo(rectRange.right, mMousePoint.y);

        dc.MoveTo(mMousePoint.x, rectRange.top);
        dc.LineTo(mMousePoint.x, mMousePoint.y - 1);

        dc.MoveTo(mMousePoint.x, mMousePoint.y + 1);
        dc.LineTo(mMousePoint.x, rectRange.bottom);

        PEndPoint = point;

        dc.MoveTo(rectRange.left, mMousePoint.y);
        dc.LineTo(mMousePoint.x - 1, mMousePoint.y);

        dc.MoveTo(mMousePoint.x + 1, mMousePoint.y);
        dc.LineTo(rectRange.right, mMousePoint.y);

        dc.MoveTo(mMousePoint.x, rectRange.top);
        dc.LineTo(mMousePoint.x, mMousePoint.y - 1);

        dc.MoveTo(mMousePoint.x, mMousePoint.y + 1);
        dc.LineTo(mMousePoint.x, rectRange.bottom);

        dc.SelectObject(oldpen);
        dc.SetROP2(oldmode);
        ReleaseDC(&dc);

クロスラインは再フラッシュしますが、画面に表示されません。どのように修正されましたか。

于 2014-01-17T01:28:50.393 に答える
0

OK、micaheltang の回答に基づいて BitBlt を使用しない回答を見つけました。ここに記載されているようにhttp://books.google.co.il/books?id=eDvx4Qx63b0C&pg=PA105&lpg=PA105&dq=MFC+blending+line+with+background&source=bl&ots=v3ycFSlHL7&sig=agpZHLBgnocSXZLQ6qSM6nWFIzM&hl=en&sa=X&ei=wZ_XUsOvLYXHStAa6#AAwLYXStAa05 =onepage&q=MFC%20blending%20line%20with%20background&f=ライン ブレンディングで false。線を消去するときは、同じモードを使用すると、以前の色が復元されます。

于 2014-01-16T09:04:02.673 に答える