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

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

?? polyline.cpp

?? 英文版的 想要的話可以下載了 為大家服務
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
 *  Ignorantly writes our current data into an opened file in a
 *  particular version.
 *
 * Parameters:
 *  pszFile         LPTSTR filename in which to store the data.
 *  lVer            LONG providing version number Major (HI)
 *                  and Minor (Low)
 *
 * Return Value:
 *  LONG            A POLYLINE_E_* value.
 */

LONG CPolyline::WriteToFile(LPTSTR pszFile, LONG lVer)
    {
    OFSTRUCT        of;
    HFILE           hFile;
    UINT            cb;
    UINT            cbExpect=0;
    WORD            wVerMaj=HIWORD(lVer);
    WORD            wVerMin=LOWORD(lVer);
    POLYLINEDATA    pl;

    if (NULL==pszFile)
        return POLYLINE_E_READFAILURE;

    //Get a copy of our data in the version we're going to save.
    DataGet(&pl, lVer);

    switch (wVerMaj)
        {
        case VERSIONMAJOR:  //2.x
            switch (wVerMin)
                {
                case VERSIONMINOR:  //2.0
                    cbExpect=CBPOLYLINEDATA;
                    break;

                default:
                    break;
                }
            break;

        case 1: //1.x
            switch (wVerMin)
                {
                case 0:  //1.0
                    cbExpect=CBPOLYLINEDATA10;
                    break;

                default:
                    break;
                }
            break;

        default:
            break;
        }

    if (0==cbExpect)
        return POLYLINE_E_UNSUPPORTEDVERSION;

    hFile=OpenFileW(pszFile, &of, OF_CREATE | OF_WRITE);

    if (HFILE_ERROR==hFile)
        return DOCERR_COULDNOTOPEN;

    cb=_lwrite(hFile, (LPCSTR)&pl, cbExpect);
    _lclose(hFile);

    return (cbExpect==cb) ? POLYLINE_E_NONE
        : POLYLINE_E_WRITEFAILURE;
    }






/*
 * CPolyline::OpenFileW (Private)
 *
 * Purpose:
 *  Under Win32, OpenFile does not take Unicode strings.  This
 *  function converts a Unicode string into an ANSI string and
 *  calls OpenFile.  This just maps to OpenFile without Unicode.
 *
 * Parameters, Return Value:
 *  Same as OpenFile.
 */

HFILE CPolyline::OpenFileW(LPTSTR pszFile, LPOFSTRUCT pof
    , UINT uFlags)
    {
   #ifdef UNICODE
    CHAR        szTemp[CCHPATHMAX];

    UNICODETOANSI(pszFile, szTemp, CCHPATHMAX);
    return OpenFile(szTemp, pof, uFlags);
   #else
    return OpenFile(pszFile, pof, uFlags);
   #endif
    }







/*
 * CPolyline::DataSet
 *
 * Purpose:
 *  Sets the current data in this Polyline to a given structure.
 *
 * Parameters:
 *  ppl             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:
 *  LONG            A POLYLINE_E_* value.
 */

