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

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

?? print.cpp

?? 英文版的 想要的話可以下載了 為大家服務(wù)
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*
 * PRINT.CPP
 * Patron Chapter 22
 *
 * Implementation of printing functions for both CPatronDoc
 * and CPages classes.  These functions are here to keep clutter
 * down in document.cpp and pages.cpp.
 *
 * Copyright (c)1993-1995 Microsoft Corporation, All Rights Reserved
 *
 * Kraig Brockschmidt, Microsoft
 * Internet  :  kraigb@microsoft.com
 * Compuserve:  >INTERNET:kraigb@microsoft.com
 */

#include "patron.h"

static HWND g_hDlgPrint=NULL;
static BOOL g_fCancelPrint=FALSE;


/*
 * CPatronDoc::Print
 *
 * Purpose:
 *  Prints the current document.
 *
 * Parameters:
 *  hWndFrame       HWND of the frame to use for dialog parents.
 *
 * Return Value:
 *  BOOL            TRUE if printing happened, FALSE if it didn't
 *                  start or didn't complete.
 */

BOOL CPatronDoc::Print(HWND hWndFrame)
    {
    PRINTDLG        pd;
    BOOL            fSuccess;

    memset(&pd, 0, sizeof(PRINTDLG));
    pd.lStructSize=sizeof(PRINTDLG);
    pd.hwndOwner  =hWndFrame;
    pd.nCopies    =1;
    pd.nFromPage  =(USHORT)-1;
    pd.nToPage    =(USHORT)-1;
    pd.nMinPage   =1;
    pd.nMaxPage   =m_pPG->NumPagesGet();

    pd.lpfnPrintHook=PrintDlgHook;

    //Get the current document printer settings
    pd.hDevMode=m_pPG->DevModeGet();

    pd.Flags=PD_RETURNDC | PD_ALLPAGES | PD_COLLATE
        | PD_HIDEPRINTTOFILE | PD_NOSELECTION | PD_ENABLEPRINTHOOK;

    if (!PrintDlg(&pd))
        return FALSE;

    if (NULL!=pd.hDevMode)
        GlobalFree(pd.hDevMode);

    if (NULL!=pd.hDevNames)
        GlobalFree(pd.hDevNames);

    //Go do the actual printing.
    fSuccess=m_pPG->Print(pd.hDC, PSZ(IDS_DOCUMENTNAME), pd.Flags
        , pd.nFromPage, pd.nToPage, pd.nCopies);

    if (!fSuccess)
        {
        MessageBox(m_hWnd, PSZ(IDS_PRINTERROR)
            , PSZ(IDS_DOCUMENTCAPTION), MB_OK);
        }

    return fSuccess;
    }






/*
 * CPatronDoc::PrinterSetup
 *
 * Purpose:
 *  Selects a new printer and options for this document.
 *
 * Parameters:
 *  hWndFrame       HWND of the frame to use for dialog parents.
 *  fDefault        BOOL to avoid any dialog and just use the
 *                  default.
 *
 * Return Value:
 *  UINT            Undefined
 */

UINT CPatronDoc::PrinterSetup(HWND hWndFrame, BOOL fDefault)
    {
    PRINTDLG        pd;

    //Attempt to get printer metrics for the default printer.
    memset(&pd, 0, sizeof(PRINTDLG));
    pd.lStructSize=sizeof(PRINTDLG);

    if (fDefault)
        pd.Flags=PD_RETURNDEFAULT;
    else
        {
        pd.hwndOwner=hWndFrame;
        pd.Flags=PD_PRINTSETUP;

        //Get the current document printer settings
        pd.hDevMode=m_pPG->DevModeGet();
        }

    if (!PrintDlg(&pd))
        return FALSE;

    if (!m_pPG->DevModeSet(pd.hDevMode, pd.hDevNames))
        {
        GlobalFree(pd.hDevNames);
        GlobalFree(pd.hDevMode);
        return FALSE;
        }

    FDirtySet(TRUE);
    return 1;
    }



/*
 * PrintDlgHook
 *
 * Purpose:
 *  Callback hook for the Print Dialog so we can hide the Setup
 *  button.  Patron only allows Setup before anything exists on
 *  the page, and is not written to handle setup at Print time.
 */

UINT CALLBACK PrintDlgHook(HWND hDlg, UINT iMsg, WPARAM wParam
    , LPARAM lParam)
    {
    if (WM_INITDIALOG==iMsg)
        {
        HWND        hWnd;

        hWnd=GetDlgItem(hDlg, psh1);
        ShowWindow(hWnd, SW_HIDE);
        return TRUE;
        }

    return FALSE;
    }




