zoukankan      html  css  js  c++  java
  • [Gdaldev]用GCPs纠正影像的一些资源

    从GDAL邮件列表中收集的一些资料.

    [Gdal-dev] How to correct use GDALGCPTransform

    Ivan Mjartan ivan.mjartan at geovap.cz
    Wed Jul 25 03:30:53 EDT 2007

    Hi list,

    So I have scan of raster without georeference and I need make geo
    position of this raster into SJTSK coordinate (*EPSG:102067*). I need do it
    on the fly. So I am trying use GDALCreateGCPTransformer.

    My input is raster it can be tiff, bitmap, jpg and so on . output can be
    Geotiff

    In my test I use polynomial order 1 and 3 GCPs points.

    I followed tutorial on GDAL库 page. But I am not success I am doing something
    wrong and I not able find right way.

    In the beginning I created blank dataset to get GeoTransform and output size
    of image like in gedalwarp.exe it is correct and I get black Geotiff and
    coordinate and size is correct. (The same when I use gedal_translate.exe to
    set GCPs and than gdalwarp to warp image). But when try use
    ChunkAndWarpImage with same Transformer the output image is still blank. So
    I also tried debug this method and I find that inside this method is used
    WarpRegion Method but there was wrong parameters of destination image. So I
    try use WarpRegion directly without success L

    I thing that I am wrong using GCPTransformer I thing that I have to set
    something in GDALWarpOptions but what? This is for me big mystery. I was
    looking on internet but there is nothing L

    Can I see some sample of using GCPTransformer ?

    May be I can use GenImgProjTransformer but I don't know how to set GCPs with
    out prior transform to Gtiff set GCPs and saving to Disk. (Input rasters can
    be jpg bitmap .)


    So like input I used this image http://80.188.225.114/temp/input.tif I am using GDAL库 1.4.2
    Thanks a lot for your help

    Ivan Mjartan

    the code looks like follow:
    Method to get destination dataset

    GDALDatasetH GDALWarpCreateOutput( char *papszSrcFiles,char *pszFilename,
    const char *pszFormat,GDAL_GCP pasGCPList[3],int
    nReqOrder,int bReversed,int nGCPCount)
    {

    GDALDriverH hDriver;

    GDALDatasetH hDstDS;

    void *hTransformArg;

    GDALColorTableH hCT = NULL;

    int nDstBandCount = 0;

    GDALDataType eDT;

    int nOrder = 1;

    hDriver = GDALGetDriverByName( pszFormat );

    GDALDatasetH hSrcDS;

    hSrcDS = GDALOpen( papszSrcFiles, GA_ReadOnly );

    if( hSrcDS == NULL )

    exit( 1 );

    eDT = GDALGetRasterDataType(GDALGetRasterBand(hSrcDS,1));

    nDstBandCount = GDALGetRasterCount(hSrcDS);

    hCT = GDALGetRasterColorTable( GDALGetRasterBand(hSrcDS,1) );

    if( hCT != NULL )
    {
    hCT = GDALCloneColorTable( hCT );
    }

    hTransformArg = GDALCreateGCPTransformer (

    nGCPCount,

    pasGCPList,

    nReqOrder,

    bReversed

    );


    if( hTransformArg == NULL )

    return NULL;


    double adfThisGeoTransform[6];

    int nThisPixels, nThisLines;
    CPLErr eErr;
    eErr = GDALSuggestedWarpOutput( hSrcDS,GDALGCPTransform,
    hTransformArg,adfThisGeoTransform,&nThisPixels, &nThisLines);


    /*if (eErr == CE_None)

    {

    return NULL;

    }*/



    GDALDestroyGCPTransformer(hTransformArg);



    GDALClose( hSrcDS );


    hDstDS = GDALCreate( hDriver, pszFilename,
    nThisPixels, nThisLines,

    nDstBandCount, eDT, NULL);



    if( hDstDS == NULL )

    return NULL;



    GDALSetProjection( hDstDS, "");

    GDALSetGeoTransform( hDstDS, adfThisGeoTransform );



    if( hCT != NULL )

    {

    GDALSetRasterColorTable(
    GDALGetRasterBand(hDstDS,1), hCT );

    GDALDestroyColorTable( hCT );

    }

    return hDstDS;

    }


    and my main method looks:


    int main( int argc, char ** argv )
    {

    GDALDatasetH hDstDS;

    const char *pszFormat = "GTiff";

    void *hTransformArg;

    int i;



    GDALDataType eOutputType = GDT_Unknown, eWorkingType =
    GDT_Unknown;

    GDALResampleAlg eResampleAlg = GRA_NearestNeighbour;



    char **papszWarpOptions = NULL;

    //moje definice



    char *pszSrcFilename = NULL;

    char *pszDstFilename = NULL;

    GDAL_GCP pasGCPList[3];



    int nReqOrder = 1;

    int bReversed = 0;

    int nGCPCount = 3;



    /* -------------------------------------------------------------------- */

    /* input and output rasters */

    /* -------------------------------------------------------------------- */

    //pszSrcFilename =
    CPLStrdup("c:\\Projects\\GDAL\\gdal142\\gedalwarp\\gedalwarp\\Debug\\out_beroGCP.tif");

    //pszSrcFilename =
    CPLStrdup("c:\\Projects\\GDAL\\gdal142\\gedalwarp\\gedalwarp\\Debug\\21.tif");

    pszSrcFilename =
    CPLStrdup("c:\\Projects\\GDAL\\gdal142\\gedalwarp\\gedalwarp\\Debug\\21.tif");

    pszDstFilename =
    CPLStrdup("c:\\Projects\\GDAL\\gdal142\\gedalwarp\\gedalwarp\\Debug\\out_r.tif");



    GDALAllRegister();


    //gcplist

    pasGCPList[0].dfGCPPixel = 0;

    pasGCPList[0].dfGCPLine = 0;

    pasGCPList[0].dfGCPX = -863909;

    pasGCPList[0].dfGCPY = -993283;

    pasGCPList[0].dfGCPZ = 0;

    pasGCPList[0].pszId = "1";

    pasGCPList[0].pszInfo = "info 1";



    pasGCPList[1].dfGCPPixel = 0;

    pasGCPList[1].dfGCPLine = 3403;

    pasGCPList[1].dfGCPX = -863909;

    pasGCPList[1].dfGCPY = -1024899;

    pasGCPList[1].dfGCPZ = 0;

    pasGCPList[1].pszId = "2";

    pasGCPList[1].pszInfo = "info 2";



    pasGCPList[2].dfGCPPixel = 3800;

    pasGCPList[2].dfGCPLine = 3403;

    pasGCPList[2].dfGCPX = -809988;

    pasGCPList[2].dfGCPY = -1024899;

    pasGCPList[2].dfGCPZ = 0;

    pasGCPList[2].pszId = "3";

    pasGCPList[2].pszInfo = "info 3";



    hDstDS = GDALWarpCreateOutput( pszSrcFilename,
    pszDstFilename,pszFormat,pasGCPList,nReqOrder,bReversed,nGCPCount);



    if( hDstDS == NULL )

    exit( 1 );



    GDALDatasetH hSrcDS;



    hSrcDS = GDALOpen(pszSrcFilename, GA_ReadOnly );



    if( hSrcDS == NULL )

    exit( 2 );



    /* -------------------------------------------------------------------- */

    /* Create a transformation object */

    /* -------------------------------------------------------------------- */

    hTransformArg = GDALCreateGCPTransformer (

    nGCPCount,

    pasGCPList,

    nReqOrder,

    bReversed

    );



    if( hTransformArg == NULL )

    return NULL;



    /* -------------------------------------------------------------------- */

    /* Setup warp options. */

    /* -------------------------------------------------------------------- */

    GDALWarpOptions *psWO = GDALCreateWarpOptions();

    psWO->pfnProgress = GDALTermProgress;

    psWO->eWorkingDataType =
    GDALGetRasterDataType(GDALGetRasterBand(hSrcDS,1));

    //psWO->eResampleAlg = eResampleAlg;



    psWO->hSrcDS = hSrcDS;

    psWO->hDstDS = hDstDS;



    psWO->pfnTransformer = GDALGCPTransform;

    psWO->pTransformerArg = hTransformArg;



    /* -------------------------------------------------------------------- */

    /* Setup band mapping. */

    /* -------------------------------------------------------------------- */



    psWO->nBandCount = GDALGetRasterCount(hSrcDS);



    psWO->panSrcBands = (int *) CPLMalloc(psWO->nBandCount*sizeof(int));

    psWO->panDstBands = (int *) CPLMalloc(psWO->nBandCount*sizeof(int));



    for( i = 0; i < psWO->nBandCount; i++ )

    {

    psWO->panSrcBands[i] = i+1;

    psWO->panDstBands[i] = i+1;

    }



    /* -------------------------------------------------------------------- */

    /* Initialize and execute the warp. */

    /* -------------------------------------------------------------------- */

    GDALWarpOperation oWO;



    if( oWO.Initialize( psWO ) == CE_None )

    {

    //if (oWO.ChunkAndWarpImage( 0, 0,
    GDALGetRasterXSize( hDstDS ),GDALGetRasterYSize( hDstDS ) )==CE_Failure){

    //printf("Error");


    //}

    oWO.WarpRegion( 0, 0,
    GDALGetRasterXSize( hDstDS ),GDALGetRasterYSize( hDstDS ),0, 0,
    GDALGetRasterXSize( hSrcDS ),GDALGetRasterYSize( hSrcDS ));

    }



    /* -------------------------------------------------------------------- */

    /* Cleanup */

    /* -------------------------------------------------------------------- */


    if( hTransformArg != NULL ){

    GDALDestroyGCPTransformer(
    hTransformArg );

    }

    GDALClose( hDstDS );

    GDALClose( hSrcDS );

    GDALDestroyWarpOptions( psWO );

    GDALDestroyDriverManager();

    return 0;

    }



    More information about the Gdal-dev mailing list

    [Gdal-dev] How to correct use GDALGCPTransform

    Frank Warmerdam warmerdam at pobox.com
    Wed Jul 25 09:46:04 EDT 2007
    Ivan Mjartan wrote:
    > I thing that I am wrong using GCPTransformer I thing that I have to set
    > something in GDALWarpOptions but what? This is for me big mystery. I was
    > looking on internet but there is nothing L
    >
    > Can I see some sample of using GCPTransformer ?
    >
    > May be I can use GenImgProjTransformer but I don't know how to set GCPs
    > with out prior transform to Gtiff set GCPs and saving to Disk. (Input
    > rasters can be jpg bitmap .)

    Ivan,

    I believe your problem is that the warper needs a transformer that goes
    from input pixel/line coordinates to destination pixel/line coordinates (and
    the reverse). But the GDALGCPTransformer only does source pixel/line to
    source georeferenced coordinates. If you look at GenImgProjTransform() in
    GDAL库/alg/gdaltransformer.cpp you may note it actually performs several steps.
    One from source pixel/line to source georef. Then potentially reproject
    to destination pixel/line. Then dest georef to dest pixel/line.

    You could implement your own similar transformer somewhat similar to
    GDALGenImgProjTransform, but I think the easier way is just to associate
    the GCPs with the source image. If it is impractical to write the image
    to a new TIFF file with gdal_translate, and with the GCPs associated, then
    another approach without intermediate files would be to create an in-memory
    VRT dataset using GDALCreateCopy() from the source image, and then call
    SetGCPs() on that VRT dataset.

    Then use the VRT as an input with the GenImgProj transformer.

    BTW, to avoid having a VRT written to disk, just use the filename "" for
    it when calling CreateCopy().

    BTW, the way you included your code (tab expansion, extra blank lines)
    made it nearly unreadable.

    Good work on all you have already learned about the warper!

    Best regards,
    --
    ---------------------------------------+--------------------------------------
    I set the clouds in motion - turn up | Frank Warmerdam, warmerdam at pobox.com
    light and sound - activate the windows | http://pobox.com/~warmerdam
    and watch the world go round - Rush | President OSGeo, http://osgeo.org



    More information about the Gdal-dev mailing list

  • 相关阅读:
    uva10256
    uva11168
    zoj2318
    hdu6121
    hdu6127
    bzoj3957: [WF2011]To Add or to Multiply
    bzoj4377: [POI2015]Kurs szybkiego czytania
    bzoj3137: [Baltic2013]tracks
    bzoj4069: [Apio2015]巴厘岛的雕塑
    bzoj4169: Lmc的游戏
  • 原文地址:https://www.cnblogs.com/flyingfish/p/889201.html
Copyright © 2011-2022 走看看