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

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

?? iviewobj.cpp

?? 英文版的 想要的話可以下載了 為大家服務
?? CPP
字號:
/*
 * IVIEWOBJ.CPP
 * Cosmo Handler Chapter 19
 *
 * Implementation of the IViewObject2 interface for Cosmo Handler.
 *
 * Copyright (c)1993-1995 Microsoft Corporation, All Rights Reserved
 *
 * Kraig Brockschmidt, Microsoft
 * Internet  :  kraigb@microsoft.com
 * Compuserve:  >INTERNET:kraigb@microsoft.com
 */


#include "hcosmo.h"


/*
 * CImpIViewObject2::CImpIViewObject2
 * CImpIViewObject2::~CImpIViewObject2
 *
 * Parameters (Constructor):
 *  pObj            PCFigure of the object we're in.
 *  pUnkOuter       LPUNKNOWN to which we delegate.
 */

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

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




/*
 * CImpIViewObject2::QueryInterface
 * CImpIViewObject2::AddRef
 * CImpIViewObject2::Release
 */

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


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

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



/*
 * CImpIViewObject2::Draw
 *
 * Purpose:
 *  Draws the object on the given hDC specifically for the requested
 *  aspect, device, and within the appropriate bounds.
 *
 * Parameters:
 *  dwAspect        DWORD aspect to draw.
 *  lindex          LONG index of the piece to draw.
 *  pvAspect        LPVOID for extra information, always NULL.
 *  ptd             DVTARGETDEVICE * containing device
 *                  information.
 *  hICDev          HDC containing the IC for the device.
 *  hDC             HDC on which to draw.
 *  pRectBounds     LPCRECTL describing the rectangle in which to
 *                  draw.
 *  pRectWBounds    LPCRECTL describing the placement rectangle if
 *                  part of what you draw is another metafile.
 *  pfnContinue     Function to call periodically during long
 *                  repaints.
 *  dwContinue      DWORD extra information for pfnContinue.
 *
 * Return Value:
 *  HRESULT         NOERROR or a general error value.
 */

STDMETHODIMP CImpIViewObject2::Draw(DWORD dwAspect, LONG lindex
    , void *pvAspect, DVTARGETDEVICE *ptd, HDC hICDev
    , HDC hDC, LPCRECTL pRectBounds, LPCRECTL pRectWBounds
    , BOOL (CALLBACK *pfnContinue) (DWORD), DWORD dwContinue)
    {
    RECT            rc;
    POLYLINEDATA    pl;
    PPOLYLINEDATA   ppl=&m_pObj->m_pl;

    RECTFROMRECTL(rc, *pRectBounds);

    //Delegate iconic and printed representations.
    if (!((DVASPECT_CONTENT | DVASPECT_THUMBNAIL) & dwAspect))
        {
        return m_pObj->m_pDefIViewObject2->Draw(dwAspect, lindex
            , pvAspect, ptd, hICDev, hDC, pRectBounds, pRectWBounds
            , pfnContinue, dwContinue);
        }


    /*
     * If we're asked to draw a frozen aspect, use the data from
     * a copy we made in IViewObject2::Freeze.  Otherwise use the
     * current data.
     */
    if (dwAspect & m_pObj->m_dwFrozenAspects)
        {
        //Point to the data to actually use.
        if (DVASPECT_CONTENT==dwAspect)
            ppl=&m_pObj->m_plContent;
        else
            ppl=&m_pObj->m_plThumbnail;
        }


    //Make a copy so we can modify it
    memcpy(&pl, ppl, CBPOLYLINEDATA);

    /*
     * If we're going to a printer, check if it's color capable.
     * if not, then use black on white for this figure.
     */
    if (NULL!=hICDev)
        {
        if (GetDeviceCaps(hICDev, NUMCOLORS) <= 2)
            {
            pl.rgbBackground=RGB(255, 255, 255);
            pl.rgbLine=RGB(0, 0, 0);
            }
        }

    m_pObj->Draw(hDC, &rc, dwAspect, ptd, hICDev, &pl);
    return NOERROR;
    }




