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

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

?? document.cpp

?? 英文版的 想要的話可以下載了 為大家服務
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*
 * DOCUMENT.CPP
 * Cosmo Chapter 13
 *
 * Implementation of the CCosmoDoc derivation of CDocument as
 * well as an implementation of CPolylineAdviseSink.
 *
 * Copyright (c)1993-1995 Microsoft Corporation, All Rights Reserved
 *
 * Kraig Brockschmidt, Microsoft
 * Internet  :  kraigb@microsoft.com
 * Compuserve:  >INTERNET:kraigb@microsoft.com
 */


#include "cosmo.h"


/*
 * CCosmoDoc::CCosmoDoc
 * CCosmoDoc::~CCosmoDoc
 *
 * Constructor Parameters:
 *  hInst           HINSTANCE of the application.
 *  pFR             PCFrame of the frame object.
 *  pAdv            PCDocumentAdviseSink to notify on events
 */

CCosmoDoc::CCosmoDoc(HINSTANCE hInst, PCFrame pFR
    , PCDocumentAdviseSink pAdv)
    : CDocument(hInst, pFR, pAdv)
    {
    m_pPL=NULL;
    m_pPLAdv=NULL;
    m_uPrevSize=SIZE_RESTORED;

    //CHAPTER13MOD
    m_pDropTarget=NULL;
    m_fDragSource=FALSE;
    //End CHAPTER13MOD
    return;
    }


CCosmoDoc::~CCosmoDoc(void)
    {
    //Clean up the allocations we did in Init
    if (NULL!=m_pPL)
        delete m_pPL;

    if (NULL!=m_pPLAdv)
        delete m_pPLAdv;

    return;
    }






/*
 * CCosmoDoc::Init
 *
 * Purpose:
 *  Initializes an already created document window.  The client
 *  actually creates the window for us, then passes that here for
 *  further initialization.
 *
 * Parameters:
 *  pDI             PDOCUMENTINIT containing initialization
 *                  parameters.
 *
 * Return Value:
 *  BOOL            TRUE if the function succeeded, FALSE otherwise.
 */

BOOL CCosmoDoc::Init(PDOCUMENTINIT pDI)
    {
    RECT        rc;

    //Change the stringtable range to our customization.
    pDI->idsMin=IDS_DOCUMENTMIN;
    pDI->idsMax=IDS_DOCUMENTMAX;

    //Do default initialization
    if (!CDocument::Init(pDI))
        return FALSE;

    //Add the Polyline stuff we need.
    m_pPLAdv=new CPolylineAdviseSink(this);
    m_pPL   =new CPolyline(m_hInst);

    //Attempt to create our contained Polyline.
    GetClientRect(m_hWnd, &rc);
    InflateRect(&rc, -8, -8);

    if (!m_pPL->Init(m_hWnd, &rc, WS_CHILD | WS_VISIBLE
        , ID_POLYLINE, m_pPLAdv))
        return FALSE;

    //CHAPTER13MOD
    m_pDropTarget=new CDropTarget(this);

    if (NULL!=m_pDropTarget)
        {
        m_pDropTarget->AddRef();
        CoLockObjectExternal(m_pDropTarget, TRUE, FALSE);
        RegisterDragDrop(m_hWnd, m_pDropTarget);
        }
    //End CHAPTER13MOD

    return TRUE;
    }







/*
 * CCosmoDoc::FMessageHook
 *
 * Purpose:
 *  Processes WM_SIZE for the document so we can resize
 *  the Polyline.
 *
 * Parameters:
 *  <WndProc Parameters>
 *  pLRes           LRESULT * in which to store the return
 *                  value for the message.
 *
 * Return Value:
 *  BOOL            TRUE to prevent further processing,
 *                  FALSE otherwise.
 */

