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

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

?? ipolylin.cpp

?? 英文版的 想要的話可以下載了 為大家服務(wù)
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*
 * IPOLYLIN.CPP
 * Polyline Component Chapter 8
 *
 * Implementation of the IPolyline8 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);
    }



//CHAPTER8MOD
/*
 * ReadFromFile and WriteToFile are replaced by the IPersistStorage
 * implementation.  We no longer read from files, instead we use
 * storages.
 */
//End CHAPTER8MOD




/*
 * CImpIPolyline::DataSet
 *
 * Purpose:
 *  Sets the current data in this Polyline to a given structure.
 *
 * Parameters:
 *  pplIn           PPOLYLINEDATA to initialize to.
 *  fSizeToData     BOOL indicating if we're to size to the data
 *                  or scale it.
 *  fNotify         BOOL indicating if we're to send an advise
 *                  on this change.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise a
 *                  POLYLINE_E_ value.
 */

STDMETHODIMP CImpIPolyline::DataSet(PPOLYLINEDATA pplIn
    , BOOL fSizeToData, BOOL fNotify)
    {
    PPOLYLINEDATA   ppl=&m_pObj->m_pl;
    RECT            rc;

    /*
     * Copy the structure in pplIn and repaint to reflect the
     * new point set.  Note that unlike the RectSet message, we
     * do no scaling, assuming that the rect in the structure
     * is appropriate for the data.
     */

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

    *ppl=*pplIn;

    //Inform our parent of the data change
    if (NULL!=m_pObj->m_pAdv)
        {
        m_pObj->m_fDirty=TRUE;
        m_pObj->m_pAdv->OnDataChange();
        }

    /*
     * If we're scaling the window to fit the data, then use
     * RectSet passing our current rectangle as the new one.
     * That makes sure that the data won't change but that the
     * window is resized.
     */

    if (fSizeToData)
        {
        POINT       pt;

        /*
         * Get our offset in the parent window so we can RectSet
         * to the right place since RectSet expects rectangle in
         * parent coordinates and we get it in client coordinates.
         */
        GetWindowRect(m_pObj->m_hWnd, &rc);
        pt.x=rc.left;
        pt.y=rc.top;
        ScreenToClient(GetParent(m_pObj->m_hWnd), &pt);
        RECTSTORECT(ppl->rc, rc);
        OffsetRect(&rc, pt.x, pt.y);

        //This will also cause a repaint.
        RectSet(&rc, fNotify);
        }
    else
        {
        //Make sure we're updated.
        InvalidateRect(m_pObj->m_hWnd, NULL, TRUE);
        UpdateWindow(m_pObj->m_hWnd);
        }

    return NOERROR;
    }







/*
 * CImpIPolyline::DataGet
 *
 * Purpose:
 *  Retrieves the Polyline's current data.
 *
 * Parameters:
 *  pplIn           PPOLYLINEDATA into which we copy the data.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise a
 *                  POLYLINE_E_ value.
 */

STDMETHODIMP CImpIPolyline::DataGet(PPOLYLINEDATA pplIn)
    {
    if (NULL==pplIn)
        return ResultFromScode(POLYLINE_E_INVALIDPOINTER);

    *pplIn=m_pObj->m_pl;
    return NOERROR;
    }







/*
 * CImpIPolyline::DataSetMem
 *
 * Purpose:
 *  Sets the Polyline's data using a global memory handle
 *  instead of a pointer.
 *
 * Parameters:
 *  hMem            HGLOBAL containing the data.
 *  fFree           BOOL indicating if we're to free the data.
 *                  The memory will be freed regardless of any
 *                  error returned from here.
 *  fSizeToData     BOOL indicating if we're to size to the data
 *                  or scale it.
 *  fNotify         BOOL indicating if we're to send an advise
 *                  on this change.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise a
 *                  POLYLINE_E_ value.
 */