/*
 * CImpIViewObject2::GetColorSet
 *
 * Purpose:
 *
 * Parameters:
 *  dwAspect        DWORD aspect of interest.
 *  lindex          LONG piece of interest.
 *  pvAspect        LPVOID containing extra information, always
 *                  NULL.
 *  ptd             DVTARGETDEVICE * containing device
 *                  information.
 *  hICDev          HDC containing the IC for the device.
 *  ppColorSet      LPLOGPALETTE * into which to return the
 *                  pointer to the palette in this color set.
 *
 * Return Value:
 *  HRESULT         NOERROR on success, S_FALSE if not supported.
 */

STDMETHODIMP CImpIViewObject2::GetColorSet(DWORD dwDrawAspect
    , LONG lindex, LPVOID pvAspect, DVTARGETDEVICE *ptd
    , HDC hICDev, LPLOGPALETTE *ppColorSet)
    {
    return ResultFromScode(S_FALSE);
    }






/*
 * CImpIViewObject2::Freeze
 *
 * Purpose:
 *  Freezes the view of a particular aspect such that data changes
 *  do not affect the view.
 *
 * Parameters:
 *  dwAspect        DWORD aspect to freeze.
 *  lindex          LONG piece index under consideration.
 *  pvAspect        LPVOID for further information, always NULL.
 *  pdwFreeze       LPDWORD in which to return the key.
 *
 * Return Value:
 *  HRESULT         NOERROR or a general error value.
 */

STDMETHODIMP CImpIViewObject2::Freeze(DWORD dwAspect, LONG lindex
    , LPVOID pvAspect, LPDWORD pdwFreeze)
    {
    //Delegate any aspect we don't handle.
    if (!((DVASPECT_CONTENT | DVASPECT_THUMBNAIL) & dwAspect))
        {
        return m_pObj->m_pDefIViewObject2->Freeze(dwAspect, lindex
            , pvAspect, pdwFreeze);
        }

    if (dwAspect & m_pObj->m_dwFrozenAspects)
        {
        *pdwFreeze=dwAspect + FREEZE_KEY_OFFSET;
        return ResultFromScode(VIEW_S_ALREADY_FROZEN);
        }

    m_pObj->m_dwFrozenAspects |= dwAspect;


    /*
     * For whatever aspects become frozen, make a copy of the data.
     * Later when drawing, if such a frozen aspect is requested,
     * we'll draw from this data rather than from our current data.
     */
    if (DVASPECT_CONTENT & dwAspect)
        {
        memcpy(&m_pObj->m_plContent, &m_pObj->m_pl
            , CBPOLYLINEDATA);
        }

    if (DVASPECT_THUMBNAIL & dwAspect)
        {
        memcpy(&m_pObj->m_plThumbnail, &m_pObj->m_pl
            , CBPOLYLINEDATA);
        }

    if (NULL!=pdwFreeze)
        *pdwFreeze=dwAspect + FREEZE_KEY_OFFSET;

    return NOERROR;
    }






/*
 * CImpIViewObject2::Unfreeze
 *
 * Purpose:
 *  Thaws an aspect frozen in Freeze.  We expect that a container
 *  will redraw us after freezing if necessary, so we don't send
 *  any sort of notification here.
 *
 * Parameters:
 *  dwFreeze        DWORD key returned from Freeze.
 *
 * Return Value:
 *  HRESULT         NOERROR or a general error value.
 */

STDMETHODIMP CImpIViewObject2::Unfreeze(DWORD dwFreeze)
    {
    DWORD       dwAspect=dwFreeze - FREEZE_KEY_OFFSET;

    //Delegate any aspect we don't handle.
    if (!((DVASPECT_CONTENT | DVASPECT_THUMBNAIL) & dwAspect))
        return m_pObj->m_pDefIViewObject2->Unfreeze(dwFreeze);

    //The aspect to unfreeze is in the key.
    m_pObj->m_dwFrozenAspects &= ~(dwAspect);

    /*
     * Since we always kept our current data up to date, we don't
     * have to do anything here like requesting data again.
     * Because we removed dwAspect from m_dwFrozenAspects, Draw
     * will again use the current data.
     */

    return NOERROR;
    }





