ArcGIS Engine基础(15)之创建栅格数据集(IRasterDataset)

        /// <summary>
        /// 创建RasterDataset数据集
        /// </summary>
        /// <param name="pWs">打开的工作空间</param>
        /// <param name="sDatasetName">Dataset的名字</param>
        /// <param name="iBands">波段值</param>
        /// <param name="iPixelType">Pixel Type</param>
        /// <param name="iCellSizeX">X CellSize</param>
        /// <param name="iCellSizeY">Y CellSize</param>
        /// <param name="pSR">坐标参考系</param>
        /// <param name="iPyramid">金字塔值</param>
        /// <param name="iType">压缩算法</param>
        /// <param name="sKeyword"></param>
        /// <param name="iCompressRate">压缩比例</param>
        /// <returns>返回创建的数据集</returns>
        public static IRasterDataset CreateNewRasterDataset(IRasterWorkspaceEx pWs, string sDatasetName, int iBands, int iPixelType, int iCellSizeX, int iCellSizeY, ISpatialReference pSR, int iPyramid, int iType, string sKeyword, int iCompressRate) {
            IRasterDef rasterDef = createRasterDef(false, pSR);
            IRasterStorageDef rasterStoreDef = createRasterStorageDef(iPyramid, iType, iCompressRate, iCellSizeX, iCellSizeY);
            // Bug Fix:下面这句会引发错误,暂时屏蔽掉
            //IGeometryDef geoDef = createGeoDefds(pSR);
            IGeometryDef geoDef = null;

            if (sKeyword == null)
                sKeyword = "defaults";

            IRasterDataset pRasterDataset = null;

            try {
                pRasterDataset = pWs.CreateRasterDataset(sDatasetName, iBands,
                    (rstPixelType)iPixelType, rasterStoreDef, sKeyword, rasterDef, geoDef);
            }
            catch {
                throw;
            }

            return pRasterDataset;
        }

       private static IRasterStorageDef createRasterStorageDef(int iPyramid, int iType, int iCompressRate, int iCellSizeX, int iCellSizeY) {
            IRasterStorageDef pRasterStorageDef = new RasterStorageDefClass();
            pRasterStorageDef.CompressionQuality = iCompressRate;
            pRasterStorageDef.CompressionType = (esriRasterCompressionType)iType;
            pRasterStorageDef.PyramidResampleType = rstResamplingTypes.RSP_NearestNeighbor;
            pRasterStorageDef.PyramidLevel = iPyramid;
            pRasterStorageDef.TileHeight = 128;
            pRasterStorageDef.TileWidth = 128;
            if (iCellSizeX > 0 && iCellSizeY > 0) {
                IPnt pntCellSize = new ESRI.ArcGIS.DataSourcesRaster.DblPntClass();
                pntCellSize.SetCoords(iCellSizeX, iCellSizeY);
                pRasterStorageDef.CellSize = pntCellSize;
            }

            return pRasterStorageDef;
        }

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xizhjxust_GIS

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值