<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 495,comments - 227,trackbacks - 0
    合并兩張jpg圖片為一張jpg圖片,思路是先把兩張圖片jpg圖片都轉化成bmp圖片,然后把兩張bmp圖片合并成一張bmp圖片,然后是把這張bmp圖片轉化為jpg圖片。

    一。jpg,bmp互相轉化
    /*********************************
    format:bmp轉為jpg, format為image/jpeg,jpg轉為bmp,format為image/bmp
    strDst為最終轉化結果的圖片路徑
    strSrc為原來圖片的路徑
    **********************************/
    BOOL ConvertPic(const WCHAR *format, const CString &strDst, const CString &strSrc)
    {
    BOOL bConvert = false;
    CLSID clsid;
    int nRet = 0;
    nRet = GetEncoderClsid(format,&clsid);  //得到CLSID
    USES_CONVERSION;
    if (nRet>=0)
    {
      Image image(A2W(strSrc));
      image.Save(A2W(strDst),&clsid,NULL);
      bConvert = true;
    }
    return bConvert;
    }
    其中GetEncoderClsid函數如下:
    /*****************************************************
    返回值為-1表示失敗,其他為成功
    ******************************************************/
    int GetEncoderClsid(const WCHAR *format, CLSID *pClsid)
    {
    int nRet = -1;
    ImageCodecInfo * pCodecInfo = NULL;
    UINT nNum = 0,nSize = 0;
    GetImageEncodersSize(&nNum,&nSize);
    if (nSize<0)
    {
      return nRet;
    }
    pCodecInfo = new ImageCodecInfo[nSize];
    if (pCodecInfo==NULL)
    {
      return nRet;
    }
    GetImageEncoders(nNum,nSize,pCodecInfo);
    for (UINT i=0; i<nNum; i++)
    {
      if (wcscmp(pCodecInfo[i].MimeType,format)==0)
      {
       *pClsid = pCodecInfo[i].Clsid;
       nRet = i;

       delete[] pCodecInfo;
       return nRet;
      }
      else
      {
       continue;
      }
    }
    delete[] pCodecInfo;
    return nRet;
    }
    bmp轉化為jpg
    ConvertPic(L"image/jpeg","c:""1.jpg","c:""1.bmp")
    jpg轉化為bmp
    ConvertPic(L"image/bmp","c:""1.bmp","c:""1.jpg")

    二。bmp圖片合并
    BOOL CombinePic(const WCHAR *format, const CString &strDst, const CString &strPic1, "
                   const CString &strPic2)
    {
    BOOL bCombine = false;
    int nRet = 0;
    CLSID clsid;
    nRet = GetEncoderClsid(format,&clsid);
    if (nRet>=0)
    {
      USES_CONVERSION;
      Bitmap bmp1(A2W(strPic1));
      Bitmap bmp2(A2W(strPic2));
      
      int nWidth = 0, nHeight = 0;
      nWidth = bmp1.GetWidth();   //假設兩圖片大小同
      nHeight = bmp1.GetHeight();
      Bitmap bmpCombine(2*nWidth,nHeight);  //高不變,寬*2,水平合并
      Graphics * pG = NULL;
      pG = Graphics::FromImage(&bmpCombine);
      if (pG!=NULL)
      {
       pG->DrawImage(&bmp1,0,0);
       pG->DrawImage(&bmp2,nWidth,0);

    // Create a string.
               WCHAR string[] = L"simone";
              
               // Initialize arguments.
               Font myFont(L"Arial", 16);
               PointF origin(50.0f, 5.0f);
               SolidBrush blackBrush(Color(255, 255, 0, 0));
               StringFormat format;
               format.SetAlignment(StringAlignmentCenter);
                // Draw string.
               pG->DrawString(
                   string,
                   6,
                   &myFont,
                   origin,
                   &format,
                   &blackBrush);

       bmpCombine.Save(A2W(strDst),&clsid,NULL);
      }
    }
    return bCombine;
    }
    例子:
    CombinePic(L"image/bmp","12.bmp","1.bmp","2.bmp");

    有了上面的功能,其他的就沒問題了
    posted on 2008-07-05 17:32 SIMONE 閱讀(615) 評論(0)  編輯  收藏 所屬分類: C++
    主站蜘蛛池模板: 亚洲一区二区高清| 全亚洲最新黄色特级网站| 999久久久免费精品国产| 毛片免费观看网站| 国产成人精品日本亚洲| 亚洲熟女综合色一区二区三区| 免费一区二区三区在线视频| www视频在线观看免费| 久久精品国产精品亚洲| 亚洲国产区男人本色在线观看| 成人一区二区免费视频| 免费毛片a在线观看67194| 亚洲av午夜成人片精品网站| 一级女性全黄久久生活片免费| 免费观看成人毛片a片2008| 337p日本欧洲亚洲大胆精品555588 | 久久精品成人免费网站| 免费乱码中文字幕网站| 在线精品亚洲一区二区| 国产成人免费全部网站| 亚洲无码一区二区三区| 国产精品久久久久影院免费| caoporn国产精品免费| 亚洲成人午夜电影| 国产黄在线播放免费观看| 国产AV无码专区亚洲AV手机麻豆| 最新亚洲人成无码网www电影| 午夜国产精品免费观看 | 亚洲熟女www一区二区三区| 国产三级免费观看| 亚洲经典千人经典日产| 日韩欧美一区二区三区免费观看| 国产精品久久久久久亚洲影视| 精品国产亚洲一区二区在线观看| 99视频精品全部免费观看| 亚洲网站在线观看| 99精品视频在线观看免费专区| 最新亚洲精品国偷自产在线| 国产亚洲色婷婷久久99精品91| 国产h肉在线视频免费观看| 日韩亚洲综合精品国产|