/*
 * CImpIViewObject2::SetAdvise
 *
 * Purpose:
 *  Provides an advise sink to the view object enabling
 *  notifications for a specific aspect.
 *
 * Parameters:
 *  dwAspects       DWORD describing the aspects of interest.
 *  dwAdvf          DWORD containing advise flags.
 *  pIAdviseSink    LPADVISESINK to notify.
 *
 * Return Value:
 *  HRESULT         NOERROR or a general error value.
 */

STDMETHODIMP CImpIViewObject2::SetAdvise(DWORD dwAspects
    , DWORD dwAdvf, LPADVISESINK pIAdviseSink)
    {
    //Pass anything we don't support on through
    if (!((DVASPECT_CONTENT | DVASPECT_THUMBNAIL) & dwAspects))
        {
        return m_pObj->m_pDefIViewObject2->SetAdvise(dwAspects
            , dwAdvf, pIAdviseSink);
        }

    if (NULL!=m_pObj->m_pIAdvSinkView)
        m_pObj->m_pIAdvSinkView->Release();

    m_pObj->m_dwAdviseAspects=dwAspects;
    m_pObj->m_dwAdviseFlags=dwAdvf;

    m_pObj->m_pIAdvSinkView=pIAdviseSink;

    if (NULL!=m_pObj->m_pIAdvSinkView)
        m_pObj->m_pIAdvSinkView->AddRef();

    return NOERROR;
    }




/*
 * CImpIViewObject2::GetAdvise
 *
 * Purpose:
 *  Returns the last known IAdviseSink seen by SetAdvise.
 *
 * Parameters:
 *  pdwAspects      LPDWORD in which to store the last requested
 *                  aspects.
 *  pdwAdvf         LPDWORD in which to store the last requested
 *                  flags.
 *  ppIAdvSink      LPADVISESINK * in which to store the
 *                  IAdviseSink.
 *
 * Return Value:
 *  HRESULT         NOERROR or a general error value.
 */

STDMETHODIMP CImpIViewObject2::GetAdvise(LPDWORD pdwAspects
    , LPDWORD pdwAdvf, LPADVISESINK *ppAdvSink)
    {
    if (NULL==m_pObj->m_pIAdvSinkView)
        {
        return m_pObj->m_pDefIViewObject2->GetAdvise(pdwAspects
            , pdwAdvf, ppAdvSink);
        }

    if (NULL==ppAdvSink)
        return ResultFromScode(E_INVALIDARG);
    else
        {
        *ppAdvSink=m_pObj->m_pIAdvSinkView;
        m_pObj->m_pIAdvSinkView->AddRef();
        }

    if (NULL!=pdwAspects)
        *pdwAspects=m_pObj->m_dwAdviseAspects;

    if (NULL!=pdwAdvf)
        *pdwAdvf=m_pObj->m_dwAdviseFlags;

    return NOERROR;
    }




/*
 * CImpIViewObject2::GetExtent
 *
 * Purpose:
 *  Retrieves the extents of the object's display.
 *
 * Parameters:
 *  dwAspect        DWORD of the aspect of interest.
 *  lindex          LONG index of the piece of interest.
 *  ptd             DVTARGETDEVICE * with device information.
 *  pszl            LPSIZEL to the structure in which to return
 *                  the extents.
 *
 * Return Value:
 *  HRESULT         NOERROR or a general error value.
 */

