亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ipolylin.cpp

?? 英文版的 想要的話可以下載了 為大家服務(wù)
?? CPP
字號:
/*
 * IPOLYLIN.CPP
 * Polyline Component Chapter 23
 *
 * Implementation of the IPolyline10 interface that we expose on the
 * CPolyline object.
 *
 * Copyright (c)1993-1995 Microsoft Corporation, All Rights Reserved
 *
 * Kraig Brockschmidt, Microsoft
 * Internet  :  kraigb@microsoft.com
 * Compuserve:  >INTERNET:kraigb@microsoft.com
 */


#include "polyline.h"


/*
 * CImpIPolyline:CImpIPolyline
 * CImpIPolyline::~CImpIPolyline
 *
 * Constructor Parameters:
 *  pObj            PCPolyline pointing to the object we live in.
 *  pUnkOuter       LPUNKNOWN of the controlling unknown.
 */

CImpIPolyline::CImpIPolyline(PCPolyline pObj, LPUNKNOWN pUnkOuter)
    {
    m_cRef=0;
    m_pObj=pObj;
    m_pUnkOuter=pUnkOuter;
    return;
    }


CImpIPolyline::~CImpIPolyline(void)
    {
    return;
    }




/*
 * CImpIPolyline::QueryInterface
 * CImpIPolyline::AddRef
 * CImpIPolyline::Release
 */

STDMETHODIMP CImpIPolyline::QueryInterface(REFIID riid, PPVOID ppv)
    {
    return m_pUnkOuter->QueryInterface(riid, ppv);
    }

STDMETHODIMP_(ULONG) CImpIPolyline::AddRef(void)
    {
    ++m_cRef;
    return m_pUnkOuter->AddRef();
    }

STDMETHODIMP_(ULONG) CImpIPolyline::Release(void)
    {
    --m_cRef;
    return m_pUnkOuter->Release();
    }





/*
 * CImpIPolyline::Init
 *
 * Purpose:
 *  Instantiates a polyline window within a given parent.  The
 *  parent may be a main application window, could be an MDI child
 *  window. We really do not care.
 *
 * Parameters:
 *  hWndParent      HWND of the parent of this window
 *  pRect           LPRECT that this window should occupy
 *  dwStyle         DWORD containing the window's style flags
 *  uID             UINT ID to associate with this window
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise E_OUTOFMEMORY
 */

STDMETHODIMP CImpIPolyline::Init(HWND hWndParent, LPRECT pRect
    , DWORD dwStyle, UINT uID)
    {
    SCODE           sc;

    m_pObj->m_hWnd=CreateWindowEx(WS_EX_NOPARENTNOTIFY
        , SZCLASSPOLYLINE, SZCLASSPOLYLINE, dwStyle, pRect->left
        , pRect->top, pRect->right-pRect->left
        , pRect->bottom-pRect->top, hWndParent, (HMENU)uID
        , m_pObj->m_hInst, m_pObj);

    sc=(NULL!=m_pObj->m_hWnd) ? S_OK : E_OUTOFMEMORY;
    return ResultFromScode(sc);
    }




/*
 * CImpIPolyline::New
 *
 * Purpose:
 *  Cleans out and reinitializes the data to defaults.
 *
 * Parameters:
 *  None
 *
 * Return Value:
 *  HRESULT         NOERROR always
 */

STDMETHODIMP CImpIPolyline::New(void)
    {
    PPOLYLINEDATA   ppl=&m_pObj->m_pl;
    UINT            i;
    RECT            rc;

    ppl->wVerMaj=VERSIONMAJOR;
    ppl->wVerMin=VERSIONMINOR;

    //Our rectangle is the size of our window's client area.
    if (NULL!=m_pObj->m_hWnd)
        {
        GetClientRect(m_pObj->m_hWnd, &rc);
        RECTTORECTS(rc, ppl->rc);
        }
    else
        {
        SetRect(&rc, 0, 0, 100, 100);       //Something reasonable
        RECTTORECTS(rc, ppl->rc);
        }

    //Clean out the POLYLINEDATA structure and repaint the window.
    for (i=0; i< CPOLYLINEPOINTS; i++)
        {
        ppl->rgpt[i].x=0;
        ppl->rgpt[i].y=0;
        }

    ppl->cPoints      =0;
    ppl->rgbBackground=GetSysColor(COLOR_WINDOW);
    ppl->rgbLine      =GetSysColor(COLOR_WINDOWTEXT);
    ppl->iLineStyle   =PS_SOLID;

    //This is now conditional since we may not yet have a window.
    if (NULL!=m_pObj->m_hWnd)
        {
        InvalidateRect(m_pObj->m_hWnd, NULL, TRUE);
        UpdateWindow(m_pObj->m_hWnd);
        m_pObj->m_fDirty=TRUE;
        }

    m_pObj->SendAdvise(OBJECTCODE_DATACHANGED);
    return NOERROR;
    }