STDMETHODIMP CImpIPolyline::DataSetMem(HGLOBAL hMem, BOOL fFree
    , BOOL fSizeToData, BOOL fNotify)
    {
    PPOLYLINEDATA   ppl;
    HRESULT         hr=ResultFromScode(POLYLINE_E_INVALIDPOINTER);

    if (NULL!=hMem)
        {
        ppl=(PPOLYLINEDATA)GlobalLock(hMem);
        hr=DataSet(ppl, fSizeToData, fNotify);

        GlobalUnlock(hMem);

        if (fFree)
            GlobalFree(hMem);
        }

    return hr;
    }







/*
 * CImpIPolyline::DataGetMem
 *
 * Purpose:
 *  Retrieves the Polyline's data in a global memory handle.
 *
 * Parameters:
 *  phMem           HGLOBAL * in which to store the handle.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise a
 *                  POLYLINE_E_ value.
 */

STDMETHODIMP CImpIPolyline::DataGetMem(HGLOBAL *phMem)
    {
    HGLOBAL         hMem;
    PPOLYLINEDATA   ppl;
    HRESULT         hr=ResultFromScode(POLYLINE_E_INVALIDPOINTER);

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

    hMem=GlobalAlloc(GMEM_DDESHARE | GMEM_MOVEABLE, CBPOLYLINEDATA);

    if (NULL!=hMem)
        {
        ppl=(PPOLYLINEDATA)GlobalLock(hMem);
        hr=DataGet(ppl);

        GlobalUnlock(hMem);

        if (FAILED(hr))
            {
            GlobalFree(hMem);
            hMem=NULL;
            }
        }

    *phMem=hMem;
    return hr;
    }




/*
 * CImpIPolyline::RenderBitmap
 *
 * Purpose:
 *  Creates a bitmap image of the current Polyline.
 *
 * Parameters:
 *  phBmp           HBITMAP * in which to return the bitmap.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise a
 *                  POLYLINE_E_ value.
 */

STDMETHODIMP CImpIPolyline::RenderBitmap(HBITMAP *phBmp)
    {
    HDC             hDC;
    HDC             hMemDC;
    HBITMAP         hBmp;
    RECT            rc;
    HGDIOBJ         hObj;

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

    //Render a bitmap the size of the current rectangle.
    hDC=GetDC(m_pObj->m_hWnd);
    hMemDC=CreateCompatibleDC(hDC);

    GetClientRect(m_pObj->m_hWnd, &rc);
    hBmp=CreateCompatibleBitmap(hDC, rc.right, rc.bottom);

    if (NULL!=hBmp)
        {
        //Draw the POLYLINEDATA into the bitmap.
        hObj=SelectObject(hMemDC, hBmp);
        m_pObj->Draw(hMemDC, FALSE, TRUE);
        SelectObject(hMemDC, hObj);
        }

    DeleteDC(hMemDC);
    ReleaseDC(m_pObj->m_hWnd, hDC);

    *phBmp=hBmp;
    return NOERROR;
    }







/*
 * CImpIPolyline::RenderMetafile
 *
 * Purpose:
 *  Renders the current image of the Polyline into a metafile.
 *
 * Parameters:
 *  phMF            HMETAFILE * in which to return the
 *                  new metafile.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise a
 *                  POLYLINE_E_ value.
 */

STDMETHODIMP CImpIPolyline::RenderMetafile(HMETAFILE *phMF)
    {
    HDC             hDC;
    HMETAFILE       hMF;
    RECT            rc;

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

    //Create a memory metafile and return its handle.
    hDC=(HDC)CreateMetaFile(NULL);
    hMF=NULL;

    if (NULL!=hDC)
        {
        /*
         * This is absolutely essential to the metafile so it
         * can be scaled in the clipboard and any destination
         * application.
         */
        SetMapMode(hDC, MM_ANISOTROPIC);
        GetClientRect(m_pObj->m_hWnd, &rc);
        SetWindowOrgEx(hDC, 0, 0, NULL);
        SetWindowExtEx(hDC, rc.right, rc.bottom, NULL);

        m_pObj->Draw(hDC, TRUE, TRUE);
        hMF=CloseMetaFile(hDC);
        }

    *phMF=hMF;
    return NOERROR;
    }






