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

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

?? print.cpp

?? 英文版的 想要的話可以下載了 為大家服務
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*
 * PRINT.CPP
 * Patron Chapter 12
 *
 * 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;
    }




//CHAPTER12MOD
/*
 * 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;
    }
//End CHAPTER12MOD




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







//CHAPTER12MOD
/*
 * 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一区二区三区免费野_久草精品视频
91精品国产色综合久久久蜜香臀| 欧美亚男人的天堂| 成人av资源在线| 精品免费国产一区二区三区四区| 亚洲欧美一区二区三区极速播放| 天天射综合影视| 色综合夜色一区| 国产日韩欧美制服另类| 麻豆91免费观看| 欧美色图在线观看| 中文字幕在线观看一区| 加勒比av一区二区| 欧美另类一区二区三区| 亚洲黄色小说网站| 99九九99九九九视频精品| 久久精品一二三| 国产一区二区在线电影| 在线91免费看| 亚洲精品国产精华液| 99久久伊人精品| 亚洲欧美激情小说另类| 91亚洲永久精品| 一区二区三区日韩精品视频| 欧美精品电影在线播放| 国产在线精品一区二区三区不卡| 国产黄色精品网站| 久久久久久久电影| 国产乱淫av一区二区三区 | 一区二区三区在线视频观看| 风流少妇一区二区| 日本一区二区三区在线不卡| 国产精品888| 国产欧美一区二区在线| 国产精品2024| 欧美极品aⅴ影院| 成人福利电影精品一区二区在线观看| 国产亚洲欧美中文| 成人精品视频一区二区三区| 国产精品视频九色porn| av网站一区二区三区| 中文字幕在线观看一区二区| 成人网在线播放| 亚洲另类在线视频| 欧美群妇大交群中文字幕| 日本中文字幕不卡| 精品美女一区二区| 成人黄色小视频在线观看| 亚洲欧美综合色| 欧美日韩在线电影| 久久国产精品无码网站| 国产女同性恋一区二区| 国产盗摄视频一区二区三区| 最新中文字幕一区二区三区| 欧美色大人视频| 精久久久久久久久久久| 国产精品美女久久久久久久久久久| 97久久精品人人爽人人爽蜜臀| 一区二区三区日本| 欧美一级专区免费大片| 成人免费毛片嘿嘿连载视频| 亚洲免费在线观看视频| 日韩免费视频一区| 91亚洲精品久久久蜜桃| 日本va欧美va欧美va精品| 国产视频不卡一区| 欧美国产97人人爽人人喊| 久久99久久精品| 亚洲欧洲日产国产综合网| 制服丝袜成人动漫| 播五月开心婷婷综合| 午夜国产不卡在线观看视频| 国产欧美一区二区在线| 欧美日韩成人一区| 成人av手机在线观看| 日韩国产欧美在线观看| 国产精品黄色在线观看| 91麻豆精品国产91久久久| youjizz国产精品| 免费成人av在线播放| 亚洲人成人一区二区在线观看| 欧美一区二区精品久久911| aaa国产一区| 韩国女主播一区二区三区| 亚洲成人先锋电影| 国产精品天美传媒沈樵| 日韩免费福利电影在线观看| 91久久精品一区二区二区| 丰满亚洲少妇av| 美女诱惑一区二区| 三级一区在线视频先锋 | 91在线视频18| 国产一区二区免费看| 国产精品视频一二三区| 自拍偷拍欧美激情| 99精品久久99久久久久| 国产在线视频一区二区三区| 亚洲一区二区三区在线| 国产精品久久久久久亚洲毛片 | 欧美人狂配大交3d怪物一区| 99热精品一区二区| 国产成人av福利| 久久99精品久久久久婷婷| 日韩av一级片| 日韩高清中文字幕一区| 亚洲国产精品久久不卡毛片| 亚洲欧美日韩中文字幕一区二区三区 | 美女脱光内衣内裤视频久久网站| 亚洲综合精品久久| 99精品欧美一区二区三区综合在线| 精品美女一区二区三区| 成人91在线观看| 久久精品99久久久| 极品少妇xxxx精品少妇| 青青草一区二区三区| 日韩av网站在线观看| 麻豆高清免费国产一区| 蜜桃视频在线观看一区二区| 日韩av电影免费观看高清完整版 | 日韩精品一区二区三区在线播放| 久久99精品一区二区三区| 国产精品网站在线| 欧美一级国产精品| 日韩午夜激情免费电影| 国产成人av电影在线观看| 不卡一卡二卡三乱码免费网站| 亚洲日本成人在线观看| 99久久99久久精品免费看蜜桃| 国产不卡视频一区二区三区| 欧美二区乱c少妇| 国产1区2区3区精品美女| 国产精品自拍一区| 成人网在线免费视频| 99久久精品国产麻豆演员表| 91啪亚洲精品| 欧美精品久久久久久久多人混战| 4438x亚洲最大成人网| 久久影院午夜片一区| 国产精品美女一区二区| 亚洲综合清纯丝袜自拍| 亚洲一区二区综合| 中文字幕在线不卡| 久久久久99精品国产片| 国产精品福利一区| 天堂蜜桃91精品| 国产成人精品免费| 欧美日韩一区二区三区在线看| 欧美日本精品一区二区三区| 精品久久一区二区三区| 国产精品视频看| 日韩国产欧美在线播放| 豆国产96在线|亚洲| 欧美日韩亚洲不卡| 国产视频911| 日韩在线一二三区| 成人a区在线观看| 欧美一级理论性理论a| 国产精品色哟哟| 青青青伊人色综合久久| 97精品国产露脸对白| 日韩欧美国产wwwww| 国产精品美女久久久久aⅴ| 午夜精品久久久久影视| 不卡的看片网站| 欧美本精品男人aⅴ天堂| 亚洲美女在线一区| 成人久久视频在线观看| 欧美日韩久久一区| 国产aⅴ精品一区二区三区色成熟| 精品国产伦一区二区三区观看方式| 久久 天天综合| 亚洲视频精选在线| 亚洲欧洲日韩av| 国产又黄又大久久| 欧美日韩你懂得| 亚洲日本在线天堂| 国产成人鲁色资源国产91色综| 欧美日韩一区高清| 亚洲欧美一区二区三区国产精品 | 国产精品538一区二区在线| 欧美精品日韩综合在线| 亚洲在线成人精品| eeuss鲁一区二区三区| 欧美大度的电影原声| 日日夜夜免费精品视频| 91高清视频在线| 亚洲视频免费观看| 不卡电影一区二区三区| 久久精品亚洲麻豆av一区二区| 男女男精品视频网| 日韩一区二区在线看片| 香港成人在线视频| 欧美日韩成人高清| 婷婷综合另类小说色区| 欧美另类一区二区三区| 午夜视频久久久久久| 91精品国产福利| 91精品国产综合久久精品麻豆| 亚洲精品乱码久久久久久久久| 成人免费毛片a| 中文字幕一区二区三区在线不卡|