/*
 * CPatronDoc::FQueryPrinterSetup
 *
 * Purpose:
 *  Returns whether or not the Printer Setup menu item can be
 *  enabled.  Once you create a tenant in any page, Printer Setup
 *  is voided simply to keep this sample simple, that is, we don't
 *  have to worry about reorganizing potentially large amounts
 *  of layout after we start plopping down objects.
 *
 * Parameters:
 *  None
 *
 * Return Value:
 *  BOOL            TRUE to enable the menu, FALSE otherwise.
 */

BOOL CPatronDoc::FQueryPrinterSetup(void)
    {
    return m_fPrintSetup;
    }




/*
 * CPages::DevModeSet
 *
 * Purpose:
 *  Provides the Pages with the current printer information.
 *
 * Parameters:
 *  hDevMode        HGLOBAL to the memory containing the DEVMODE.
 *                  This function assumes responsibility for this
 *                  handle.
 *  hDevNames       HGLOBAL providing the driver name and device
 *                  name from which we can create a DC for
 *                  information.
 *
 * Return Value:
 *  BOOL            TRUE if we could accept this configuration,
 *                  FALSE otherwise.  If we return TRUE we also
 *                  delete the old memory we hold.
 */

BOOL CPages::DevModeSet(HGLOBAL hDevMode, HGLOBAL hDevNames)
    {
    LPDEVNAMES      pdn;
    LPTSTR          psz;
    HGLOBAL         hMem;
    PDEVICECONFIG   pdc;
    LPDEVMODE       pdm;
    LPSTREAM        pIStream;
    HRESULT         hr;
    ULONG           cbDevMode, cbWrite;
    BOOL            fRet=FALSE;

    if (NULL==hDevMode || NULL==hDevNames)
        return FALSE;

    hr=m_pIStorage->OpenStream(SZSTREAMDEVICECONFIG, 0, STGM_DIRECT
        | STGM_WRITE | STGM_SHARE_EXCLUSIVE, 0, &pIStream);

    if (FAILED(hr))
        return FALSE;

    /*
     * DEVMODE is variable length--total length in hDevMode, so the
     * amount to write is that plus string space.  We subtract
     * sizeof(DEVMODE) as that is already included from GlobalSize.
     */
    cbDevMode=GlobalSize(hDevMode);
    cbWrite=cbDevMode+sizeof(DEVICECONFIG)-sizeof(DEVMODE);

    hMem=GlobalAlloc(GHND, cbWrite);

    if (NULL==hMem)
        {
        pIStream->Release();
        return FALSE;
        }

    pdc=(PDEVICECONFIG)GlobalLock(hMem);    //This always works
    pdm=(LPDEVMODE)GlobalLock(hDevMode);    //This might not

    if (NULL!=pdm)
        {
        pdc->cb=cbWrite;
        pdc->cbDevMode=cbDevMode;
        memcpy(&pdc->dm, pdm, (int)cbDevMode);
        GlobalUnlock(hDevMode);

        psz=(LPTSTR)GlobalLock(hDevNames);

        if (NULL!=psz)
            {
            pdn=(LPDEVNAMES)psz;
            lstrcpy(pdc->szDriver, psz+pdn->wDriverOffset);
            lstrcpy(pdc->szDevice, psz+pdn->wDeviceOffset);
            lstrcpy(pdc->szPort,   psz+pdn->wOutputOffset);

            pIStream->Write(pdc, cbWrite, &cbWrite);
            GlobalUnlock(hDevNames);
            fRet=TRUE;
            }
        }

    GlobalUnlock(hMem);
    GlobalFree(hMem);

    pIStream->Release();

    if (!fRet)
        return FALSE;

    GlobalFree(hDevNames);
    GlobalFree(hDevMode);

    return ConfigureForDevice();
    }




/*
 * CPages::DevModeGet
 *
 * Purpose:
 *  Retrieves a copy of the current DEVMODE structure for this
 *  Pages window.  The caller is responsible for this memory.
 *
 * Parameters:
 *  None
 *
 * Return Value:
 *  HGLOBAL         Handle to the memory containing the DEVMODE
 *                  structure.
 */