/*
 * CImpIPolyline::Undo
 *
 * Purpose:
 *  Reverses previous actions in a Polyline.
 *
 * Parameters:
 *  None
 *
 * Return Value:
 *  HRESULT         S_OK if we can Undo more, S_FALSE otherwise.
 */

STDMETHODIMP CImpIPolyline::Undo(void)
    {
    SCODE           sc;

    //Decrement the number of active points and repaint.
    if (m_pObj->m_pl.cPoints > 0)
        {
        m_pObj->m_pl.cPoints--;
        InvalidateRect(m_pObj->m_hWnd, NULL, TRUE);
        UpdateWindow(m_pObj->m_hWnd);
        }

    if (NULL!=m_pObj->m_pAdv)
        {
        m_pObj->m_fDirty=TRUE;
        m_pObj->m_pAdv->OnPointChange();
        }

    m_pObj->SendAdvise(OBJECTCODE_DATACHANGED);

    //Return if we can undo any more.
    sc=(0!=m_pObj->m_pl.cPoints) ? S_OK : S_FALSE;
    return ResultFromScode(sc);
    }






/*
 * CImpIPolyline::Window
 *
 * Purpose:
 *  Returns the window handle associated with this polyline.
 *
 * Parameters:
 *  phWnd           HWND * in which to return the window handle.
 *
 * Return Value:
 *  HRESULT         NOERROR always.
 */

STDMETHODIMP CImpIPolyline::Window(HWND *phWnd)
    {
    *phWnd=m_pObj->m_hWnd;
    return NOERROR;
    }






/*
 * CImpIPolyline::RectGet
 *
 * Purpose:
 *  Returns the rectangle of the Polyline in parent coordinates.
 *
 * Parameters:
 *  pRect           LPRECT in which to return the rectangle.
 *
 * Return Value:
 *  HRESULT         NOERROR always
 */

STDMETHODIMP CImpIPolyline::RectGet(LPRECT pRect)
    {
    RECT            rc;
    POINT           pt;

    if (NULL==m_pObj->m_hWnd)
        {
        SetRect(pRect, 0, 0, 150, 150); //Reasonable default
        return NOERROR;
        }

    //Retrieve the size of our rectangle in parent coordinates.
    GetWindowRect(m_pObj->m_hWnd, &rc);
    pt.x=rc.left;
    pt.y=rc.top;
    ScreenToClient(GetParent(m_pObj->m_hWnd), &pt);

    SetRect(pRect, pt.x, pt.y, pt.x+(rc.right-rc.left)
        , pt.y+(rc.bottom-rc.top));

    return NOERROR;
    }





/*
 * CImpIPolyline::SizeGet
 *
 * Purpose:
 *  Retrieves the size of the Polyline in parent coordinates.
 *
 * Parameters:
 *  pRect           LPRECT in which to return the size.  The right
 *                  and bottom fields will contain the dimensions.
 *
 * Return Value:
 *  HRESULT         NOERROR always
 */

STDMETHODIMP CImpIPolyline::SizeGet(LPRECT pRect)
    {
    RectGet(pRect);
    return NOERROR;
    }






/*
 * CImpIPolyline::RectSet
 *
 * Purpose:
 *  Sets a new rectangle for the Polyline which sizes to fit.
 *
 * Parameters:
 *  pRect           LPRECT containing the new rectangle.
 *  fNotify         BOOL indicating if we're to notify anyone of
 *                  the change.
 *
 * Return Value:
 *  HRESULT         NOERROR always
 */

