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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ipolylin.cpp

?? 英文版的 想要的話可以下載了 為大家服務
?? CPP
?? 第 1 頁 / 共 2 頁
字號:

    /*
     * Global lock only fails in PMODE if the selector is invalid
     * (like it was discarded) or references a 0 length segment,
     * neither of which can happen here.
     */
    pMF=(LPMETAFILEPICT)GlobalLock(hMem);

    pMF->hMF=hMF;
    pMF->mm=MM_ANISOTROPIC;

    //Insert the extents in MM_HIMETRIC units.
    GetClientRect(m_pObj->m_hWnd, &rc);
    m_pObj->RectConvertMappings(&rc, FALSE);
    pMF->xExt=rc.right;
    pMF->yExt=rc.bottom;

    GlobalUnlock(hMem);

    *phMem=hMem;
    return NOERROR;
    }









/*
 * 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.
    GetClientRect(m_pObj->m_hWnd, &rc);
    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;

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

    //Inform the advise sink of this data change.
    if (NULL!=m_pObj->m_pAdv)
        {
        m_pObj->m_fDirty=TRUE;
        m_pObj->m_pAdv->OnDataChange();
        }

    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();
        }

    //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;

    //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;

    SetWindowPos(m_pObj->m_hWnd, NULL, pRect->left, pRect->top
        , cx, cy, SWP_NOZORDER);

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

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

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

    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;

    SetWindowPos(m_pObj->m_hWnd, NULL, 0, 0, (UINT)cx, (UINT)cy
        , SWP_NOMOVE | SWP_NOZORDER);

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

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

    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);
        }

    *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);
            }
        }

    *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一区二区三区免费野_久草精品视频
欧美久久婷婷综合色| 亚洲国产精品影院| 欧美午夜精品理论片a级按摩| 亚洲国产另类精品专区| 在线一区二区观看| 美女任你摸久久| 中文字幕在线播放不卡一区| 欧美性videosxxxxx| 美女一区二区久久| 一区二区三区欧美视频| 久久久亚洲国产美女国产盗摄| 91久久久免费一区二区| 激情图片小说一区| 亚洲国产综合视频在线观看| 国产欧美精品区一区二区三区 | 在线视频一区二区三区| 久久激情五月激情| 玉足女爽爽91| 国产欧美日韩在线视频| 91麻豆精品国产91久久久久久久久 | 精品久久久久香蕉网| 91极品美女在线| 国产剧情一区二区| 亚洲影视资源网| 日本一区二区三区电影| 欧美一区二区在线视频| 激情国产一区二区| 日韩国产欧美三级| 亚洲精品国产一区二区三区四区在线| 欧美v日韩v国产v| 欧美日韩国产在线播放网站| 91免费视频网址| 成人免费视频免费观看| 精品在线观看视频| 日韩av在线发布| 亚洲与欧洲av电影| 亚洲精品视频在线看| 中文字幕欧美国产| 精品国产亚洲在线| 欧美一级精品大片| 欧美猛男gaygay网站| 欧美午夜精品一区二区三区 | 国产欧美日韩综合精品一区二区 | 亚洲视频电影在线| 国产欧美精品在线观看| 欧美精品一区二区三区蜜桃 | 日本不卡一区二区三区| 亚洲四区在线观看| 亚洲天堂2016| 亚洲高清免费在线| 亚洲成人综合在线| 偷窥国产亚洲免费视频| 日韩精品视频网| 久久精品国内一区二区三区| 久久精品99国产精品| 国产sm精品调教视频网站| jlzzjlzz亚洲女人18| 色成年激情久久综合| 国产午夜精品久久久久久免费视| 久久一留热品黄| 国产欧美精品一区二区色综合朱莉| 亚洲国产精品成人综合色在线婷婷| 亚洲欧美综合另类在线卡通| 亚洲午夜免费电影| 青娱乐精品在线视频| 国产精品一级片| 91在线视频播放| 91精品国产色综合久久ai换脸| 日韩精品中午字幕| 国产精品入口麻豆原神| 一区二区在线免费观看| 日韩精品电影在线| 国产98色在线|日韩| 在线观看国产一区二区| 欧美v日韩v国产v| 亚洲欧美日韩久久| 久久99精品久久久久久国产越南 | 精品一区二区三区在线视频| 成人免费毛片app| 欧美精品三级日韩久久| 国产日韩欧美不卡| 手机精品视频在线观看| 国产aⅴ精品一区二区三区色成熟| 色香蕉久久蜜桃| 日韩三级免费观看| 亚洲女厕所小便bbb| 久久精品国产成人一区二区三区| www.日韩在线| 欧美白人最猛性xxxxx69交| 亚洲精品欧美激情| 国产精品18久久久久久久网站| 欧美亚洲丝袜传媒另类| 国产校园另类小说区| 午夜精品久久久久久久蜜桃app| 国产精品中文有码| 欧美一区二区三区免费在线看 | 久久国产尿小便嘘嘘尿| 色综合天天综合| 久久久99精品免费观看不卡| 五月天一区二区| 97超碰欧美中文字幕| 欧美精品一区二区三区很污很色的| 一级精品视频在线观看宜春院| 国内精品免费**视频| 911国产精品| 亚洲亚洲精品在线观看| 成人av在线资源| 亚洲精品一区二区三区四区高清| 亚洲午夜一二三区视频| 91视频免费播放| 欧美高清在线精品一区| 国内精品写真在线观看| 91精品国产黑色紧身裤美女| 亚洲愉拍自拍另类高清精品| 99re8在线精品视频免费播放| 久久免费偷拍视频| 美国三级日本三级久久99| 欧美日本一区二区三区| 一区二区三区在线观看网站| av在线播放不卡| 国产精品毛片久久久久久| 国产一区二区三区精品视频| 日韩欧美国产一区二区在线播放| 韩日精品视频一区| 欧美一区二区三区免费在线看 | 亚洲一二三区不卡| 91视频免费看| 亚洲裸体xxx| 91浏览器入口在线观看| 综合久久久久久久| voyeur盗摄精品| 1区2区3区国产精品| 99久久er热在这里只有精品66| 日本一区二区三区视频视频| 国产精品1区2区3区在线观看| 久久一区二区视频| 国产一区二区在线观看视频| 欧美大肚乱孕交hd孕妇| 狠狠色综合播放一区二区| 精品电影一区二区三区| 国产精品夜夜嗨| 国产亚洲一区二区三区四区| 粉嫩嫩av羞羞动漫久久久| 中文字幕在线不卡一区二区三区| 波多野结衣欧美| 亚洲欧美成人一区二区三区| 欧美在线视频全部完| 一区二区三区 在线观看视频| 欧美在线三级电影| 奇米影视一区二区三区| 久久美女高清视频| 国产精品99久久不卡二区| 亚洲国产精品99久久久久久久久 | 欧美午夜理伦三级在线观看| 亚洲国产成人tv| 日韩三级电影网址| 国产乱理伦片在线观看夜一区 | 男女激情视频一区| 亚洲精品一区二区三区影院| 成人深夜视频在线观看| 亚洲精品自拍动漫在线| 8v天堂国产在线一区二区| 精品一区二区免费| 国产精品久久综合| 欧美一a一片一级一片| 蜜桃av一区二区三区电影| 久久久99精品免费观看| 一本色道亚洲精品aⅴ| 日本怡春院一区二区| 国产女人18毛片水真多成人如厕| 色婷婷国产精品久久包臀| 日本亚洲三级在线| 国产精品区一区二区三区| 欧美三级资源在线| 狠狠色丁香久久婷婷综| 一区二区三区欧美| 日韩欧美三级在线| 99精品1区2区| 精品在线观看免费| 亚洲一区二区三区在线播放| 欧美成人伊人久久综合网| 97超碰欧美中文字幕| 麻豆精品久久精品色综合| 亚洲男人的天堂av| 亚洲精品一区二区三区蜜桃下载| 91日韩一区二区三区| 久久99久久久欧美国产| 亚洲一区二区视频| 久久精品水蜜桃av综合天堂| 欧美日韩精品福利| av在线这里只有精品| 国模娜娜一区二区三区| 亚洲地区一二三色| 国产精品欧美综合在线| 日韩美女一区二区三区| 一本久久a久久精品亚洲| 国产精品456露脸| 麻豆高清免费国产一区| 亚洲成人av在线电影| 亚洲码国产岛国毛片在线|