HGLOBAL CPages::DevModeGet(void)
    {
    HGLOBAL         hMem;
    LPVOID          pv;
    ULONG           cbDevMode, cbRead;
    LARGE_INTEGER   li;
    LPSTREAM        pIStream;
    HRESULT         hr;

    hr=m_pIStorage->OpenStream(SZSTREAMDEVICECONFIG, 0, STGM_DIRECT
        | STGM_READ | STGM_SHARE_EXCLUSIVE, 0, &pIStream);

    if (FAILED(hr))
        return FALSE;

    //Read how much to allocate for the DEVMODE structure
    LISet32(li, CBSEEKOFFSETCBDEVMODE);
    pIStream->Seek(li, STREAM_SEEK_SET, NULL);
    pIStream->Read(&cbDevMode, sizeof(ULONG), &cbRead);

    hMem=GlobalAlloc(GHND, cbDevMode);

    if (NULL!=hMem)
        {
        pv=(LPVOID)GlobalLock(hMem);
        pIStream->Read(pv, cbDevMode, &cbRead);
        GlobalUnlock(hMem);
        }

    pIStream->Release();
    return hMem;
    }







/*
 * CPages::DevReadConfig
 *
 * Purpose:
 *  Public function to read the current device configuration and
 *  optionally return an information context for it.
 *
 *
 * Parameters:
 *  ppcd            PCOMBINEDEVICE * in which to return a pointer
 *                  to an allocated structure that has all the
 *                  device information we want.  Ignored if NULL.
 *                  This is allocated with the task allocator.
 *  phDC            HDC * in which to return the information
 *                  context.  If NULL, no IC is created.  Caller
 *                  becomes responsible for the returned IC.
 *
 * Return Value:
 *  BOOL            TRUE if successful, FALSE otherwise.
 */

