JAVA根据像素点换算坐标系

JAVA根据tiff图像提供对应的像素点换算对应坐标系

       需要引用的pom依赖:

        <!--geotools依赖包-->
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-geotiff</artifactId>
            <version>19.2</version>
        </dependency>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-image</artifactId>
            <version>19.2</version>
        </dependency>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-imagemosaic</artifactId>
            <version>19.2</version>
        </dependency>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-render</artifactId>
            <version>19.2</version>
        </dependency>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-imageio-ext-gdal</artifactId>
            <version>19.2</version>
        </dependency>

         代码如下:


import org.gdal.gdal.Dataset;
import org.gdal.gdal.gdal;
import org.gdal.gdalconst.gdalconstConstants;



public class MyTest4 {

    /**
     * 必须注册
     */
    static {
        gdal.AllRegister();
    }

    private static final String FILE_PATH = "C:\\images\\test.tiff";

@Test
    public void readTif() {
        Dataset dataset = gdal.Open(MyTest4.FILE_PATH, gdalconstConstants.GA_ReadOnly);
        //获取到六参数数组
        double[] ori_transform = dataset.GetGeoTransform();

    // 已知的像素点坐标 (x, y)
    double pixelX = 6136.57523839107; // 示例像素X坐标
    double pixelY = 16106.60091191435; // 示例像素Y坐标

    // 应用GeoTransform进行坐标转换
    double geoX = ori_transform[0] + pixelX * ori_transform[1] + pixelY * ori_transform[2];
    double geoY = ori_transform[3] + pixelX * ori_transform[4] + pixelY * ori_transform[5];
    // 输出转换后的地理坐标(经纬度)
    System.out.println("像素坐标 (" + pixelX + ", " + pixelY + ") 对应的地理坐标为 (" + geoX + ", " + geoY + ")");

}

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为了将像素坐标换为世界坐标系,需要进行相机标定。相机标定是指确定相机的内部参数和外部参数,以便将像素坐标系中的点换为世界坐标系中的点。在Matlab中,可以使用以下步骤进行相机标定和像素坐标系到世界坐标系的换: 1.采集一组已知的三维点和它们在图像中的对应二维点,这些点应该分布在整个图像中,并且应该包括不同深度的点。 2.使用Matlab中的Camera Calibrator App进行相机标定。在该应用程序中,可以导入采集的图像并选择标定模板。然后,应用程序将自动检测标定板并计算相机的内部参数和外部参数。 3.使用Matlab中的undistortImage函数将图像畸变校正。该函数需要相机的内部参数和畸变系数作为输入。 4.使用Matlab中的extrinsics函数将相机的外部参数换为旋矩阵和平移向量。 5.使用Matlab中的projectPoints函数将像素坐标系中的点换为世界坐标系中的点。该函数需要相机的内部参数、旋矩阵、平移向量和像素坐标系中的点作为输入。 下面是一个Matlab代码示例,用于将像素坐标系中的点换为世界坐标系中的点: ```matlab % 相机标定 [imagePoints, boardSize] = detectCheckerboardPoints(imageFileNames); worldPoints = generateCheckerboardPoints(boardSize, squareSize); cameraParams = estimateCameraParameters(imagePoints, worldPoints); % 畸变校正 I = imread('image.jpg'); undistortedImage = undistortImage(I, cameraParams); % 外部参数换 [R, t] = extrinsics(imagePoints, worldPoints, cameraParams); % 像素坐标换为世界坐标系 imagePoints = [x, y]; worldPoints = projectPoints(imagePoints, R, t, cameraParams); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值