STDMETHODIMP CImpIPolyline::RectSet(LPRECT pRect, BOOL fNotify)
    {
    UINT            cx, cy;
    RECT            rc;

    //Scale the points from our current size to the new size
    cx=pRect->right-pRect->left;
    cy=pRect->bottom-pRect->top;

    SetRect(&rc, 0, 0, cx, cy);
    RECTTORECTS(rc, m_pObj->m_pl.rc);

    if (NULL!=m_pObj->m_hWnd)
        {
        SetWindowPos(m_pObj->m_hWnd, NULL, pRect->left, pRect->top
            , cx, cy, SWP_NOZORDER);
        InvalidateRect(m_pObj->m_hWnd, NULL, TRUE);
        }

    if (fNotify && NULL!=m_pObj->m_pAdv)
        {
        m_pObj->m_fDirty=TRUE;
        m_pObj->m_pAdv->OnSizeChange();
        }

    return NOERROR;
    }







/*
 * CImpIPolyline::SizeSet
 *
 * Purpose:
 *  Sets a new size for the Polyline which sizes to fit.
 *
 * Parameters:
 *  pRect           LPRECT containing the new rectangle.
 *  fNotify         BOOL indicating if we're to notify anyone of
 *                  the change.
 *
 * Return Value:
 *  HRESULT         NOERROR always
 */

STDMETHODIMP CImpIPolyline::SizeSet(LPRECT pRect, BOOL fNotify)
    {
    UINT            cx, cy;

    //Scale the points from our current size to the new size
    cx=pRect->right-pRect->left;
    cy=pRect->bottom-pRect->top;

    if (NULL!=m_pObj->m_hWnd)
        {
        SetWindowPos(m_pObj->m_hWnd, NULL, 0, 0, (UINT)cx, (UINT)cy
            , SWP_NOMOVE | SWP_NOZORDER);
        InvalidateRect(m_pObj->m_hWnd, NULL, TRUE);
        }

    if (fNotify && NULL!=m_pObj->m_pAdv)
        {
        m_pObj->m_fDirty=TRUE;
        m_pObj->m_pAdv->OnSizeChange();
        }

    return NOERROR;
    }






/*
 * CImpIPolyline::ColorSet
 *
 * Purpose:
 *  Changes for background or line color in the Polyline
 *
 * Parameters:
 *  iColor          UINT index of the color to change.
 *  cr              COLORREF new color to use.
 *  pcrPrev         COLORREF * in whch to store the
 *                  previous color.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise a
 *                  POLYLINE_E_ value.
 */

STDMETHODIMP CImpIPolyline::ColorSet(UINT iColor, COLORREF cr
    , COLORREF *pcrPrev)
    {
    COLORREF        crRet;

    if (NULL==pcrPrev)
        return ResultFromScode(POLYLINE_E_INVALIDPOINTER);

    switch (iColor)
        {
        case POLYLINECOLOR_BACKGROUND:
            crRet=m_pObj->m_pl.rgbBackground;
            m_pObj->m_pl.rgbBackground=cr;
            break;

        case POLYLINECOLOR_LINE:
            crRet=m_pObj->m_pl.rgbLine;
            m_pObj->m_pl.rgbLine=cr;
            break;
        }

    //If the color changed, repaint
    if (crRet!=cr)
        {
        if (NULL!=m_pObj->m_pAdv)
            {
            m_pObj->m_fDirty=TRUE;
            m_pObj->m_pAdv->OnColorChange();
            }

        InvalidateRect(m_pObj->m_hWnd, NULL, TRUE);
        UpdateWindow(m_pObj->m_hWnd);

        m_pObj->SendAdvise(OBJECTCODE_DATACHANGED);
        }

    *pcrPrev=crRet;
    return NOERROR;
    }







/*
 * CImpIPolyline::ColorGet
 *
 * Purpose:
 *  Retrieves one of the colors currently in use by the Polyline.
 *
 * Parameters:
 *  iColor          UINT identifying the color of interest.
 *  pcr             COLORREF * in which to return the color.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise a
 *                  POLYLINE_E_ value.
 */

STDMETHODIMP CImpIPolyline::ColorGet(UINT iColor, COLORREF *pcr)
    {
    COLORREF        crRet;

    if (NULL==pcr)
        return ResultFromScode(POLYLINE_E_INVALIDPOINTER);

    crRet=(POLYLINECOLOR_BACKGROUND==iColor)
        ? m_pObj->m_pl.rgbBackground : m_pObj->m_pl.rgbLine;

    *pcr=crRet;
    return NOERROR;
    }








