<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++
    主站蜘蛛池模板: 成年女人免费视频播放体验区| 亚洲性线免费观看视频成熟| 免费一级做a爰片久久毛片潮喷| 亚洲国产视频久久| 7723日本高清完整版免费| 亚洲男人电影天堂| 91嫩草国产在线观看免费| 91在线亚洲综合在线| 天天摸天天操免费播放小视频| 亚洲国产精品嫩草影院| 免费中文字幕一级毛片| eeuss影院免费92242部| 亚洲AV永久精品爱情岛论坛| 91久久青青草原线免费| 中文字幕亚洲综合小综合在线| 最新猫咪www免费人成| 亚洲经典千人经典日产| 亚洲人成电影网站国产精品| 国产三级在线免费| 91亚洲精品自在在线观看| 日美韩电影免费看| 国产成人无码免费网站| 亚洲国产精品久久久久| 成人免费在线观看网站| 一级毛片a免费播放王色电影| 亚洲乱码日产一区三区| 最新欧洲大片免费在线| 国产综合激情在线亚洲第一页| 亚洲中文久久精品无码ww16| 最近免费中文字幕大全高清大全1| 亚洲а∨天堂久久精品9966| 亚洲日韩在线中文字幕第一页| 秋霞人成在线观看免费视频| 久久夜色精品国产噜噜亚洲a| 亚洲人成影院在线观看 | 亚洲高清无码在线观看| 久久久久免费精品国产小说| 亚洲男人的天堂网站| 久久亚洲国产精品| 国产成人精品免费直播| 99久久精品国产免费|