BOOL CCosmoDoc::FMessageHook(HWND hWnd, UINT iMsg, WPARAM wParam
    , LPARAM lParam, LRESULT *pLRes)
    {
    UINT        dx, dy;
    RECT        rc;

    *pLRes=0;

    if (WM_SIZE==iMsg)
        {
        //Don't effect the Polyline size to or from minimized state.
        if (SIZE_MINIMIZED!=wParam && SIZE_MINIMIZED !=m_uPrevSize)
            {
            //When we change size, resize any Polyline we hold.
            dx=LOWORD(lParam);
            dy=HIWORD(lParam);

            /*
             * If we are getting WM_SIZE in response to a Polyline
             * notification, then don't resize the Polyline window
             * again.
             */
            if (!m_fNoSize && NULL!=m_pPL)
                {
                //Resize the polyline to fit the new client
                SetRect(&rc, 8, 8, dx-8, dy-8);
                m_pPL->RectSet(&rc, FALSE);

                /*
                 * We consider sizing something that makes the file
                 * dirty, but not until we've finished the create
                 * process, which is why we set fNoDirty to FALSE
                 * in WM_CREATE since we get a WM_SIZE on the first
                 * creation.
                 */
                if (!m_fNoDirty)
                    FDirtySet(TRUE);

                SetRect(&rc, 0, 0, dx, dy);

                if (NULL!=m_pAdv)
                    m_pAdv->OnSizeChange(this, &rc);

                m_fNoDirty=FALSE;
                }
            }

        m_uPrevSize=wParam;
        }

    //CHAPTER13MOD
    if (WM_LBUTTONDOWN==iMsg)
        {
        LPDROPSOURCE    pIDropSource;
        LPDATAOBJECT    pIDataObject;
        HRESULT         hr;
        SCODE           sc;
        DWORD           dwEffect;

        /*
         * The document has an 8 pixel border around the polyline
         * window where we'll see mouse clicks.  A left mouse button
         * click here means the start of a drag-drop operation.
         *
         * Since this is a modal operation, this IDropSource
         * is entirely local.
         */

        pIDropSource=new CDropSource(this);

        if (NULL==pIDropSource)
            return FALSE;

        pIDropSource->AddRef();
        m_fDragSource=TRUE;

        //Go get the data and start the ball rolling.
        pIDataObject=TransferObjectCreate(FALSE);

        if (NULL!=pIDataObject)
            {
            hr=DoDragDrop(pIDataObject, pIDropSource
                , DROPEFFECT_COPY | DROPEFFECT_MOVE, &dwEffect);

            pIDataObject->Release();
            sc=GetScode(hr);
            }
        else
            sc=E_FAIL;

        /*
         * When we return from DoDragDrop, either cancel or drop.
         * First toss the IDropSource we have here, then bail out
         * on cancel, and possibly clear our data on a move drop.
         */

        pIDropSource->Release();

        /*
         * If dropped on the same document (determined using
         * this flag, then dwEffect will be DROPEFFECT_NONE (see
         * IDropTarget::Drop in DROPTGT.CPP).  In any case,
         * reset this since the operation is done.
         */

        m_fDragSource=FALSE;

        if (DRAGDROP_S_DROP==sc && DROPEFFECT_MOVE==dwEffect)
            {
            m_pPL->New();
            FDirtySet(TRUE);
            }

        //On a canceled drop or a copy we don't do anything else
        return TRUE;
        }

    if (WM_DESTROY==iMsg)
        {
        /*
         * We have to revoke the drop target here because the window
         * will be destroyed and the property forcefully removed
         * before we could do this in the destructor.
         */
        if (NULL!=m_pDropTarget)
            {
            RevokeDragDrop(m_hWnd);
            CoLockObjectExternal(m_pDropTarget, FALSE, TRUE);
            ReleaseInterface(m_pDropTarget);
            }

        return FALSE;
        }

    //End CHAPTER13MOD

    /*
     * We return FALSE even on WM_SIZE so we can let the default
     * procedure handle maximized MDI child windows appropriately.
     */
    return FALSE;
    }








/*
 * CCosmoDoc::Clear
 *
 * Purpose:
 *  Sets all contents in the document back to defaults with
 *  no filename.
 *
 * Paramters:
 *  None
 *
 * Return Value:
 *  None
 */

void CCosmoDoc::Clear(void)
    {
    //Completely reset the polyline
    m_pPL->New();

    CDocument::Clear();
    m_lVer=0;
    return;
    }






/*
 * CCosmoDoc::Load
 *
 * Purpose:
 *  Loads a given document without any user interface overwriting
 *  the previous contents of the Polyline window.  We do this by
 *  opening the file and telling the Polyline to load itself from
 *  that file.
 *
 * Parameters:
 *  fChangeFile     BOOL indicating if we're to update the window
 *                  title and the filename from using this file.
 *  pszFile         LPTSTR to the filename to load, NULL if the file
 *                  is new and untitled.
 *
 * Return Value:
 *  UINT            An error value from DOCERR_*
 */