/*
 * CImpIPolyline::LineStyleSet
 *
 * Purpose:
 *  Changes the line style in use by the Polyline
 *
 * Parameters:
 *  iStyle          UINT style of the line to use.
 *  piPrev          UINT * in which to store the previous style.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise a
 *                  POLYLINE_E_ value.
 */

STDMETHODIMP CImpIPolyline::LineStyleSet(UINT iStyle, UINT *piPrev)
    {
    UINT            uRet;

    uRet=(UINT)m_pObj->m_pl.iLineStyle;

    if (NULL==piPrev)
        return ResultFromScode(POLYLINE_E_INVALIDPOINTER);

    //Validate the line style
    if (PS_SOLID==iStyle || PS_DASH==iStyle || PS_DOT==iStyle
        || PS_DASHDOT==iStyle || PS_DASHDOTDOT==iStyle)
        {
        m_pObj->m_pl.iLineStyle=iStyle;

        if (uRet!=(UINT)m_pObj->m_pl.iLineStyle)
            {
            if (NULL!=m_pObj->m_pAdv)
                {
                m_pObj->m_fDirty=TRUE;
                m_pObj->m_pAdv->OnLineStyleChange();
                }

            InvalidateRect(m_pObj->m_hWnd, NULL, TRUE);
            UpdateWindow(m_pObj->m_hWnd);

            m_pObj->SendAdvise(OBJECTCODE_DATACHANGED);
            }
        }

    *piPrev=uRet;
    return NOERROR;
    }







/*
 * CImpIPolyline::LineStyleGet
 *
 * Purpose:
 *  Retrieves the current line style in use in the Polyline
 *
 * Parameters:
 *  piStyle         UINT * in which to store the style.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise a
 *                  POLYLINE_E_ value.
 */

