zoukankan      html  css  js  c++  java
  • 20190710记录:去掉中转图,直接以1280*1024进行反坐标计算,填补pbFinal。

    1、记录:去掉中转图,直接以1280*1024进行反坐标计算。pbFinal=1280*1024。

    // Imagejoint.cpp : 定义控制台应用程序的入口点。
    //
    #include "stdafx.h"
    #include "Imagejoint.h"
    #include "math.h"
    #include <afxwin.h> 
    #ifdef _DEBUG
    #define new DEBUG_NEW
    #endif
    #include <atlimage.h>//CImage类
    #include <locale.h>
    
    // The one and only application object
    
    CWinApp theApp;
    
    using namespace std;
    //双三次插值系数
    double fs(double w)
    {    
            double a=-0.5;
            double fs;
            if (abs(w)<=1)
                fs=(a+2)*pow(abs(w),3)-(a+3)*pow(abs(w),2)+1;
            else if (abs(w)>1&&abs(w)<=2)
                fs=a*pow(abs(w),3)-5*a*pow(abs(w),2)+8*a*abs(w)-4*a;
            else
                fs=0;
            return fs;
    }
    
    HRESULT Imagejoint(PBYTE pbSrc,int iWidth,int iHeight,double dbZoom,PBYTE pbFinal);
    
    int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
    {
    
        int nRetCode = 0;//表示整数类型的函数返回码。n表示整数类型,Ret是Return的缩写,表示返回值,Code表示代码。
        setlocale(LC_ALL,"chs");
        HMODULE hModule = ::GetModuleHandle(NULL);
    
        if (hModule != NULL)
        {
            // initialize MFC and print and error on failure
            CImage cImage;
            HRESULT hResult;
    
            //初始化一些变量
            int        iWidth,iHeight,iBytePerPixel,iPitch;
            int        x,y;
            PBYTE    pbSrc=NULL,pbFinal=NULL;//源图、目标图
            PBYTE    pbImage=NULL;//load图像后存在这
            PDWORD    pdwImage=NULL;//用于保存图像
            double    dbZoom=2.25;
    
        
            CString str = "frame1.bmp";
            LPCTSTR filename = (LPCTSTR)str;
            do{
                if (!AfxWinInit(hModule, NULL, ::GetCommandLine(), 0))
                {
                    // TODO: change error code to suit your needs
                    _tprintf(_T("Fatal Error: MFC initialization failed
    "));
                    nRetCode = 1;
                    break;
                }
                //Load 图像到cImage对象中
                hResult=cImage.Load(filename);
                if(hResult!=ERROR_SUCCESS)
                {
                    _tprintf(_T("源图像文件名错误!
    "));
                    nRetCode= -3;
                    break;
                }
                
                iWidth=cImage.GetWidth();
                iHeight=cImage.GetHeight();
                //分配源图内存
                pbSrc = (PBYTE)malloc(iWidth*iHeight);
                pbFinal = (PBYTE)malloc(1280*1024);
            //while (dbZoom<3);
            //{
                //分配目标图内存
    
    
                if(pbSrc==NULL || pbFinal==NULL )
                {
                    _tprintf(_T("内存申请错误!
    "));
                    nRetCode= -4;
                    break;
                }
                //cImage数据存到pbImage,后再转换为源灰度图pbSrc
                iPitch=cImage.GetPitch();
                iBytePerPixel=(cImage.GetBPP()+7)/8;
                if(iBytePerPixel==3)
                {
                    for(y=0;y<iHeight;y++)
                    {   //load的图像数据放到pbImage
                        pbImage=(PBYTE)(PBYTE(cImage.GetBits())+iPitch*y);//得到的是图像初始像素地址
                        for(x=0;x<iWidth;x++)
                        {
                            //pbImage转换为灰度图pbSrc
                            pbSrc[y*iWidth+x]=(pbImage[3*x]*0.15+pbImage[3*x+1]*0.55+pbImage[3*x+2]*0.3);
                        }
                    }
                }
                cImage.Destroy();
                //TO DO:执行操作
                hResult=Imagejoint(pbSrc,iWidth,iHeight,dbZoom,pbFinal);
                if(hResult!=ERROR_SUCCESS)
                {
                    _tprintf(_T("图像处理错误!
    "));
                    nRetCode= -5;
                    break;
                }
    
    
                //处理后保存图像
                iWidth=1280;
                iHeight=1024;
                cImage.Create(iWidth,-iHeight,32);
                iPitch=cImage.GetPitch();
                for(y=0;y<iHeight;y++)
                {
                    pdwImage=(PDWORD)(PBYTE(cImage.GetBits())+iPitch*y);
                    for(x=0;x<iWidth;x++)
                    {
                        pdwImage[x]=pbFinal[y*iWidth+x]*0x10101;  
                    }
                }
                //待保存图像文件名
                CString name1="target";
                CString name2;
                name2.Format(_T("%.2lf"),dbZoom);
    
                CString csTagName;
                csTagName=name1+name2;
                //CString csTagName="target";
                csTagName.Trim();
                csTagName.MakeUpper();
                if(csTagName.Right(4)!=_T(".BMP") ) csTagName.Append(_T(".BMP"));
                hResult=cImage.Save(csTagName);
                if(hResult!=ERROR_SUCCESS)
                {
                    _tprintf(_T("图像结果保存错误!
    "));
                    nRetCode= -5;
                    break;
                }
                _tprintf(_T("图像处理成功!
    "));
                nRetCode= ERROR_SUCCESS;
                break;
    
                //dbZoom=dbZoom+0.5;
                //}
    
            }while(0);
            if(pbSrc) free(pbSrc);
            if(pbFinal) free(pbFinal);
            
        }
        else
        {
            _tprintf(_T("Fatal Error: GetModuleHandle failed
    "));
            nRetCode = 1;
        }
        getchar();    
        return nRetCode;
    }
    
    HRESULT Imagejoint(PBYTE pbSrc,int iWidth,int iHeight,double dbZoom,PBYTE pbFinal)
    {
        double phase[33]={0};//16相位,包含端点存在33个距离
        for (int i=0;i<33;i++)
        {
            double i2=1.0*i;
            phase[i]=fs(i2/16);
        }
    
        //旋转中心为图像中心
        double rx0=iWidth;  
        double ry0=iHeight; 
        double srcx,srcy,u,v;
        int xOr,yOr;
        int newWidth=ceil(dbZoom*iWidth);
        int newHeight=ceil(dbZoom*iHeight);
    
        for (int y=0;y<1024;y++)
        {
            for (int x=0;x<1280;x++)
            {
    
                srcx=(double)(newWidth/2-640+x)/dbZoom;
                srcy=(double)(newHeight/2-512+y)/dbZoom ;
                xOr = floor(srcx);
                yOr = floor(srcy);
                u=srcx-xOr;
                v=srcy-yOr;
    
                int phasex=floor(16*u+0.5);//16相位
                int phasey=floor(16*v+0.5);
                double A1,B1,C1,D1,A2,B2,C2,D2;
                A1=phase[16+phasex];
                B1=phase[phasex];
                C1=phase[16-phasex];
                D1=phase[32-phasex];
    
                A2=phase[16+phasey];
                B2=phase[phasey];
                C2=phase[16-phasey];
                D2=phase[32-phasey];
    
    
                if( !(srcx>=0 && srcx<=iWidth && srcy>=0 && srcy<=iHeight))
                    {
                        pbFinal[y*1280+x]=0;//255
                    }
                else
                {   
                    double middle=
                        pbSrc[(yOr-1)*iWidth+(xOr-1)]*A1*A2+
                        pbSrc[(yOr)*iWidth+(xOr-1)]*A1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr-1)]*A1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr-1)]*A1*D2+
                        
                        pbSrc[(yOr-1)*iWidth+(xOr)]*B1*A2+
                        pbSrc[(yOr)*iWidth+(xOr)]*B1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr)]*B1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr)]*B1*D2+
    
                        pbSrc[(yOr-1)*iWidth+(xOr+1)]*C1*A2+
                        pbSrc[(yOr)*iWidth+(xOr+1)]*C1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr+1)]*C1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr+1)]*C1*D2+
    
                        pbSrc[(yOr-1)*iWidth+(xOr+2)]*D1*A2+
                        pbSrc[(yOr)*iWidth+(xOr+2)]*D1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr+2)]*D1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr+2)]*D1*D2;
    
                    if(middle<=255&&middle>=0)
                        pbFinal[y*1280+x]=middle;
                    else if(middle>255)
                        pbFinal[y*1280+x]=255;
                    else 
                        pbFinal[y*1280+x]=0;
                }
            }
        }
        return ERROR_SUCCESS;
    }
    View Code

    2、外圈需拼接

    目前dbZoom都是表示的,中间处的放大倍数。

    由于目前测试图像是768*576的。

    在dbZoom<1.75左右时,其外圈仍需补充拼接。

    先进行简单测试:发现需补充拼接的点为,映射后落在原图外的部分。暂时仍采用同一图像进行外圈的拼接。

    // Imagejoint.cpp : 定义控制台应用程序的入口点。
    //
    #include "stdafx.h"
    #include "Imagejoint.h"
    #include <afxwin.h> 
    #ifdef _DEBUG
    #define new DEBUG_NEW
    #endif
    #include <atlimage.h>//CImage类
    #include <locale.h>
    #include "math.h"
    using namespace std;
    //双三次插值系数
    double fs(double w)
    {    
            double a=-0.5;
            double fs;
            if (abs(w)<=1)
                fs=(a+2)*pow(abs(w),3)-(a+3)*pow(abs(w),2)+1;
            else if (abs(w)>1&&abs(w)<=2)
                fs=a*pow(abs(w),3)-5*a*pow(abs(w),2)+8*a*abs(w)-4*a;
            else
                fs=0;
            return fs;
    }
    
    HRESULT Imagejoint(PBYTE pbSrc,int iWidth,int iHeight,double dbZoom,PBYTE pbFinal);
    
    int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
    {
    
        int nRetCode = 0;//表示整数类型的函数返回码。n表示整数类型,Ret是Return的缩写,表示返回值,Code表示代码。
        setlocale(LC_ALL,"chs");
        HMODULE hModule = ::GetModuleHandle(NULL);
    
        if (hModule != NULL)
        {
            // initialize MFC and print and error on failure
            CImage cImage;
            HRESULT hResult;
    
            //初始化一些变量
            int        iWidth,iHeight,iBytePerPixel,iPitch;
            int        x,y;
            PBYTE    pbSrc=NULL,pbFinal=NULL;//源图、目标图
            PBYTE    pbImage=NULL;//load图像后存在这
            PDWORD    pdwImage=NULL;//用于保存图像
            double    dbZoom=1.25;
    
        
            CString str = "frame1.bmp";
            LPCTSTR filename = (LPCTSTR)str;
            do{
                if (!AfxWinInit(hModule, NULL, ::GetCommandLine(), 0))
                {
                    // TODO: change error code to suit your needs
                    _tprintf(_T("Fatal Error: MFC initialization failed
    "));
                    nRetCode = 1;
                    break;
                }
                //Load 图像到cImage对象中
                hResult=cImage.Load(filename);
                if(hResult!=ERROR_SUCCESS)
                {
                    _tprintf(_T("源图像文件名错误!
    "));
                    nRetCode= -3;
                    break;
                }
                
                iWidth=cImage.GetWidth();
                iHeight=cImage.GetHeight();
                //分配源图内存
                pbSrc = (PBYTE)malloc(iWidth*iHeight);
                pbFinal = (PBYTE)malloc(1280*1024);
            //while (dbZoom<3);
            //{
                //分配目标图内存
    
    
                if(pbSrc==NULL || pbFinal==NULL )
                {
                    _tprintf(_T("内存申请错误!
    "));
                    nRetCode= -4;
                    break;
                }
                //cImage数据存到pbImage,后再转换为源灰度图pbSrc
                iPitch=cImage.GetPitch();
                iBytePerPixel=(cImage.GetBPP()+7)/8;
                if(iBytePerPixel==3)
                {
                    for(y=0;y<iHeight;y++)
                    {   //load的图像数据放到pbImage
                        pbImage=(PBYTE)(PBYTE(cImage.GetBits())+iPitch*y);//得到的是图像初始像素地址
                        for(x=0;x<iWidth;x++)
                        {
                            //pbImage转换为灰度图pbSrc
                            pbSrc[y*iWidth+x]=(pbImage[3*x]*0.15+pbImage[3*x+1]*0.55+pbImage[3*x+2]*0.3);
                        }
                    }
                }
                cImage.Destroy();
                //TO DO:执行操作
                hResult=Imagejoint(pbSrc,iWidth,iHeight,dbZoom,pbFinal);
                if(hResult!=ERROR_SUCCESS)
                {
                    _tprintf(_T("图像处理错误!
    "));
                    nRetCode= -5;
                    break;
                }
    
    
                //处理后保存图像
                iWidth=1280;
                iHeight=1024;
                cImage.Create(iWidth,-iHeight,32);
                iPitch=cImage.GetPitch();
                for(y=0;y<iHeight;y++)
                {
                    pdwImage=(PDWORD)(PBYTE(cImage.GetBits())+iPitch*y);
                    for(x=0;x<iWidth;x++)
                    {
                        pdwImage[x]=pbFinal[y*iWidth+x]*0x10101;  
                    }
                }
                //待保存图像文件名
                CString name1="target";
                CString name2;
                name2.Format(_T("%.2lf"),dbZoom);
    
                CString csTagName;
                csTagName=name1+name2;
                //CString csTagName="target";
                csTagName.Trim();
                csTagName.MakeUpper();
                if(csTagName.Right(4)!=_T(".BMP") ) csTagName.Append(_T(".BMP"));
                hResult=cImage.Save(csTagName);
                if(hResult!=ERROR_SUCCESS)
                {
                    _tprintf(_T("图像结果保存错误!
    "));
                    nRetCode= -5;
                    break;
                }
                _tprintf(_T("图像处理成功!
    "));
                nRetCode= ERROR_SUCCESS;
                break;
    
                //dbZoom=dbZoom+0.5;
                //}
    
            }while(0);
            if(pbSrc) free(pbSrc);
            if(pbFinal) free(pbFinal);
            
        }
        else
        {
            _tprintf(_T("Fatal Error: GetModuleHandle failed
    "));
            nRetCode = 1;
        }
        getchar();    
        return nRetCode;
    }
    
    HRESULT Imagejoint(PBYTE pbSrc,int iWidth,int iHeight,double dbZoom,PBYTE pbFinal)
    {
        double phase[33]={0};//16相位,包含端点存在33个距离
        for (int i=0;i<33;i++)
        {
            double i2=1.0*i;
            phase[i]=fs(i2/16);
        }
    
        //旋转中心为图像中心
        double rx0=iWidth;  
        double ry0=iHeight; 
        double srcx,srcy,u,v;
        int xOr,yOr;
        int newWidth=ceil(dbZoom*iWidth);
        int newHeight=ceil(dbZoom*iHeight);
    
        for (int y=0;y<1024;y++)
        {
            for (int x=0;x<1280;x++)
            {
    
                srcx=(double)(newWidth/2-640+x)/dbZoom;
                srcy=(double)(newHeight/2-512+y)/dbZoom ;
                xOr = floor(srcx);
                yOr = floor(srcy);
                u=srcx-xOr;
                v=srcy-yOr;
    
                int phasex=floor(16*u+0.5);//16相位
                int phasey=floor(16*v+0.5);
                double A1,B1,C1,D1,A2,B2,C2,D2;
                A1=phase[16+phasex];
                B1=phase[phasex];
                C1=phase[16-phasex];
                D1=phase[32-phasex];
    
                A2=phase[16+phasey];
                B2=phase[phasey];
                C2=phase[16-phasey];
                D2=phase[32-phasey];
    
    
                if( !(srcx>=0 && srcx<=iWidth && srcy>=0 && srcy<=iHeight))//越界部分需拼接为外圈大视场图像,远景
                    {
    
                        srcx=(double)(newWidth/2-320+x)/(2*dbZoom);
                        srcy=(double)(newHeight/2-256+y)/(2*dbZoom) ;
                        xOr = floor(srcx);
                        yOr = floor(srcy);
                        u=srcx-xOr; 
                        v=srcy-yOr;
    
                        int phasex=floor(16*u+0.5);//16相位
                        int phasey=floor(16*v+0.5);
                        double A1,B1,C1,D1,A2,B2,C2,D2;
                        A1=phase[16+phasex];
                        B1=phase[phasex];
                        C1=phase[16-phasex];
                        D1=phase[32-phasex];
    
                        A2=phase[16+phasey];
                        B2=phase[phasey];
                        C2=phase[16-phasey];
                        D2=phase[32-phasey];
    
                        double middle=
                        pbSrc[(yOr-1)*iWidth+(xOr-1)]*A1*A2+
                        pbSrc[(yOr)*iWidth+(xOr-1)]*A1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr-1)]*A1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr-1)]*A1*D2+
                        
                        pbSrc[(yOr-1)*iWidth+(xOr)]*B1*A2+
                        pbSrc[(yOr)*iWidth+(xOr)]*B1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr)]*B1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr)]*B1*D2+
    
                        pbSrc[(yOr-1)*iWidth+(xOr+1)]*C1*A2+
                        pbSrc[(yOr)*iWidth+(xOr+1)]*C1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr+1)]*C1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr+1)]*C1*D2+
    
                        pbSrc[(yOr-1)*iWidth+(xOr+2)]*D1*A2+
                        pbSrc[(yOr)*iWidth+(xOr+2)]*D1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr+2)]*D1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr+2)]*D1*D2;
    
                    if(middle<=255&&middle>=0)
                        pbFinal[y*1280+x]=middle;
                    else if(middle>255)
                        pbFinal[y*1280+x]=255;
                    else 
                        pbFinal[y*1280+x]=0;
                        //pbFinal[y*1280+x]=255;
                    }
                else
                {   
                    double middle=
                        pbSrc[(yOr-1)*iWidth+(xOr-1)]*A1*A2+
                        pbSrc[(yOr)*iWidth+(xOr-1)]*A1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr-1)]*A1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr-1)]*A1*D2+
                        
                        pbSrc[(yOr-1)*iWidth+(xOr)]*B1*A2+
                        pbSrc[(yOr)*iWidth+(xOr)]*B1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr)]*B1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr)]*B1*D2+
    
                        pbSrc[(yOr-1)*iWidth+(xOr+1)]*C1*A2+
                        pbSrc[(yOr)*iWidth+(xOr+1)]*C1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr+1)]*C1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr+1)]*C1*D2+
    
                        pbSrc[(yOr-1)*iWidth+(xOr+2)]*D1*A2+
                        pbSrc[(yOr)*iWidth+(xOr+2)]*D1*B2+
                        pbSrc[(yOr+1)*iWidth+(xOr+2)]*D1*C2+
                        pbSrc[(yOr+2)*iWidth+(xOr+2)]*D1*D2;
    
                    if(middle<=255&&middle>=0)
                        pbFinal[y*1280+x]=middle;
                    else if(middle>255)
                        pbFinal[y*1280+x]=255;
                    else 
                        pbFinal[y*1280+x]=0;
                }
            }
        }
        return ERROR_SUCCESS;
    }
    View Code

    3、初步改为利用双图拼接而来,但是其中一些参数不对,拼接位置不对。注意:代码起始阶段的图像长宽和内存分配,默认是两图相同的。

    // Imagejoint.cpp : 定义控制台应用程序的入口点。
    //
    #include "stdafx.h"
    #include "Imagejoint.h"
    #include <afxwin.h> 
    #ifdef _DEBUG
    #define new DEBUG_NEW
    #endif
    #include <atlimage.h>//CImage类
    #include <locale.h>
    #include "math.h"
    using namespace std;
    //双三次插值系数
    double fs(double w)
    {    
            double a=-0.5;
            double fs;
            if (abs(w)<=1)
                fs=(a+2)*pow(abs(w),3)-(a+3)*pow(abs(w),2)+1;
            else if (abs(w)>1&&abs(w)<=2)
                fs=a*pow(abs(w),3)-5*a*pow(abs(w),2)+8*a*abs(w)-4*a;
            else
                fs=0;
            return fs;
    }
    
    HRESULT Imagejoint(PBYTE pbSrc1,PBYTE pbSrc2,int iWidth,int iHeight,double dbZoom,PBYTE pbFinal);
    
    int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
    {
    
        int nRetCode = 0;//表示整数类型的函数返回码。n表示整数类型,Ret是Return的缩写,表示返回值,Code表示代码。
        setlocale(LC_ALL,"chs");
        HMODULE hModule = ::GetModuleHandle(NULL);
    
        if (hModule != NULL)
        {
            // initialize MFC and print and error on failure
            CImage cImage_far;
            CImage cImage_near;
    
    
            HRESULT hResult1,hResult2;
    
            //初始化一些变量
            int        iWidth,iHeight,iBytePerPixel,iPitch;
            int        x,y;
            PBYTE    pbSrc1=NULL,pbSrc2=NULL,pbFinal=NULL;//源图、目标图
            PBYTE    pbImage=NULL;//load图像后存在这
            PDWORD    pdwImage=NULL;//用于保存图像
            double    dbZoom=1.25;
    
        
            CString str = "far-frame1.bmp";
            CString str2 = "near-frame1.bmp";
            LPCTSTR filename1 = (LPCTSTR)str;
            LPCTSTR filename2 = (LPCTSTR)str2;
            do{
                if (!AfxWinInit(hModule, NULL, ::GetCommandLine(), 0))
                {
                    // TODO: change error code to suit your needs
                    _tprintf(_T("Fatal Error: MFC initialization failed
    "));
                    nRetCode = 1;
                    break;
                }
                //Load 图像到cImage对象中
                hResult1=cImage_far.Load(filename1);
                hResult2=cImage_near.Load(filename2);
                if(hResult1!=ERROR_SUCCESS||hResult2!=ERROR_SUCCESS)
                {
                    _tprintf(_T("源图像文件名错误!
    "));
                    nRetCode= -3;
                    break;
                }
                
                iWidth=cImage_far.GetWidth();
                iHeight=cImage_far.GetHeight();
                //分配源图内存
                pbSrc1 = (PBYTE)malloc(iWidth*iHeight);
                pbSrc2 = (PBYTE)malloc(iWidth*iHeight);
                pbFinal = (PBYTE)malloc(1280*1024);
            //while (dbZoom<3);
            //{
                //分配目标图内存
    
    
                if(pbSrc1==NULL||pbSrc2==NULL || pbFinal==NULL )
                {
                    _tprintf(_T("内存申请错误!
    "));
                    nRetCode= -4;
                    break;
                }
                //cImage数据存到pbImage,后再转换为源灰度图pbSrc
                iPitch=cImage_far.GetPitch();
                iBytePerPixel=(cImage_far.GetBPP()+7)/8;
                if(iBytePerPixel==3)
                {
                    for(y=0;y<iHeight;y++)
                    {   //load的图像数据放到pbImage
                        pbImage=(PBYTE)(PBYTE(cImage_far.GetBits())+iPitch*y);//得到的是图像初始像素地址
                        for(x=0;x<iWidth;x++)
                        {
                            //pbImage转换为灰度图pbSrc
                            pbSrc1[y*iWidth+x]=(pbImage[3*x]*0.15+pbImage[3*x+1]*0.55+pbImage[3*x+2]*0.3);
                        }
                    }
                }
                cImage_far.Destroy();
    
    
                iPitch=cImage_near.GetPitch();
                iBytePerPixel=(cImage_near.GetBPP()+7)/8;
                if(iBytePerPixel==3)
                {
                    for(y=0;y<iHeight;y++)
                    {   //load的图像数据放到pbImage
                        pbImage=(PBYTE)(PBYTE(cImage_near.GetBits())+iPitch*y);//得到的是图像初始像素地址
                        for(x=0;x<iWidth;x++)
                        {
                            //pbImage转换为灰度图pbSrc
                            pbSrc2[y*iWidth+x]=(pbImage[3*x]*0.15+pbImage[3*x+1]*0.55+pbImage[3*x+2]*0.3);
                        }
                    }
                }
                cImage_near.Destroy();
                //TO DO:执行操作
                hResult1=Imagejoint(pbSrc1,pbSrc2,iWidth,iHeight,dbZoom,pbFinal);
                if(hResult1!=ERROR_SUCCESS)
                {
                    _tprintf(_T("图像处理错误!
    "));
                    nRetCode= -5;
                    break;
                }
    
    
                //处理后保存图像
                iWidth=1280;
                iHeight=1024;
                cImage_far.Create(iWidth,-iHeight,32);
                iPitch=cImage_far.GetPitch();
                for(y=0;y<iHeight;y++)
                {
                    pdwImage=(PDWORD)(PBYTE(cImage_far.GetBits())+iPitch*y);
                    for(x=0;x<iWidth;x++)
                    {
                        pdwImage[x]=pbFinal[y*iWidth+x]*0x10101;  
                    }
                }
                //待保存图像文件名
                CString name1="target";
                CString name2;
                name2.Format(_T("%.2lf"),dbZoom);
    
                CString csTagName;
                csTagName=name1+name2;
                //CString csTagName="target";
                csTagName.Trim();
                csTagName.MakeUpper();
                if(csTagName.Right(4)!=_T(".BMP") ) csTagName.Append(_T(".BMP"));
                hResult1=cImage_far.Save(csTagName);
                if(hResult1!=ERROR_SUCCESS)
                {
                    _tprintf(_T("图像结果保存错误!
    "));
                    nRetCode= -5;
                    break;
                }
                _tprintf(_T("图像处理成功!
    "));
                nRetCode= ERROR_SUCCESS;
                break;
    
                //dbZoom=dbZoom+0.5;
                //}
    
            }while(0);
            if(pbSrc1) free(pbSrc1);
            if(pbSrc2) free(pbSrc2);
            if(pbFinal) free(pbFinal);
            
        }
        else
        {
            _tprintf(_T("Fatal Error: GetModuleHandle failed
    "));
            nRetCode = 1;
        }
        getchar();    
        return nRetCode;
    }
    
    HRESULT Imagejoint(PBYTE pbSrc1,PBYTE pbSrc2,int iWidth,int iHeight,double dbZoom,PBYTE pbFinal)
    {
        double phase[33]={0};//16相位,包含端点存在33个距离
        for (int i=0;i<33;i++)
        {
            double i2=1.0*i;
            phase[i]=fs(i2/16);
        }
    
        //旋转中心为图像中心
        double rx0=iWidth;  
        double ry0=iHeight; 
        double srcx,srcy,u,v;
        int xOr,yOr;
        int newWidth=ceil(dbZoom*iWidth);
        int newHeight=ceil(dbZoom*iHeight);
    
        for (int y=0;y<1024;y++)
        {
            for (int x=0;x<1280;x++)
            {
    
                srcx=(double)(newWidth/2-640+x)/dbZoom;
                srcy=(double)(newHeight/2-512+y)/dbZoom ;
                xOr = floor(srcx);
                yOr = floor(srcy);
                u=srcx-xOr;
                v=srcy-yOr;
    
                int phasex=floor(16*u+0.5);//16相位
                int phasey=floor(16*v+0.5);
                double A1,B1,C1,D1,A2,B2,C2,D2;
                A1=phase[16+phasex];
                B1=phase[phasex];
                C1=phase[16-phasex];
                D1=phase[32-phasex];
    
                A2=phase[16+phasey];
                B2=phase[phasey];
                C2=phase[16-phasey];
                D2=phase[32-phasey];
    
    
                if( !(srcx>=0 && srcx<=iWidth && srcy>=0 && srcy<=iHeight))//越界部分需拼接为外圈大视场图像,远景
                    {
    
                        srcx=(double)(newWidth/2-320+x)/(2*dbZoom);
                        srcy=(double)(newHeight/2-256+y)/(2*dbZoom) ;
                        xOr = floor(srcx);
                        yOr = floor(srcy);
                        u=srcx-xOr; 
                        v=srcy-yOr;
    
                        int phasex=floor(16*u+0.5);//16相位
                        int phasey=floor(16*v+0.5);
                        double A1,B1,C1,D1,A2,B2,C2,D2;
                        A1=phase[16+phasex];
                        B1=phase[phasex];
                        C1=phase[16-phasex];
                        D1=phase[32-phasex];
    
                        A2=phase[16+phasey];
                        B2=phase[phasey];
                        C2=phase[16-phasey];
                        D2=phase[32-phasey];
    
                        double middle=
                        pbSrc1[(yOr-1)*iWidth+(xOr-1)]*A1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr-1)]*A1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr-1)]*A1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr-1)]*A1*D2+
                        
                        pbSrc1[(yOr-1)*iWidth+(xOr)]*B1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr)]*B1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr)]*B1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr)]*B1*D2+
    
                        pbSrc1[(yOr-1)*iWidth+(xOr+1)]*C1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr+1)]*C1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr+1)]*C1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr+1)]*C1*D2+
    
                        pbSrc1[(yOr-1)*iWidth+(xOr+2)]*D1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr+2)]*D1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr+2)]*D1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr+2)]*D1*D2;
    
                    if(middle<=255&&middle>=0)
                        pbFinal[y*1280+x]=middle;
                    else if(middle>255)
                        pbFinal[y*1280+x]=255;
                    else 
                        pbFinal[y*1280+x]=0;
                        //pbFinal[y*1280+x]=255;
                    }
                else
                {   
                    double middle=
                        pbSrc2[(yOr-1)*iWidth+(xOr-1)]*A1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr-1)]*A1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr-1)]*A1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr-1)]*A1*D2+
                        
                        pbSrc2[(yOr-1)*iWidth+(xOr)]*B1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr)]*B1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr)]*B1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr)]*B1*D2+
    
                        pbSrc2[(yOr-1)*iWidth+(xOr+1)]*C1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr+1)]*C1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr+1)]*C1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr+1)]*C1*D2+
    
                        pbSrc2[(yOr-1)*iWidth+(xOr+2)]*D1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr+2)]*D1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr+2)]*D1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr+2)]*D1*D2;
    
                    if(middle<=255&&middle>=0)
                        pbFinal[y*1280+x]=middle;
                    else if(middle>255)
                        pbFinal[y*1280+x]=255;
                    else 
                        pbFinal[y*1280+x]=0;
                }
            }
        }
        return ERROR_SUCCESS;
    }
    View Code

    4、对拼接位置修正,x+6,y-3。右6,上3。

    // Imagejoint.cpp : 定义控制台应用程序的入口点。
    //
    #include "stdafx.h"
    #include "Imagejoint.h"
    #include <afxwin.h> 
    #ifdef _DEBUG
    #define new DEBUG_NEW
    #endif
    #include <atlimage.h>//CImage类
    #include <locale.h>
    #include "math.h"
    using namespace std;
    //双三次插值系数
    double fs(double w)
    {    
            double a=-0.5;
            double fs;
            if (abs(w)<=1)
                fs=(a+2)*pow(abs(w),3)-(a+3)*pow(abs(w),2)+1;
            else if (abs(w)>1&&abs(w)<=2)
                fs=a*pow(abs(w),3)-5*a*pow(abs(w),2)+8*a*abs(w)-4*a;
            else
                fs=0;
            return fs;
    }
    
    HRESULT Imagejoint(PBYTE pbSrc1,PBYTE pbSrc2,int iWidth,int iHeight,double dbZoom,PBYTE pbFinal);
    
    int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
    {
    
        int nRetCode = 0;//表示整数类型的函数返回码。n表示整数类型,Ret是Return的缩写,表示返回值,Code表示代码。
        setlocale(LC_ALL,"chs");
        HMODULE hModule = ::GetModuleHandle(NULL);
    
        if (hModule != NULL)
        {
            // initialize MFC and print and error on failure
            CImage cImage_far;
            CImage cImage_near;
    
    
            HRESULT hResult1,hResult2;
    
            //初始化一些变量
            int        iWidth,iHeight,iBytePerPixel,iPitch;
            int        x,y;
            PBYTE    pbSrc1=NULL,pbSrc2=NULL,pbFinal=NULL;//源图、目标图
            PBYTE    pbImage=NULL;//load图像后存在这
            PDWORD    pdwImage=NULL;//用于保存图像
            double    dbZoom=1.5;
    
        
            CString str = "far-frame1.bmp";
            CString str2 = "near-frame1.bmp";
            LPCTSTR filename1 = (LPCTSTR)str;
            LPCTSTR filename2 = (LPCTSTR)str2;
            do{
                if (!AfxWinInit(hModule, NULL, ::GetCommandLine(), 0))
                {
                    // TODO: change error code to suit your needs
                    _tprintf(_T("Fatal Error: MFC initialization failed
    "));
                    nRetCode = 1;
                    break;
                }
                //Load 图像到cImage对象中
                hResult1=cImage_far.Load(filename1);
                hResult2=cImage_near.Load(filename2);
                if(hResult1!=ERROR_SUCCESS||hResult2!=ERROR_SUCCESS)
                {
                    _tprintf(_T("源图像文件名错误!
    "));
                    nRetCode= -3;
                    break;
                }
                
                iWidth=cImage_far.GetWidth();
                iHeight=cImage_far.GetHeight();
                //分配源图内存
                pbSrc1 = (PBYTE)malloc(iWidth*iHeight);
                pbSrc2 = (PBYTE)malloc(iWidth*iHeight);
                pbFinal = (PBYTE)malloc(1280*1024);
            //while (dbZoom<3);
            //{
                //分配目标图内存
    
    
                if(pbSrc1==NULL||pbSrc2==NULL || pbFinal==NULL )
                {
                    _tprintf(_T("内存申请错误!
    "));
                    nRetCode= -4;
                    break;
                }
                //cImage数据存到pbImage,后再转换为源灰度图pbSrc
                iPitch=cImage_far.GetPitch();
                iBytePerPixel=(cImage_far.GetBPP()+7)/8;
                if(iBytePerPixel==3)
                {
                    for(y=0;y<iHeight;y++)
                    {   //load的图像数据放到pbImage
                        pbImage=(PBYTE)(PBYTE(cImage_far.GetBits())+iPitch*y);//得到的是图像初始像素地址
                        for(x=0;x<iWidth;x++)
                        {
                            //pbImage转换为灰度图pbSrc
                            pbSrc1[y*iWidth+x]=(pbImage[3*x]*0.15+pbImage[3*x+1]*0.55+pbImage[3*x+2]*0.3);
                        }
                    }
                }
                cImage_far.Destroy();
    
    
                iPitch=cImage_near.GetPitch();
                iBytePerPixel=(cImage_near.GetBPP()+7)/8;
                if(iBytePerPixel==3)
                {
                    for(y=0;y<iHeight;y++)
                    {   //load的图像数据放到pbImage
                        pbImage=(PBYTE)(PBYTE(cImage_near.GetBits())+iPitch*y);//得到的是图像初始像素地址
                        for(x=0;x<iWidth;x++)
                        {
                            //pbImage转换为灰度图pbSrc
                            pbSrc2[y*iWidth+x]=(pbImage[3*x]*0.15+pbImage[3*x+1]*0.55+pbImage[3*x+2]*0.3);
                        }
                    }
                }
                cImage_near.Destroy();
                //TO DO:执行操作
                hResult1=Imagejoint(pbSrc1,pbSrc2,iWidth,iHeight,dbZoom,pbFinal);
                if(hResult1!=ERROR_SUCCESS)
                {
                    _tprintf(_T("图像处理错误!
    "));
                    nRetCode= -5;
                    break;
                }
    
    
                //处理后保存图像
                iWidth=1280;
                iHeight=1024;
                cImage_far.Create(iWidth,-iHeight,32);
                iPitch=cImage_far.GetPitch();
                for(y=0;y<iHeight;y++)
                {
                    pdwImage=(PDWORD)(PBYTE(cImage_far.GetBits())+iPitch*y);
                    for(x=0;x<iWidth;x++)
                    {
                        pdwImage[x]=pbFinal[y*iWidth+x]*0x10101;  
                    }
                }
                //待保存图像文件名
                CString name1="target";
                CString name2;
                name2.Format(_T("%.2lf"),dbZoom);
    
                CString csTagName;
                csTagName=name1+name2;
                //CString csTagName="target";
                csTagName.Trim();
                csTagName.MakeUpper();
                if(csTagName.Right(4)!=_T(".BMP") ) csTagName.Append(_T(".BMP"));
                hResult1=cImage_far.Save(csTagName);
                if(hResult1!=ERROR_SUCCESS)
                {
                    _tprintf(_T("图像结果保存错误!
    "));
                    nRetCode= -5;
                    break;
                }
                _tprintf(_T("图像处理成功!
    "));
                nRetCode= ERROR_SUCCESS;
                break;
    
                //dbZoom=dbZoom+0.5;
                //}
    
            }while(0);
            if(pbSrc1) free(pbSrc1);
            if(pbSrc2) free(pbSrc2);
            if(pbFinal) free(pbFinal);
            
        }
        else
        {
            _tprintf(_T("Fatal Error: GetModuleHandle failed
    "));
            nRetCode = 1;
        }
        getchar();    
        return nRetCode;
    }
    
    HRESULT Imagejoint(PBYTE pbSrc1,PBYTE pbSrc2,int iWidth,int iHeight,double dbZoom,PBYTE pbFinal)
    {
        double phase[33]={0};//16相位,包含端点存在33个距离
        for (int i=0;i<33;i++)
        {
            double i2=1.0*i;
            phase[i]=fs(i2/16);
        }
    
        //旋转中心为图像中心
        double rx0=iWidth;  
        double ry0=iHeight; 
        double srcx,srcy,u,v;
        int xOr,yOr;
        int newWidth=ceil(dbZoom*iWidth);
        int newHeight=ceil(dbZoom*iHeight);
    
        for (int y=0;y<1024;y++)
        {
            for (int x=0;x<1280;x++)
            {
    
                srcx=(double)(newWidth/2-640+x)/dbZoom;
                srcy=(double)(newHeight/2-512+y)/dbZoom ;
                xOr = floor(srcx);
                yOr = floor(srcy);
                u=srcx-xOr;
                v=srcy-yOr;
    
                int phasex=floor(16*u+0.5);//16相位
                int phasey=floor(16*v+0.5);
                double A1,B1,C1,D1,A2,B2,C2,D2;
                A1=phase[16+phasex];
                B1=phase[phasex];
                C1=phase[16-phasex];
                D1=phase[32-phasex];
    
                A2=phase[16+phasey];
                B2=phase[phasey];
                C2=phase[16-phasey];
                D2=phase[32-phasey];
    
                //Matlab中测试获取定值(34:541 -Y,41:728 -X),需要微调。
                if( !(srcx>=41 && srcx<=720 && srcy>=34 && srcy<=541))//越界部分需拼接为外圈大视场图像,远景
                    {
    
                        srcx=(double)(newWidth-640+x)/(2*dbZoom)+6;//补偏差
                        srcy=(double)(newHeight-512+y)/(2*dbZoom)-3;
                        xOr = floor(srcx);
                        yOr = floor(srcy);
                        u=srcx-xOr; 
                        v=srcy-yOr;
    
                        int phasex=floor(16*u+0.5);//16相位
                        int phasey=floor(16*v+0.5);
                        double A1,B1,C1,D1,A2,B2,C2,D2;
                        A1=phase[16+phasex];
                        B1=phase[phasex];
                        C1=phase[16-phasex];
                        D1=phase[32-phasex];
    
                        A2=phase[16+phasey];
                        B2=phase[phasey];
                        C2=phase[16-phasey];
                        D2=phase[32-phasey];
    
                        double middle=
                        pbSrc1[(yOr-1)*iWidth+(xOr-1)]*A1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr-1)]*A1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr-1)]*A1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr-1)]*A1*D2+
                        
                        pbSrc1[(yOr-1)*iWidth+(xOr)]*B1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr)]*B1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr)]*B1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr)]*B1*D2+
    
                        pbSrc1[(yOr-1)*iWidth+(xOr+1)]*C1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr+1)]*C1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr+1)]*C1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr+1)]*C1*D2+
    
                        pbSrc1[(yOr-1)*iWidth+(xOr+2)]*D1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr+2)]*D1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr+2)]*D1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr+2)]*D1*D2;
    
                    if(middle<=255&&middle>=0)
                        pbFinal[y*1280+x]=middle;
                    else if(middle>255)
                        pbFinal[y*1280+x]=255;
                    else 
                        pbFinal[y*1280+x]=0;
                        //pbFinal[y*1280+x]=255;
                    }
                else
                {   
                    double middle=
                        pbSrc2[(yOr-1)*iWidth+(xOr-1)]*A1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr-1)]*A1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr-1)]*A1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr-1)]*A1*D2+
                        
                        pbSrc2[(yOr-1)*iWidth+(xOr)]*B1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr)]*B1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr)]*B1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr)]*B1*D2+
    
                        pbSrc2[(yOr-1)*iWidth+(xOr+1)]*C1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr+1)]*C1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr+1)]*C1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr+1)]*C1*D2+
    
                        pbSrc2[(yOr-1)*iWidth+(xOr+2)]*D1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr+2)]*D1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr+2)]*D1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr+2)]*D1*D2;
    
                    if(middle<=255&&middle>=0)
                        pbFinal[y*1280+x]=middle;
                    else if(middle>255)
                        pbFinal[y*1280+x]=255;
                    else 
                        pbFinal[y*1280+x]=0;
                }
            }
        }
        return ERROR_SUCCESS;
    }
    View Code

    5、加入dbZoom自循环。

    for(dbZoom=1.25;dbZoom<=2.25;dbZoom+=0.25)

    但要注意!由于之后有:cImage_far.Destroy();和cImage_near.Destroy();

    因此循环内应包含!CImage cImage_far;CImage cImage_near;

    // Imagejoint.cpp : 定义控制台应用程序的入口点。
    //
    #include "stdafx.h"
    #include "Imagejoint.h"
    #include <afxwin.h> 
    #ifdef _DEBUG
    #define new DEBUG_NEW
    #endif
    #include <atlimage.h>//CImage类
    #include <locale.h>
    #include "math.h"
    using namespace std;
    //双三次插值系数
    double fs(double w)
    {    
            double a=-0.5;
            double fs;
            if (abs(w)<=1)
                fs=(a+2)*pow(abs(w),3)-(a+3)*pow(abs(w),2)+1;
            else if (abs(w)>1&&abs(w)<=2)
                fs=a*pow(abs(w),3)-5*a*pow(abs(w),2)+8*a*abs(w)-4*a;
            else
                fs=0;
            return fs;
    }
    
    HRESULT Imagejoint(PBYTE pbSrc1,PBYTE pbSrc2,int iWidth,int iHeight,double dbZoom,PBYTE pbFinal);
    
    int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
    {
    
        int nRetCode = 0;//表示整数类型的函数返回码。n表示整数类型,Ret是Return的缩写,表示返回值,Code表示代码。
        setlocale(LC_ALL,"chs");
        HMODULE hModule = ::GetModuleHandle(NULL);
    
        if (hModule != NULL)
        {
    
            HRESULT hResult1,hResult2;
            //初始化一些变量
            int        iWidth,iHeight,iBytePerPixel,iPitch;
            int        x,y;
            PBYTE    pbSrc1=NULL,pbSrc2=NULL,pbFinal=NULL;//源图、目标图
            PBYTE    pbImage=NULL;//load图像后存在这
            PDWORD    pdwImage=NULL;//用于保存图像
            double    dbZoom=1.25;
    
            for(dbZoom=1.25;dbZoom<=2.25;dbZoom+=0.25)
            {
                CImage cImage_far;
                CImage cImage_near;
        
                CString str = "far-frame1.bmp";
                CString str2 = "near-frame1.bmp";
                LPCTSTR filename1 = (LPCTSTR)str;
                LPCTSTR filename2 = (LPCTSTR)str2;
      
                if (!AfxWinInit(hModule, NULL, ::GetCommandLine(), 0))
                {
                    // TODO: change error code to suit your needs
                    _tprintf(_T("Fatal Error: MFC initialization failed
    "));
                    nRetCode = 1;
                    
                }
                //Load 图像到cImage对象中
                hResult1=cImage_far.Load(filename1);
                hResult2=cImage_near.Load(filename2);
                if(hResult1!=ERROR_SUCCESS||hResult2!=ERROR_SUCCESS)
                {
                    _tprintf(_T("源图像文件名错误!
    "));
                    nRetCode= -3;
                  
                }
                
                iWidth=cImage_far.GetWidth();
                iHeight=cImage_far.GetHeight();
                //分配源图内存
                pbSrc1 = (PBYTE)malloc(iWidth*iHeight);
                pbSrc2 = (PBYTE)malloc(iWidth*iHeight);
                //分配目标图内存
                pbFinal = (PBYTE)malloc(1280*1024);
                if(pbSrc1==NULL||pbSrc2==NULL || pbFinal==NULL )
                {
                    _tprintf(_T("内存申请错误!
    "));
                    nRetCode= -4;
                   
                }
                //cImage数据存到pbImage,后再转换为源灰度图pbSrc
                iPitch=cImage_far.GetPitch();
                iBytePerPixel=(cImage_far.GetBPP()+7)/8;
                if(iBytePerPixel==3)
                {
                    for(y=0;y<iHeight;y++)
                    {   //load的图像数据放到pbImage
                        pbImage=(PBYTE)(PBYTE(cImage_far.GetBits())+iPitch*y);//得到的是图像初始像素地址
                        for(x=0;x<iWidth;x++)
                        {
                            //pbImage转换为灰度图pbSrc
                            pbSrc1[y*iWidth+x]=(pbImage[3*x]*0.15+pbImage[3*x+1]*0.55+pbImage[3*x+2]*0.3);
                        }
                    }
                }
                cImage_far.Destroy();
    
                iPitch=cImage_near.GetPitch();
                iBytePerPixel=(cImage_near.GetBPP()+7)/8;
                if(iBytePerPixel==3)
                {
                    for(y=0;y<iHeight;y++)
                    {   //load的图像数据放到pbImage
                        pbImage=(PBYTE)(PBYTE(cImage_near.GetBits())+iPitch*y);//得到的是图像初始像素地址
                        for(x=0;x<iWidth;x++)
                        {
                            //pbImage转换为灰度图pbSrc
                            pbSrc2[y*iWidth+x]=(pbImage[3*x]*0.15+pbImage[3*x+1]*0.55+pbImage[3*x+2]*0.3);
                        }
                    }
                }
                cImage_near.Destroy();
    
                //执行操作
                hResult1=Imagejoint(pbSrc1,pbSrc2,iWidth,iHeight,dbZoom,pbFinal);
                if(hResult1!=ERROR_SUCCESS)
                {
                    _tprintf(_T("图像处理错误!
    "));
                    nRetCode= -5;
                   
                }
                //处理后保存图像
                iWidth=1280;
                iHeight=1024;
                cImage_far.Create(iWidth,-iHeight,32);
                iPitch=cImage_far.GetPitch();
                for(y=0;y<iHeight;y++)
                {
                    pdwImage=(PDWORD)(PBYTE(cImage_far.GetBits())+iPitch*y);
                    for(x=0;x<iWidth;x++)
                    {
                        pdwImage[x]=pbFinal[y*iWidth+x]*0x10101;  
                    }
                }
                //可预存待保存图像文件名
                CString name1="target";
                CString name2;
                name2.Format(_T("%.2lf"),dbZoom);
                CString csTagName;
                csTagName=name1+name2;
                
                csTagName.Trim();
                csTagName.MakeUpper();
                if(csTagName.Right(4)!=_T(".BMP") ) csTagName.Append(_T(".BMP"));
                hResult1=cImage_far.Save(csTagName);
                if(hResult1!=ERROR_SUCCESS)
                {
                    _tprintf(_T("图像结果保存错误!
    "));
                    nRetCode= -5;
                   
                }
                _tprintf(_T("图像处理成功!
    "));
                nRetCode= ERROR_SUCCESS;
    
                if(pbSrc1) free(pbSrc1);
                if(pbSrc2) free(pbSrc2);
                if(pbFinal) free(pbFinal);
            }//对应+=0.25倍数的for循环。
    
        }
        else
        {
            _tprintf(_T("Fatal Error: GetModuleHandle failed
    "));
            nRetCode = 1;
        }
        getchar();    
        return nRetCode;
    }
    
    HRESULT Imagejoint(PBYTE pbSrc1,PBYTE pbSrc2,int iWidth,int iHeight,double dbZoom,PBYTE pbFinal)
    {
        double phase[33]={0};//16相位,包含端点存在33个距离
        for (int i=0;i<33;i++)
        {
            double i2=1.0*i;
            phase[i]=fs(i2/16);
        }
    
        //旋转中心为图像中心
        double rx0=iWidth;  
        double ry0=iHeight; 
        double srcx,srcy,u,v;
        int xOr,yOr;
        int newWidth=ceil(dbZoom*iWidth);
        int newHeight=ceil(dbZoom*iHeight);
    
        for (int y=0;y<1024;y++)
        {
            for (int x=0;x<1280;x++)
            {
    
                srcx=(double)(newWidth/2-640+x)/dbZoom;
                srcy=(double)(newHeight/2-512+y)/dbZoom ;
                xOr = floor(srcx);
                yOr = floor(srcy);
                u=srcx-xOr;
                v=srcy-yOr;
    
                int phasex=floor(16*u+0.5);//16相位
                int phasey=floor(16*v+0.5);
                double A1,B1,C1,D1,A2,B2,C2,D2;
                A1=phase[16+phasex];
                B1=phase[phasex];
                C1=phase[16-phasex];
                D1=phase[32-phasex];
    
                A2=phase[16+phasey];
                B2=phase[phasey];
                C2=phase[16-phasey];
                D2=phase[32-phasey];
    
                //Matlab中测试获取定值(34:541 -Y,41:728 -X),需要微调。
                if( !(srcx>=41 && srcx<=720 && srcy>=34 && srcy<=541))//越界部分需拼接为外圈大视场图像,远景
                    {
    
                        srcx=(double)(newWidth-640+x)/(2*dbZoom)+6;//补偏差
                        srcy=(double)(newHeight-512+y)/(2*dbZoom)-3;
                        xOr = floor(srcx);
                        yOr = floor(srcy);
                        u=srcx-xOr; 
                        v=srcy-yOr;
    
                        int phasex=floor(16*u+0.5);//16相位
                        int phasey=floor(16*v+0.5);
                        double A1,B1,C1,D1,A2,B2,C2,D2;
                        A1=phase[16+phasex];
                        B1=phase[phasex];
                        C1=phase[16-phasex];
                        D1=phase[32-phasex];
    
                        A2=phase[16+phasey];
                        B2=phase[phasey];
                        C2=phase[16-phasey];
                        D2=phase[32-phasey];
    
                        double middle=
                        pbSrc1[(yOr-1)*iWidth+(xOr-1)]*A1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr-1)]*A1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr-1)]*A1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr-1)]*A1*D2+
                        
                        pbSrc1[(yOr-1)*iWidth+(xOr)]*B1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr)]*B1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr)]*B1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr)]*B1*D2+
    
                        pbSrc1[(yOr-1)*iWidth+(xOr+1)]*C1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr+1)]*C1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr+1)]*C1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr+1)]*C1*D2+
    
                        pbSrc1[(yOr-1)*iWidth+(xOr+2)]*D1*A2+
                        pbSrc1[(yOr)*iWidth+(xOr+2)]*D1*B2+
                        pbSrc1[(yOr+1)*iWidth+(xOr+2)]*D1*C2+
                        pbSrc1[(yOr+2)*iWidth+(xOr+2)]*D1*D2;
    
                    if(middle<=255&&middle>=0)
                        pbFinal[y*1280+x]=middle;
                    else if(middle>255)
                        pbFinal[y*1280+x]=255;
                    else 
                        pbFinal[y*1280+x]=0;
                        //pbFinal[y*1280+x]=255;
                    }
                else
                {   
                    double middle=
                        pbSrc2[(yOr-1)*iWidth+(xOr-1)]*A1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr-1)]*A1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr-1)]*A1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr-1)]*A1*D2+
                        
                        pbSrc2[(yOr-1)*iWidth+(xOr)]*B1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr)]*B1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr)]*B1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr)]*B1*D2+
    
                        pbSrc2[(yOr-1)*iWidth+(xOr+1)]*C1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr+1)]*C1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr+1)]*C1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr+1)]*C1*D2+
    
                        pbSrc2[(yOr-1)*iWidth+(xOr+2)]*D1*A2+
                        pbSrc2[(yOr)*iWidth+(xOr+2)]*D1*B2+
                        pbSrc2[(yOr+1)*iWidth+(xOr+2)]*D1*C2+
                        pbSrc2[(yOr+2)*iWidth+(xOr+2)]*D1*D2;
    
                    if(middle<=255&&middle>=0)
                        pbFinal[y*1280+x]=middle;
                    else if(middle>255)
                        pbFinal[y*1280+x]=255;
                    else 
                        pbFinal[y*1280+x]=0;
                }
            }
        }
        return ERROR_SUCCESS;
    }
    View Code

    至此,基本完成效果仿真。

    但目前只是针对图像的。下面考虑如何读取.avi格式的视频文件处理。

  • 相关阅读:
    P1631-序列合并
    P1484-种树
    17.树的子结构(python)
    16.合并两个排序的链表(python)
    反转链表
    链表中倒数第k个节点(python)
    调整数组顺序使奇数位于偶数前面(python)
    Spark--wordcount(词频降序)
    数值的整数次方
    二进制中1的个数(python)
  • 原文地址:https://www.cnblogs.com/wxl845235800/p/11162450.html
Copyright © 2011-2022 走看看