UINT CCosmoDoc::Load(BOOL fChangeFile, LPTSTR pszFile)
    {
    HRESULT         hr;
    LPSTORAGE       pIStorage;

    if (NULL==pszFile)
        {
        //For a new untitled document, just rename ourselves.
        Rename(NULL);
        m_lVer=VERSIONCURRENT;
        return DOCERR_NONE;
        }

    /*
     * If not a Compound File, open the file using STGM_CONVERT in
     * transacted mode to see old files as a storage with one stream
     * called "CONTENTS" (which is conveniently the name we use
     * in the new files).  We must use STGM_TRANSACTED here or else
     * the old file will be immediately converted on disk:  we only
     * want a converted image in memory from which to read.  In
     * addition, note that we need STGM_READWRITE as well since
     * conversion is inherently a write operation.
     */

    pIStorage=NULL;

    if (NOERROR!=StgIsStorageFile(pszFile))
        {
        hr=StgCreateDocfile(pszFile,STGM_TRANSACTED | STGM_READWRITE
            | STGM_CONVERT | STGM_SHARE_EXCLUSIVE, 0, &pIStorage);

        if (FAILED(hr))
            {
            //If denied write access, try to load the old way
            if (STG_E_ACCESSDENIED==GetScode(hr))
                m_lVer=m_pPL->ReadFromFile(pszFile);
            else
                return DOCERR_COULDNOTOPEN;
            }
        }
    else
        {
        hr=StgOpenStorage(pszFile, NULL, STGM_DIRECT | STGM_READ
            | STGM_SHARE_EXCLUSIVE, NULL, 0, &pIStorage);

        if (FAILED(hr))
            return DOCERR_COULDNOTOPEN;
        }

    if (NULL!=pIStorage)
        {
        m_lVer=m_pPL->ReadFromStorage(pIStorage);
        pIStorage->Release();
        }

    if (POLYLINE_E_READFAILURE==m_lVer)
        return DOCERR_READFAILURE;

    if (POLYLINE_E_UNSUPPORTEDVERSION==m_lVer)
        return DOCERR_UNSUPPORTEDVERSION;

    if (fChangeFile)
        Rename(pszFile);

    //Importing a file makes things dirty
    FDirtySet(!fChangeFile);

    return DOCERR_NONE;
    }







/*
 * CCosmoDoc::Save
 *
 * Purpose:
 *  Writes the file to a known filename, requiring that the user has
 *  previously used FileOpen or FileSaveAs to provide a filename.
 *
 * Parameters:
 *  uType           UINT indicating the type of file the user
 *                  requested to save in the File Save As dialog.
 *  pszFile         LPTSTR under which to save.  If NULL, use the
 *                  current name.
 *
 * Return Value:
 *  UINT            An error value from DOCERR_*
 */

UINT CCosmoDoc::Save(UINT uType, LPTSTR pszFile)
    {
    LONG        lVer, lRet;
    UINT        uTemp;
    BOOL        fRename=TRUE;
    HRESULT     hr;
    LPSTORAGE   pIStorage;

    if (NULL==pszFile)
        {
        fRename=FALSE;
        pszFile=m_szFile;
        }

    /*
     * Type 1 is the current version, type 2 is version 1.0 of the
     * Polyline so we use this to send the right version to
     * CPolyline::WriteToFile/WriteToStorage.
     */

    switch (uType)
        {
        case 0:         //From Save, use loaded version.
            lVer=m_lVer;
            break;

        case 1:
            lVer=VERSIONCURRENT;
            break;

        case 2:
            lVer=MAKELONG(0, 1);    //1.0
            break;

        default:
            return DOCERR_UNSUPPORTEDVERSION;
        }

    /*
     * If the version the user wants to save is different from the
     * version that we loaded and m_lVer is not zero (new doc),
     * then inform the user of the version change and verify.
     */
    if (0!=m_lVer && m_lVer!=lVer)
        {
        TCHAR       szMsg[128];

        wsprintf(szMsg, PSZ(IDS_VERSIONCHANGE)
            , (UINT)HIWORD(m_lVer), (UINT)LOWORD(m_lVer)
            , (UINT)HIWORD(lVer), (UINT)LOWORD(lVer));

        uTemp=MessageBox(m_hWnd, szMsg, PSZ(IDS_DOCUMENTCAPTION)
            , MB_YESNOCANCEL);

        if (IDCANCEL==uTemp)
            return DOCERR_CANCELLED;

        //If the user won't upgrade, revert to loaded version.
        if (IDNO==uTemp)
            lVer=m_lVer;
        }

    /*
     * For 1.0 files, still use the old code.  For new files, use
     * storages instead
     */
    if (lVer==MAKELONG(0, 1))
        lRet=m_pPL->WriteToFile(pszFile, lVer);
    else
        {
        hr=StgCreateDocfile(pszFile, STGM_DIRECT | STGM_READWRITE
            | STGM_CREATE | STGM_SHARE_EXCLUSIVE, 0, &pIStorage);

        if (FAILED(hr))
            return DOCERR_COULDNOTOPEN;

        //Mark this as one of our class
        WriteClassStg(pIStorage, CLSID_CosmoFigure);

        //Write user-readable class information
        WriteFmtUserTypeStg(pIStorage, m_cf
            , PSZ(IDS_CLIPBOARDFORMAT));

        lRet=m_pPL->WriteToStorage(pIStorage, lVer);
        pIStorage->Release();
        }

    if (POLYLINE_E_NONE!=lRet)
        return DOCERR_WRITEFAILURE;

    //Saving makes us clean
    FDirtySet(FALSE);

    //Update the known version of this document.
    m_lVer=lVer;

    if (fRename)
        Rename(pszFile);

    return DOCERR_NONE;
    }