STDMETHODIMP CImpIPolyline::LineStyleGet(UINT *piStyle)
    {
    if (NULL==piStyle)
        return ResultFromScode(POLYLINE_E_INVALIDPOINTER);

    *piStyle=m_pObj->m_pl.iLineStyle;
    return NOERROR;
    }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美成人一区二区三区| 久久福利资源站| 亚洲免费在线看| 亚洲视频在线观看三级| 亚洲色图清纯唯美| 亚洲免费av在线| 一级女性全黄久久生活片免费| 亚洲免费av观看| 一二三区精品视频| 亚洲3atv精品一区二区三区| 无吗不卡中文字幕| 精品一区免费av| 国产酒店精品激情| 成人午夜精品在线| 91亚洲精品一区二区乱码| 91久久免费观看| 欧美日韩视频一区二区| 日韩手机在线导航| 国产亚洲综合在线| 亚洲美女屁股眼交| 日本美女一区二区三区视频| 精东粉嫩av免费一区二区三区| 精品在线亚洲视频| 99视频精品免费视频| 在线看日韩精品电影| 91精品欧美久久久久久动漫| 久久久精品国产免大香伊| 中文字幕在线不卡一区| 亚洲国产精品久久一线不卡| 精品在线播放免费| 99视频超级精品| 6080午夜不卡| 久久九九99视频| 一区二区三区高清| 精品一区二区三区在线观看国产| 成人激情小说乱人伦| 欧美伊人久久久久久久久影院| 欧美大肚乱孕交hd孕妇| 亚洲欧洲日韩女同| 男人的天堂亚洲一区| 不卡的av在线| 欧美美女喷水视频| 国产精品看片你懂得| caoporn国产一区二区| 欧美日韩小视频| 欧美激情一区二区三区| 五月天视频一区| 成人av资源下载| 91精品国产一区二区三区香蕉| 国产欧美日本一区视频| 首页国产丝袜综合| 成人深夜在线观看| 欧美成人性战久久| 亚洲永久精品国产| 国产成人综合精品三级| 欧美日韩色综合| 一色桃子久久精品亚洲| 免费久久99精品国产| 色综合久久久久综合99| 久久色中文字幕| 亚洲成av人片在www色猫咪| 国产+成+人+亚洲欧洲自线| 制服丝袜中文字幕一区| 国产精品理论片| 国产麻豆成人传媒免费观看| 欧美精品久久99| 亚洲人午夜精品天堂一二香蕉| 国产一区二区成人久久免费影院 | 久久国产成人午夜av影院| 99热精品一区二区| 久久精品网站免费观看| 美国毛片一区二区三区| 欧美人牲a欧美精品| 亚洲日本va午夜在线影院| 国产乱码精品一区二区三区五月婷| 欧美军同video69gay| 一区二区视频在线看| 成人av动漫在线| 国产夜色精品一区二区av| 另类小说欧美激情| 欧美一区午夜精品| 亚洲成人激情av| 91福利国产精品| 成人欧美一区二区三区视频网页| 国模一区二区三区白浆| 日韩午夜在线影院| 日本不卡一区二区| 欧美高清视频在线高清观看mv色露露十八| 专区另类欧美日韩| 不卡大黄网站免费看| 国产精品麻豆视频| eeuss影院一区二区三区| 亚洲国产成人午夜在线一区| 国产高清久久久久| 国产欧美一二三区| 成人午夜精品在线| 国产精品美女一区二区| 北条麻妃一区二区三区| 国产精品色一区二区三区| 成人不卡免费av| 国产精品久久网站| 成人黄色片在线观看| 国产精品系列在线| voyeur盗摄精品| 亚洲精品中文字幕在线观看| 日本高清视频一区二区| 亚洲国产精品麻豆| 91精品国产91久久久久久一区二区| 午夜欧美在线一二页| 欧美精品久久一区| 日本欧美一区二区在线观看| 欧美电视剧免费观看| 欧美日韩色综合| 天天影视网天天综合色在线播放| 欧美日本视频在线| 日韩成人一级片| 久久综合成人精品亚洲另类欧美| 国产九色sp调教91| 亚洲婷婷综合色高清在线| 91国在线观看| 奇米一区二区三区av| 久久夜色精品一区| 成人动漫一区二区在线| 一区二区三区四区五区视频在线观看 | 国产精品中文有码| 国产精品乱子久久久久| 91黄色激情网站| 美国十次综合导航| 国产精品视频第一区| 欧美性猛交xxxxxx富婆| 久久精品二区亚洲w码| 欧美激情一区二区三区蜜桃视频 | 国产女主播在线一区二区| 91在线高清观看| 日本不卡的三区四区五区| 久久一二三国产| 91精品福利在线| 久久99久久久欧美国产| 国产精品久久久久久久久免费相片 | 欧美一级欧美三级在线观看| 精品无人码麻豆乱码1区2区| 中文字幕亚洲区| 91精品国产日韩91久久久久久| 国产精品一线二线三线| 亚洲欧美一区二区三区极速播放| 正在播放一区二区| 波多野结衣中文字幕一区二区三区| 亚洲一区二区三区三| 国产亚洲欧美中文| 欧美在线视频日韩| 国产成人精品一区二区三区四区 | 亚洲国产精品国自产拍av| 欧美亚洲高清一区| 国产麻豆午夜三级精品| 亚洲男人的天堂一区二区| 欧美成人a视频| 欧美综合视频在线观看| 国产高清精品在线| 日产国产欧美视频一区精品| 国产精品家庭影院| 精品免费国产二区三区| 欧美午夜电影一区| 日韩欧美三级在线| 色综合久久久久网| 国产成+人+日韩+欧美+亚洲| 午夜精品aaa| 亚洲人成7777| 久久精品欧美一区二区三区不卡| 欧美老肥妇做.爰bbww视频| av一区二区久久| 韩国v欧美v日本v亚洲v| 香蕉成人啪国产精品视频综合网| 中文乱码免费一区二区| 日韩免费观看高清完整版| 在线观看www91| 91在线视频网址| 国产成人免费在线视频| 蜜臀a∨国产成人精品| 亚洲制服丝袜在线| 亚洲免费观看高清完整版在线观看熊 | 色欧美乱欧美15图片| 国产一区三区三区| 日本不卡一二三区黄网| 亚洲一区二区三区三| 国产精品国产自产拍在线| 久久久久久久久久久电影| 欧美一卡在线观看| 欧美福利一区二区| 在线精品观看国产| 91黄色激情网站| 色狠狠桃花综合| 91在线云播放| 不卡区在线中文字幕| 成人免费看黄yyy456| 国产精品一二三区| 国产精品一区二区不卡| 国产一区二区免费看| 国产一区激情在线| 国产成人精品在线看| 国产91精品精华液一区二区三区|