/*
 * CImpIPolyline::RenderMetafilePict
 *
 * Purpose:
 *  Renders the current Polyline into a METAFILEPICT structure in
 *  global memory.
 *
 * Parameters:
 *  phMem           HGLOBAL * in which to return the
 *                  METAFILEPICT.
 *
 * Return Value:
 *  HRESULT         NOERROR if successful, otherwise a
 *                  POLYLINE_E_ value.
 */

STDMETHODIMP CImpIPolyline::RenderMetafilePict(HGLOBAL *phMem)
    {
    HGLOBAL         hMem;
    HMETAFILE       hMF;
    LPMETAFILEPICT  pMF;
    RECT            rc;
    HRESULT         hr;

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

    //Get the metafile
    hr=RenderMetafile(&hMF);

    if (FAILED(hr))
        return hr;

    //Allocate the METAFILEPICT structure.
    hMem=GlobalAlloc(GMEM_DDESHARE | GMEM_MOVEABLE
        , sizeof(METAFILEPICT));

    if (NULL==hMem)
        {
        DeleteMetaFile(hMF);
        return ResultFromScode(E_FAIL);
        }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久只精品国产| 欧美精选一区二区| 亚洲.国产.中文慕字在线| 欧美精品第1页| 成人午夜伦理影院| 天使萌一区二区三区免费观看| 精品国产乱码久久久久久久| 99re热这里只有精品免费视频 | 日韩一区二区三区av| 国产精品18久久久久久vr| 亚洲私人黄色宅男| 日韩一区二区三区三四区视频在线观看 | 热久久一区二区| 欧美韩国日本一区| 欧美肥妇free| 91在线视频18| 国产伦精品一区二区三区免费迷| 亚洲美女区一区| 精品动漫一区二区三区在线观看| 色综合天天综合网天天狠天天| 日本不卡一二三区黄网| 亚洲欧美另类小说| 久久久久久亚洲综合影院红桃| 欧美日本一道本| 99久久er热在这里只有精品15| 激情五月婷婷综合| 亚洲午夜激情网站| 国产精品萝li| 精品美女在线播放| 欧美日韩精品三区| aaa国产一区| 国产伦精品一区二区三区免费| 日精品一区二区| 亚洲欧美色综合| 国产欧美综合在线观看第十页| 日韩欧美精品三级| 欧美电影一区二区三区| 91国产成人在线| 99国产精品国产精品毛片| 三级影片在线观看欧美日韩一区二区| 亚洲天堂2016| **欧美大码日韩| 国产精品成人一区二区艾草| 久久精品亚洲一区二区三区浴池| 欧美一区二区三区婷婷月色| 欧美日韩美女一区二区| 欧美在线一二三| 色八戒一区二区三区| 99久久精品久久久久久清纯| 麻豆精品久久精品色综合| 亚洲高清免费观看| 亚洲影院理伦片| 一个色综合网站| 亚洲国产一区二区视频| 日韩久久一区二区| 一区二区三区蜜桃| 亚洲制服丝袜一区| 午夜精品在线视频一区| 亚洲第一会所有码转帖| 亚洲第一在线综合网站| 日韩制服丝袜av| 久久福利视频一区二区| 精品一区二区三区在线观看国产 | 色爱区综合激月婷婷| 国产成人鲁色资源国产91色综| 国产一区二区三区免费看| 久久精品国产一区二区三区免费看| 麻豆一区二区三| 国内精品久久久久影院一蜜桃| 国产一区二区三区日韩| 懂色一区二区三区免费观看| 国产精品自拍av| 96av麻豆蜜桃一区二区| eeuss国产一区二区三区| 91亚洲国产成人精品一区二三| 色老头久久综合| 日韩一区二区影院| 日本一区二区三区国色天香 | 一区二区国产盗摄色噜噜| 亚洲一区二区三区在线看| 日韩黄色片在线观看| 麻豆精品一区二区av白丝在线| 精久久久久久久久久久| 91色porny蝌蚪| 91精品国产综合久久蜜臀| 精品国精品自拍自在线| 日本一区二区电影| 亚洲一区二区三区四区在线观看 | 国产精品久久影院| 亚洲四区在线观看| 日韩av中文在线观看| 国内外成人在线| 国产精品夜夜爽| 欧美三片在线视频观看| 精品人伦一区二区色婷婷| 中文字幕亚洲一区二区av在线| 亚洲成在人线免费| 国产黄色91视频| 欧美群妇大交群中文字幕| 国产亚洲精品超碰| 亚洲欧美在线另类| 亚洲国产美女搞黄色| 国产麻豆一精品一av一免费 | 日韩成人一区二区| 国产最新精品精品你懂的| 99精品热视频| 精品99999| 亚洲一级电影视频| 国产91色综合久久免费分享| 欧美日韩一区在线| 中文欧美字幕免费| 一区二区在线免费观看| 看电影不卡的网站| 91九色最新地址| 欧美国产精品v| 免费在线成人网| 色婷婷综合久久久久中文一区二区 | 成人avav在线| 欧美一级理论片| 亚洲乱码国产乱码精品精小说| 久久99久久精品欧美| 欧美日韩日日夜夜| 亚洲欧美日韩一区二区| 久久9热精品视频| 在线播放一区二区三区| 亚洲另类中文字| 国产激情视频一区二区在线观看 | 久久国产婷婷国产香蕉| 91在线一区二区三区| 久久精品人人爽人人爽| 美女mm1313爽爽久久久蜜臀| 精品视频在线视频| 亚洲乱码一区二区三区在线观看| 成人丝袜高跟foot| 久久久精品免费网站| 国产在线国偷精品免费看| 欧美色偷偷大香| 亚洲精品美国一| av中文字幕不卡| 一区在线观看视频| 成人国产精品视频| 国产蜜臀av在线一区二区三区| 丝袜美腿成人在线| 日韩女优电影在线观看| 国产原创一区二区三区| 国产片一区二区三区| 99久久综合狠狠综合久久| 亚洲精品久久久蜜桃| 欧美视频一区二区在线观看| 天天综合天天综合色| 日韩欧美综合在线| 国产精品1区2区| 亚洲女与黑人做爰| 欧美精品丝袜久久久中文字幕| 首页国产欧美日韩丝袜| 精品久久久久久最新网址| 国产99久久久国产精品潘金网站| 国产精品每日更新| 欧美性色综合网| 精品一区二区三区在线视频| 国产女人aaa级久久久级| 色综合久久久网| 首页亚洲欧美制服丝腿| 久久久高清一区二区三区| www.66久久| 日日夜夜免费精品| 久久午夜电影网| 色婷婷综合中文久久一本| 免费一级片91| 亚洲视频免费在线观看| 欧美一区二区女人| 成人午夜电影久久影院| 亚洲电影在线播放| 久久久不卡影院| 欧美日韩一区久久| 国产精品亚洲а∨天堂免在线| 亚洲精品少妇30p| 精品88久久久久88久久久| 日本高清无吗v一区| 麻豆成人久久精品二区三区小说| 国产精品无圣光一区二区| 欧美嫩在线观看| 成人动漫视频在线| 日本欧美一区二区三区乱码| 国产精品黄色在线观看| 欧美一区二区大片| 91色视频在线| 国产一区不卡在线| 午夜伦理一区二区| 最新热久久免费视频| 精品国产1区二区| 欧美日韩一区不卡| 97se亚洲国产综合自在线不卡| 久久国产婷婷国产香蕉| 亚洲制服丝袜一区| 国产精品久久夜| 欧美精品一区二区不卡| 欧美精品一卡两卡| 色久优优欧美色久优优| 成人免费的视频|