/*
 * CCosmoDoc::Undo
 *
 * Purpose:
 *  Reverses a previous action.
 *
 * Parameters:
 *  None
 *
 * Return Value:
 *  None
 */

void CCosmoDoc::Undo(void)
    {
    m_pPL->Undo();
    return;
    }






/*
 * CCosmoDoc::Clip
 *
 * Purpose:
 *  Places a private format, a metafile, and a bitmap of the display
 *  on the clipboard, optionally implementing Cut by deleting the
 *  data in the current window after rendering.
 *
 * Parameters:
 *  hWndFrame       HWND of the main window.
 *  fCut            BOOL indicating cut (TRUE) or copy (FALSE).
 *
 * Return Value:
 *  BOOL            TRUE if successful, FALSE otherwise.
 */

BOOL CCosmoDoc::Clip(HWND hWndFrame, BOOL fCut)
    {
    //CHAPTER13MOD
    BOOL            fRet=TRUE;
    LPDATAOBJECT    pIDataObject;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
88在线观看91蜜桃国自产| 另类成人小视频在线| 精品1区2区3区| 国产一区二区三区免费播放| 一区二区三区在线免费播放| 日韩视频在线你懂得| 在线亚洲人成电影网站色www| 国产老肥熟一区二区三区| 一区二区三区在线看| 国产三级精品视频| 欧美xxxxxxxxx| 欧美日韩国产在线播放网站| 91亚洲精华国产精华精华液| 国产一区二区在线观看免费| 亚洲成人一区二区| 亚洲欧美日韩国产手机在线| 国产日韩欧美在线一区| 精品88久久久久88久久久| 在线成人小视频| 精品嫩草影院久久| 国产成人免费网站| 亚洲v中文字幕| 亚洲欧美在线观看| 久久亚洲精精品中文字幕早川悠里| 欧美亚一区二区| 99re在线精品| 波多野洁衣一区| 国产美女在线精品| 久久99久久99| 日韩国产一二三区| 午夜一区二区三区在线观看| 国产精品国产自产拍在线| 亚洲国产精品高清| 国产三级精品三级在线专区| 国产亚洲一区二区三区在线观看 | 99re这里只有精品视频首页| 久久99精品久久久久久国产越南 | 国产精品99久久久久| 精品久久久久久久一区二区蜜臀| 337p亚洲精品色噜噜狠狠| 欧美日韩亚洲丝袜制服| 欧美日韩国产经典色站一区二区三区| 欧洲一区二区三区在线| 欧美日韩视频不卡| 欧美一区二区三区电影| 日韩一级二级三级精品视频| 精品蜜桃在线看| 精品99999| 国产精品毛片久久久久久| 国产精品久久久久久亚洲伦 | 亚洲乱码国产乱码精品精可以看| 亚洲人成精品久久久久| 一区二区三区毛片| 污片在线观看一区二区| 麻豆成人久久精品二区三区小说| 国产精品中文字幕一区二区三区| 粉嫩绯色av一区二区在线观看| thepron国产精品| 色婷婷精品久久二区二区蜜臀av| 欧美日韩mp4| 久久久噜噜噜久噜久久综合| 亚洲欧洲美洲综合色网| 亚洲福利视频一区二区| 美国毛片一区二区三区| 成人中文字幕合集| 欧美午夜在线一二页| 欧美一区二区三区不卡| 在线成人av影院| 欧美剧情电影在线观看完整版免费励志电影 | 亚洲在线视频免费观看| 日韩精品三区四区| 国产成人综合亚洲网站| 国产成人午夜视频| 日本大香伊一区二区三区| 粉嫩av一区二区三区| 欧美日韩精品一区视频| 精品国产123| 久久日一线二线三线suv| 久久久久久黄色| 99久久精品国产一区二区三区| 久久久久久久电影| 欧美极品另类videosde| 亚洲精选免费视频| 天天色 色综合| 国产精品亚洲第一| 欧日韩精品视频| 一本一本大道香蕉久在线精品| 欧美挠脚心视频网站| 精品日韩欧美一区二区| 国产精品国产精品国产专区不蜜 | 国内精品嫩模私拍在线| 国产精品自产自拍| 成人不卡免费av| 91精品国产91久久久久久最新毛片| 久久综合九色欧美综合狠狠| 成人欧美一区二区三区小说| 亚洲国产一区二区a毛片| 精品一区二区综合| 色噜噜狠狠一区二区三区果冻| 日韩欧美亚洲国产另类| 国产区在线观看成人精品 | 毛片av中文字幕一区二区| 国产一区二区三区视频在线播放| www.色精品| 亚洲国产激情av| 亚洲成av人片一区二区| 激情六月婷婷久久| 精品视频1区2区| 国产精品日日摸夜夜摸av| 天天操天天综合网| 北条麻妃一区二区三区| 日韩免费在线观看| 国产精品亚洲一区二区三区在线 | 毛片av一区二区三区| 国产不卡视频在线播放| 欧美精品一二三区| 国产精品久久精品日日| 蜜臀av性久久久久蜜臀aⅴ四虎| 99国产精品久| 国产欧美中文在线| 亚洲福利视频一区| 欧美三级视频在线观看| 中文字幕亚洲欧美在线不卡| 国内精品伊人久久久久影院对白| 欧美色中文字幕| 亚洲欧美在线高清| 国产精品69毛片高清亚洲| 日韩一区二区三区免费观看| 亚洲妇女屁股眼交7| 色综合天天综合网国产成人综合天 | 亚洲成人777| 色综合久久久网| 国产精品久久二区二区| 国产成人av电影在线观看| 日韩午夜激情电影| 亚洲成人资源网| 欧美精品电影在线播放| 亚洲日本青草视频在线怡红院| 国产精品一二二区| 久久久精品国产免大香伊| 精品一区二区免费在线观看| 日韩一区二区三区精品视频| 亚洲va欧美va人人爽午夜 | 99精品桃花视频在线观看| 国产欧美日韩在线看| 成人性色生活片| 国产精品热久久久久夜色精品三区| 国产盗摄视频一区二区三区| 久久青草国产手机看片福利盒子 | 国产成a人亚洲精品| wwww国产精品欧美| 亚洲福利视频导航| 亚洲精品在线观| 国产乱人伦偷精品视频不卡| 久久九九久久九九| 国产精品91xxx| 中文字幕在线观看一区| 国产高清不卡一区| 一区二区三区中文在线| 91久久国产最好的精华液| 亚洲第一电影网| 欧美高清视频在线高清观看mv色露露十八| 亚洲小说春色综合另类电影| 欧美视频第二页| 天堂成人国产精品一区| 91.com视频| 同产精品九九九| 日韩一区二区三区免费观看| 精品一区二区av| 亚洲精品乱码久久久久久日本蜜臀| 在线观看网站黄不卡| 五月激情综合色| 精品国产区一区| 粉嫩欧美一区二区三区高清影视| 国产精品久久三| eeuss国产一区二区三区| 五月婷婷久久丁香| 精品va天堂亚洲国产| 成人黄色一级视频| 亚洲综合激情小说| 日韩一区二区精品在线观看| 国精产品一区一区三区mba视频 | 综合色天天鬼久久鬼色| 日本韩国欧美一区二区三区| 另类中文字幕网| 国产精品免费看片| 欧美视频三区在线播放| 狠狠色丁香久久婷婷综| 国产精品二三区| 菠萝蜜视频在线观看一区| 日韩成人一级大片| 国产日韩精品视频一区| 欧美伊人精品成人久久综合97| 久久丁香综合五月国产三级网站| 国产精品久线观看视频| 欧美日韩国产一区| 成人app软件下载大全免费| 丝袜美腿亚洲综合| 国产精品每日更新在线播放网址| 在线不卡中文字幕|