LONG CPolyline::DataSet(PPOLYLINEDATA ppl, BOOL fSizeToData
    , BOOL fNotify)
    {
    RECTS       rcs;
    RECT        rc;
    UINT        i;

    /*
     * Copy the structure in ppl 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==ppl)
        return POLYLINE_E_INVALIDPOINTER;

    //Preserve the old rectangle
    rcs=m_pl.rc;

    /*
     * For version 2.0 we perform a straight copy.  For version
     * 1.0 we copy the 1.0 structure and fill in defaults for
     * the 2.0 additions.
     */

    switch (ppl->wVerMaj)
        {
        case VERSIONMAJOR:          //2.x
            switch (ppl->wVerMin)
                {
                case VERSIONMINOR:  //2.0
                    m_pl=*ppl;
                    break;

                default:
                    return POLYLINE_E_UNSUPPORTEDVERSION;
                }
            break;

        case 1:                     //1.x
            switch (ppl->wVerMin)
                {
                case 0:             //1.0
                    *((PPOLYLINEDATA10)&m_pl)=
                        *((PPOLYLINEDATA10)ppl);

                    /*
                     * Update this structure to 2.0.  Note that we
                     * assume whoever loaded us to save the loaded
                     * version so it can later ask what version
                     * the user wants to save.
                     */
                    m_pl.wVerMaj=VERSIONMAJOR;
                    m_pl.wVerMin=VERSIONMINOR;

                    /*
                     * Version 1.0 stored rc in parent coordinates.
                     * We need those now in our client coodinates.
                     */
                    RECTSTORECT(m_pl.rc, rc);
                    OffsetRect(&rc, -m_pl.rc.left, -m_pl.rc.top);

                    /*
                     * 1.0 data had points relative to size of the
                     * rectangle.  We need to scale these to 0-32767
                     * independent of the rectangle for the version
                     * upgrade.
                     */
                    for (i=0; i < m_pl.cPoints; i++)
                        PointScale(&rc, &m_pl.rgpt[i], FALSE);

                    RECTTORECTS(rc, m_pl.rc);

                    //New 2.0 features
                    m_pl.rgbBackground=GetSysColor(COLOR_WINDOW);
                    m_pl.rgbLine=GetSysColor(COLOR_WINDOWTEXT);
                    m_pl.iLineStyle=PS_SOLID;
                    break;

                default:
                    return POLYLINE_E_UNSUPPORTEDVERSION;
                }
            break;

        default:
            return POLYLINE_E_UNSUPPORTEDVERSION;
        }


    //Inform our parent of the data change
    if (NULL!=m_pAdv)
        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_hWnd, &rc);
        pt.x=rc.left;
        pt.y=rc.top;
        ScreenToClient(GetParent(m_hWnd), &pt);
        RECTSTORECT(m_pl.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_hWnd, NULL, TRUE);
        UpdateWindow(m_hWnd);
        }

    return POLYLINE_E_NONE;
    }







/*
 * CPolyline::DataGet
 *
 * Purpose:
 *  Retrieves the Polyline's current data.
 *
 * Parameters:
 *  ppl             PPOLYLINEDATA into which we copy the data.
 *  lVer            LONG version of the data to retrieve.  Use
 *                  VERSIONCURRENT to retrieve the most current.
 *
 * Return Value:
 *  LONG            A POLYLINE_E_* value
 */

LONG CPolyline::DataGet(PPOLYLINEDATA ppl, LONG lVer)
    {
    UINT        i;
    RECT        rc;

    //Retieve the current version
    if (lVer==MAKELONG(VERSIONMINOR, VERSIONMAJOR)
        || VERSIONCURRENT==lVer)
        {
        *ppl=m_pl;
        return POLYLINE_E_NONE;
        }

    //Check for versions we support, 1.x
    if (HIWORD(lVer)!=1)
        return POLYLINE_E_UNSUPPORTEDVERSION;

    if (LOWORD(lVer)==0)    //Check for 1.0
        {
        //Do 2.0 to 1.0 conversion
        *((PPOLYLINEDATA10)ppl)=*((PPOLYLINEDATA10)&m_pl);

        RECTSTORECT(ppl->rc, rc);

        //Get the parent coordinates of our rectangle
        if (!IsWindow(m_hWnd))
            OffsetRect(&rc, 8, 8); //This is always the offset.
        else
            RectGet(&rc);

        /*
         * 1.0 data has points relative to size of the rectangle.
         * We need to scale these from 0-32767 so we have the
         * right values.
         */
        for (i=0; i < ppl->cPoints; i++)
            PointScale(&rc, &ppl->rgpt[i], TRUE);

        RECTTORECTS(rc, ppl->rc);

        //Insure old version numbers.
        ppl->wVerMaj=1;
        ppl->wVerMin=0;

        ((PPOLYLINEDATA10)ppl)->fDrawEntire=TRUE;
        return POLYLINE_E_NONE;
        }

    return POLYLINE_E_UNSUPPORTEDVERSION;
    }








/*
 * CPolyline::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:
 *  LONG            A POLYLINE_E_* value.
 */

LONG CPolyline::DataSetMem(HGLOBAL hMem, BOOL fFree
    , BOOL fSizeToData, BOOL fNotify)
    {
    PPOLYLINEDATA   ppl;
    LONG            lRet=POLYLINE_E_INVALIDPOINTER;

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

        GlobalUnlock(hMem);

        if (fFree)
            GlobalFree(hMem);
        }

    return lRet;
    }