STDMETHODIMP CImpIViewObject2::GetExtent(DWORD dwAspect, LONG lindex
    , DVTARGETDEVICE *ptd, LPSIZEL pszl)
    {
    HDC         hDC;
    int         iXppli, iYppli;
    RECT        rc;

    /*
     * We can answer for CONTENT/THUMBNAIL, but try the server for
     * others. In addition, always delegate is the server is running
     * since it has a window to define the size.
     */
    if (!((DVASPECT_CONTENT | DVASPECT_THUMBNAIL) & dwAspect)
        || OleIsRunning(m_pObj->m_pDefIOleObject))
        return m_pObj->m_pDefIOleObject->GetExtent(dwAspect, pszl);

    /*
     * The size is in the rc field of the POLYLINEDATA structure
     * which we now have to convert to HIMETRIC.
     */

    hDC=GetDC(NULL);
    iXppli=GetDeviceCaps(hDC, LOGPIXELSX);
    iYppli=GetDeviceCaps(hDC, LOGPIXELSY);

    RECTSTORECT(m_pObj->m_pl.rc, rc);
    pszl->cx=(long)MulDiv(HIMETRIC_PER_INCH
        , (rc.right-rc.left), iXppli);

    pszl->cy=(long)MulDiv(HIMETRIC_PER_INCH
        , (rc.bottom-rc.top), iYppli);

    ReleaseDC(NULL, hDC);
    return NOERROR;
    }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久91精品久久久久久秒播| 狠狠狠色丁香婷婷综合激情| 欧美大片一区二区三区| 不卡视频免费播放| 日韩黄色免费网站| 亚洲三级理论片| 国产亚洲精品aa| 欧美久久久久久久久| 99久久婷婷国产综合精品| 久久国产精品99久久久久久老狼| 亚洲男人天堂一区| 国产精品女主播在线观看| 欧美一区二区高清| 欧美综合色免费| 99久免费精品视频在线观看 | 久久久av毛片精品| 欧美肥妇free| 91福利资源站| 99精品视频在线观看免费| 国产精品亚洲专一区二区三区| 秋霞午夜av一区二区三区| 亚洲一级二级三级在线免费观看| 国产精品国产三级国产三级人妇| 亚洲精品一区二区三区四区高清| 欧美挠脚心视频网站| 在线精品视频小说1| 99国产欧美另类久久久精品 | 91免费在线播放| 成人性生交大片免费看中文网站| 黄网站免费久久| 九九热在线视频观看这里只有精品| 亚洲va欧美va人人爽| 亚洲精品免费在线观看| 自拍偷拍亚洲综合| 亚洲欧洲av一区二区三区久久| 国产日韩成人精品| 欧美高清在线精品一区| 欧美高清在线精品一区| 亚洲国产精品二十页| 国产精品理论在线观看| 国产精品久久综合| 国产精品成人在线观看| 中文字幕在线不卡国产视频| 国产精品久久久久影院亚瑟 | 欧美精品久久一区二区三区| 欧美视频一区二区在线观看| 欧美色大人视频| 欧美视频一区二区三区在线观看| 欧美视频在线一区二区三区 | 亚洲婷婷综合久久一本伊一区| 欧美国产精品一区二区三区| 国产精品免费免费| 亚洲日本一区二区| 亚洲一区成人在线| 日韩一区精品字幕| 国内精品嫩模私拍在线| 国产成人99久久亚洲综合精品| 国产 日韩 欧美大片| 95精品视频在线| 欧洲激情一区二区| 欧美不卡一区二区三区| 国产视频一区二区在线| 一区视频在线播放| 性做久久久久久久久| 精品在线观看视频| gogo大胆日本视频一区| 欧美亚洲国产bt| 欧美一级片在线| 欧美国产欧美综合| 亚洲主播在线播放| 国产一区二区在线视频| 99r国产精品| 欧美精品国产精品| 国产拍欧美日韩视频二区| 亚洲男同1069视频| 久久成人av少妇免费| caoporm超碰国产精品| 欧美日韩国产一级片| 久久精品一区二区三区四区| 亚洲免费伊人电影| 精品无人区卡一卡二卡三乱码免费卡 | 欧美亚洲动漫制服丝袜| 日韩免费性生活视频播放| 亚洲免费在线观看视频| 精品在线播放午夜| 91福利视频久久久久| 精品国产乱码久久久久久图片| 国产精品久久久久久久蜜臀| 日韩精品一级中文字幕精品视频免费观看| 狠狠色丁香久久婷婷综合_中| 99这里都是精品| 日韩精品一区二区三区视频| 一区二区三区中文字幕精品精品| 蜜臂av日日欢夜夜爽一区| 99久久精品国产麻豆演员表| 日韩一区二区不卡| 亚洲免费伊人电影| 国产成人自拍高清视频在线免费播放| 91国偷自产一区二区三区观看| 欧美电影免费观看高清完整版| 亚洲欧美区自拍先锋| 激情综合网天天干| 欧美日韩国产首页| 国产精品久久网站| 国产一区久久久| 欧美一区二区黄| 亚洲国产一区二区视频| 成人免费视频视频在线观看免费 | 精品国产乱码久久久久久夜甘婷婷 | 一区二区三区精密机械公司| 国产精品一区二区久久不卡 | 欧美精品tushy高清| 最新不卡av在线| 国产福利一区二区三区在线视频| 51久久夜色精品国产麻豆| 亚洲精品乱码久久久久久| 成人在线视频首页| 久久精品一区二区三区av| 蜜臀av性久久久久av蜜臀妖精| 在线观看免费亚洲| 中文字幕一区二区三区不卡在线| 国产福利一区二区三区在线视频| 日韩精品一区二区三区在线| 午夜亚洲国产au精品一区二区| 色综合久久66| 亚洲你懂的在线视频| 91浏览器在线视频| 自拍偷拍欧美激情| k8久久久一区二区三区| 国产精品久久三区| 成人av在线资源| 国产精品久久久久久一区二区三区| 国产精品一区二区久久不卡| 国产网站一区二区三区| 国产精品一二二区| 中文字幕av一区二区三区| 粉嫩绯色av一区二区在线观看| 久久久精品2019中文字幕之3| 国产美女娇喘av呻吟久久| 久久久久国产精品麻豆ai换脸| 国产在线精品一区二区夜色| 欧美va在线播放| 国产乱码精品一区二区三| 国产农村妇女毛片精品久久麻豆| 国产99久久久国产精品免费看| 国产性做久久久久久| gogo大胆日本视频一区| 亚洲激情在线播放| 在线免费观看成人短视频| 亚洲成人av福利| 欧美一区二区精品| 国产一区在线看| 中文字幕乱码日本亚洲一区二区 | 色婷婷精品大在线视频| 亚洲精品美腿丝袜| 欧美日韩成人综合| 麻豆国产精品一区二区三区| 久久夜色精品一区| av电影天堂一区二区在线观看| 亚洲综合一区在线| 日韩欧美国产综合| 国产美女视频一区| 亚洲欧美激情一区二区| 欧美三级资源在线| 精品在线免费视频| 中文字幕一区二区不卡| 欧美午夜片在线观看| 麻豆成人免费电影| 中文字幕欧美区| 欧美日韩国产色站一区二区三区| 久久精品国产亚洲高清剧情介绍 | 7777女厕盗摄久久久| 激情六月婷婷久久| 亚洲美女视频在线观看| 日韩欧美一二三区| 波多野结衣中文字幕一区二区三区| 亚洲综合一二区| 国产亚洲美州欧州综合国| 在线观看国产日韩| 国产成人精品亚洲777人妖| 亚洲午夜精品在线| 国产亚洲1区2区3区| 777色狠狠一区二区三区| 国产91对白在线观看九色| 亚洲影院免费观看| 久久免费电影网| 欧美三电影在线| 国产成人综合亚洲91猫咪| 亚洲一区视频在线观看视频| 舔着乳尖日韩一区| 欧美日韩一本到| 国产精品一级二级三级| 亚洲午夜视频在线观看| 国产片一区二区| 欧美一区二区三区播放老司机| 成人性生交大片| 免费高清在线一区| 有码一区二区三区| 国产精品久久久久久久久搜平片| 欧美一区二区视频观看视频 |