BOOL CPages::DevReadConfig(PCOMBINEDEVICE *ppcd, HDC *phDC)
    {
    HRESULT         hr;
    LPSTREAM        pIStream;
    LPMALLOC        pIMalloc;
    PCOMBINEDEVICE  pcd;
    ULONG           cb, cbRead;
    LARGE_INTEGER   li;

    hr=m_pIStorage->OpenStream(SZSTREAMDEVICECONFIG, 0, STGM_DIRECT
        | STGM_READ | STGM_SHARE_EXCLUSIVE, 0, &pIStream);

    if (FAILED(hr))
        return FALSE;

    /*
     * Allocate the COMBINEDEVICE structure including the variable
     * information past the DEVMODE part.
     */

    hr=CoGetMalloc(MEMCTX_TASK, &pIMalloc);

    if (FAILED(hr))
        {
        pIStream->Release();
        return FALSE;
        }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
天天色天天操综合| 国产精品久久毛片a| 日日欢夜夜爽一区| 欧美日韩二区三区| 美美哒免费高清在线观看视频一区二区 | 精品黑人一区二区三区久久| 男人操女人的视频在线观看欧美| 91精品国产黑色紧身裤美女| 国内一区二区在线| 欧美国产精品久久| 色综合天天视频在线观看 | 欧美日韩成人激情| 免费观看一级特黄欧美大片| 久久久影院官网| 91天堂素人约啪| 日韩精品久久理论片| 久久久久一区二区三区四区| 99国内精品久久| 亚洲午夜久久久久中文字幕久| 欧美高清视频一二三区| 国产美女久久久久| 亚洲免费观看高清完整版在线观看 | 国产精品污网站| 在线一区二区三区做爰视频网站| 午夜伊人狠狠久久| 国产欧美精品一区二区色综合朱莉| eeuss鲁片一区二区三区在线看| 艳妇臀荡乳欲伦亚洲一区| 日韩丝袜美女视频| av不卡免费在线观看| 天天色图综合网| 国产精品毛片高清在线完整版 | av高清久久久| 日韩成人免费电影| 《视频一区视频二区| 正在播放亚洲一区| 成人动漫在线一区| 麻豆精品精品国产自在97香蕉 | 精品成人一区二区| 欧美中文字幕一区二区三区 | 日本不卡免费在线视频| 国产精品家庭影院| 精品免费国产一区二区三区四区| 色就色 综合激情| 国产精品996| 日本欧美在线看| 亚洲欧洲中文日韩久久av乱码| 日韩欧美国产综合一区 | 日韩欧美一级二级| 欧美网站一区二区| 99re热视频精品| 精品一区二区三区在线播放| 亚洲国产精品精华液网站| 国产精品欧美极品| 精品久久人人做人人爰| 在线不卡免费av| 色妞www精品视频| 粉嫩在线一区二区三区视频| 卡一卡二国产精品| 亚洲18女电影在线观看| 亚洲综合一区在线| 亚洲日本va午夜在线影院| 日本一区二区高清| 国产视频一区二区在线观看| 久久综合国产精品| 日韩精品一区二区三区中文精品| 欧美日韩免费不卡视频一区二区三区| 成人精品视频一区| 午夜电影网一区| 国产精品福利一区| 亚洲欧美另类图片小说| 国产精品免费看片| 欧美国产一区视频在线观看| 久久青草国产手机看片福利盒子| 日韩精品综合一本久道在线视频| 欧美精品在线一区二区三区| 欧美日韩免费不卡视频一区二区三区| 91国产免费观看| 91国产精品成人| 欧美精品九九99久久| 欧美精品丝袜中出| 日韩一区二区精品在线观看| 日韩免费观看高清完整版| 日韩一级免费一区| 日韩久久久精品| 欧美激情一区三区| 亚洲视频网在线直播| 亚洲三级在线免费观看| 亚洲愉拍自拍另类高清精品| 亚洲一区二区三区精品在线| 亚洲国产综合人成综合网站| 日韩中文字幕麻豆| 国内精品写真在线观看| 国产91丝袜在线观看| 97se亚洲国产综合自在线观| 色网站国产精品| 7777精品伊人久久久大香线蕉完整版| 日韩一区二区免费高清| 久久久.com| 一区二区三区四区视频精品免费| 亚洲1区2区3区4区| 国产中文一区二区三区| 成人av网站在线观看免费| 在线观看日韩国产| 欧美一区二区三区人| 久久久噜噜噜久久人人看 | 欧美日韩一级片在线观看| 日韩一级在线观看| 中文字幕一区二区三区视频 | 国产精品欧美综合在线| 亚洲高清在线精品| 韩国精品一区二区| 91美女视频网站| 日韩免费视频一区二区| 国产精品久久久久影视| 日日噜噜夜夜狠狠视频欧美人| 国产黄人亚洲片| 欧美日韩精品二区第二页| 国产三级精品在线| 午夜精品国产更新| 顶级嫩模精品视频在线看| 欧美电影影音先锋| 国产精品久久久久久久久免费樱桃| 天堂蜜桃一区二区三区| 99久精品国产| 欧美va亚洲va在线观看蝴蝶网| 亚洲欧美国产毛片在线| 精品夜夜嗨av一区二区三区| 欧美亚洲国产一区在线观看网站| 精品999久久久| 午夜精品福利久久久| 成人福利在线看| 2023国产精品自拍| 婷婷久久综合九色综合伊人色| 国产成人免费xxxxxxxx| 欧美一区二区三区四区在线观看| 日韩一区有码在线| 国产一区二区0| 日韩亚洲电影在线| 午夜婷婷国产麻豆精品| 色欧美片视频在线观看在线视频| 久久精品视频一区| 激情文学综合插| 欧美一区二区精品在线| 亚洲成人免费在线观看| 91网站在线播放| 国产精品国产三级国产| 国产精品小仙女| 精品国产乱码久久久久久夜甘婷婷 | 国产精品无圣光一区二区| 国产综合色产在线精品| 欧美日韩精品一二三区| 亚洲精品老司机| 成人开心网精品视频| 国产欧美日韩卡一| 国产福利一区二区三区| 精品久久久久久久人人人人传媒| 美女网站一区二区| 在线综合亚洲欧美在线视频 | 日韩在线播放一区二区| 色呦呦网站一区| 一区二区三区四区在线| 色狠狠桃花综合| 亚洲精品自拍动漫在线| 91久久精品一区二区三区| 亚洲精品免费一二三区| 欧美午夜精品一区二区三区| 亚洲精品国久久99热| 色哟哟亚洲精品| 亚洲韩国精品一区| 51精品国自产在线| 精品一区二区免费看| wwwwww.欧美系列| 成人在线综合网站| 日韩一区有码在线| 欧美亚洲免费在线一区| 日韩不卡一二三区| 精品免费日韩av| 国产69精品一区二区亚洲孕妇| 国产精品伦理一区二区| 91麻豆福利精品推荐| 亚洲午夜国产一区99re久久| 欧美精品 日韩| 国产美女在线观看一区| 亚洲国产精品99久久久久久久久 | 99久久精品免费精品国产| 亚洲色图色小说| 欧美亚洲日本国产| 日本sm残虐另类| 国产日韩欧美精品综合| 91小视频免费观看| 亚洲成人1区2区| 亚洲精品在线电影| 99久久久国产精品免费蜜臀| 亚洲一级二级三级在线免费观看| 69堂成人精品免费视频| 国产乱人伦偷精品视频不卡| 亚洲视频一区二区在线观看| 日韩欧美激情在线| 99在线精品免费|