/*
 * CPolyline::DataGetMem
 *
 * Purpose:
 *  Retrieves the Polyline's data in a global memory handle.
 *
 * Parameters:
 *  lVer            LONG version of data to retrieve.
 *  phMem           HGLOBAL * in which to store the handle.
 *
 * Return Value:
 *  LONG            A POLYLINE_E_* value.
 */

LONG CPolyline::DataGetMem(LONG lVer, HGLOBAL *phMem)
    {
    HGLOBAL         hMem;
    PPOLYLINEDATA   ppl;
    LONG            lRet;

    if (NULL==phMem)
        return POLYLINE_E_INVALIDPOINTER;

    hMem=GlobalAlloc(GMEM_DDESHARE | GMEM_MOVEABLE
        , CBPOLYLINEDATA);

    if (NULL!=hMem)
        {
        ppl=(PPOLYLINEDATA)GlobalLock(hMem);
        lRet=DataGet(ppl, lVer);
        GlobalUnlock(hMem);

        if (POLYLINE_E_NONE!=lRet)
            {
            GlobalFree(hMem);
            hMem=NULL;
            }
        }

    *phMem=hMem;
    return lRet;
    }







/*
 * CPolyline::RectGet
 *
 * Purpose:
 *  Returns the rectangle of the Polyline in parent coordinates.
 *
 * Parameters:
 *  pRect           LPRECT in which to return the rectangle.
 *
 * Return Value:
 *  None
 */

void CPolyline::RectGet(LPRECT pRect)
    {
    RECT        rc;
    POINT       pt;

    //Retrieve the size of our rectangle in parent coordinates.
    GetWindowRect(m_hWnd, &rc);
    pt.x=rc.left;
    pt.y=rc.top;
    ScreenToClient(GetParent(m_hWnd), &pt);

    SetRect(pRect, pt.x, pt.y, pt.x+(rc.right-rc.left)
        , pt.y+(rc.bottom-rc.top));

    return;
    }





/*
 * CPolyline::SizeGet
 *
 * Purpose:
 *  Retrieves the size of the Polyline in parent coordinates.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品一区二区三区四区| 日韩二区三区在线观看| 国产91在线观看丝袜| 9色porny自拍视频一区二区| 久久久青草青青国产亚洲免观| 欧美经典一区二区三区| 老司机午夜精品| 欧美男女性生活在线直播观看| 亚洲黄色录像片| 99精品黄色片免费大全| 国产网站一区二区| 亚洲成人激情综合网| 欧美乱熟臀69xxxxxx| 亚洲一区av在线| 国产精品日韩成人| 欧美天堂亚洲电影院在线播放| 偷拍与自拍一区| 欧美一区二区三区视频免费播放| 亚洲精品国久久99热| 91免费观看国产| 一区二区三区.www| 精品国产免费一区二区三区香蕉 | 日韩一级片在线播放| 中文字幕日韩av资源站| 欧美在线视频不卡| 老司机免费视频一区二区三区| 91精品免费观看| 在线看一区二区| 日本怡春院一区二区| 亚洲欧美日韩久久| 日本一区二区三区国色天香| 欧美色视频在线| 成人av网站免费观看| 精品写真视频在线观看| 午夜av一区二区三区| 亚洲精品国产一区二区三区四区在线 | 欧美美女喷水视频| 欧美主播一区二区三区美女| 成人动漫av在线| 国产裸体歌舞团一区二区| 天堂精品中文字幕在线| 日韩av电影免费观看高清完整版在线观看| 亚洲成人午夜影院| 国产麻豆精品久久一二三| 久久99国产精品麻豆| 国产一区免费电影| 不卡电影一区二区三区| 99久久久精品| 奇米精品一区二区三区在线观看| 亚洲成在人线免费| 国产米奇在线777精品观看| 99精品国产视频| 欧洲中文字幕精品| 久久奇米777| 亚洲精选在线视频| 亚洲视频免费在线观看| 蜜臀久久99精品久久久画质超高清| 午夜精品爽啪视频| heyzo一本久久综合| 欧美三级乱人伦电影| 久久一区二区视频| 日韩高清欧美激情| 99久久精品免费| 精品乱人伦小说| 丝瓜av网站精品一区二区| 99国内精品久久| 国产精品入口麻豆原神| 丁香天五香天堂综合| 美女mm1313爽爽久久久蜜臀| 北岛玲一区二区三区四区| 日韩三级精品电影久久久| 亚洲国产中文字幕在线视频综合 | 亚洲精品乱码久久久久久 | 国产精品一区二区三区四区 | 成人激情图片网| 久久亚洲一区二区三区明星换脸 | 国产成人亚洲综合a∨婷婷| 欧美偷拍一区二区| 亚洲自拍与偷拍| 欧美日韩在线三级| 亚洲r级在线视频| 91精品婷婷国产综合久久竹菊| 亚洲成人激情综合网| 在线综合视频播放| 美女久久久精品| 久久精品夜色噜噜亚洲a∨| 国产麻豆视频一区二区| 欧美激情在线观看视频免费| 成人精品国产福利| 无码av免费一区二区三区试看| 欧美区一区二区三区| 国产精品18久久久久久久网站| 久久综合一区二区| 色综合色综合色综合色综合色综合 | 中文字幕中文字幕在线一区 | 中文字幕av不卡| 国产婷婷色一区二区三区在线| 欧美一区二区啪啪| 91视频www| 91极品美女在线| 欧美日免费三级在线| 欧美日韩久久久| 日韩三级视频在线观看| 亚洲精品一区二区三区四区高清 | 日韩理论电影院| 国产成人精品影视| 日韩精品电影一区亚洲| 亚洲欧美日韩国产另类专区 | 精品国产91洋老外米糕| 欧美日韩一区二区在线观看视频| 成人免费高清视频| 国产激情一区二区三区四区| 美女一区二区视频| 日韩国产欧美在线播放| 亚洲电影激情视频网站| 国产精品免费视频网站| 久久欧美中文字幕| 26uuu色噜噜精品一区二区| 日韩视频在线观看一区二区| 在线观看91av| 欧美一区二区三区视频免费播放| 欧美精品久久99| 制服.丝袜.亚洲.另类.中文| 337p亚洲精品色噜噜噜| 欧美一级久久久| 国产日韩欧美高清| 亚洲美腿欧美偷拍| 日韩激情av在线| 久久电影网站中文字幕| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 欧美一区二区在线看| 91麻豆精品国产91久久久更新时间 | 欧美一区二区日韩一区二区| 精品日韩一区二区三区| 国产精品久久久久久亚洲毛片| 亚洲国产视频在线| 精品一区精品二区高清| 99久久伊人久久99| 欧美精品亚洲二区| 中文字幕成人网| 日本欧洲一区二区| 色婷婷综合在线| 精品欧美乱码久久久久久1区2区| 中文字幕在线免费不卡| 久88久久88久久久| 欧美在线一二三四区| 国产精品乱人伦中文| 国产一二精品视频| 精品国产制服丝袜高跟| 日本美女一区二区| 在线观看免费亚洲| 一二三区精品视频| 欧美伊人精品成人久久综合97| 中文成人综合网| 国产精品18久久久久久久网站| 69久久99精品久久久久婷婷 | 精品噜噜噜噜久久久久久久久试看| 欧美一区二区在线免费观看| 欧美激情一区二区三区不卡| 国产精品高潮呻吟久久| 亚洲图片欧美色图| 麻豆精品在线看| 国产经典欧美精品| 久久九九久久九九| 亚洲成av人影院| 欧美日韩国产区一| 亚洲综合免费观看高清完整版| 岛国精品一区二区| 中文字幕在线不卡视频| 色偷偷久久人人79超碰人人澡| 国产精品国产成人国产三级| 99久久久久久99| 久久久亚洲欧洲日产国码αv| 激情五月婷婷综合| 国产女同互慰高潮91漫画| 成人激情免费电影网址| 亚洲精品少妇30p| 欧美一级搡bbbb搡bbbb| 本田岬高潮一区二区三区| 亚洲美女淫视频| 亚洲精品在线观| 色综合天天综合在线视频| 久久精品国产秦先生| 亚洲色图在线看| 日本一区二区综合亚洲| 欧美日韩一区二区三区不卡 | 亚洲综合av网| 国产偷国产偷亚洲高清人白洁| 欧美网站大全在线观看| 久久99精品久久久久久动态图| 亚洲精品一二三| 国产色一区二区| 日韩欧美国产午夜精品| 欧美午夜电影网| 欧美一a一片一级一片| 成人午夜精品在线| 成人性生交大合| av爱爱亚洲一区| 99久久精品国产毛片| 91在线无精精品入口|