zoukankan      html  css  js  c++  java
  • 镶嵌数据集添加过滤

    public static List<ILayer> LoadGdbRasterLayer(string dataYear, List<string> regionCodes)
    {
    string gdbPath = AppConfig.MapMineThemePicPath;
    if (!Directory.Exists(gdbPath)) return null;
    List<ILayer> allLayer = new List<ILayer>();
    try
    {
    IWorkspaceFactory gdbWorkspaceFactory = new FileGDBWorkspaceFactoryClass();
    IWorkspace pWorkspace = gdbWorkspaceFactory.OpenFromFile(gdbPath, 0);
    IEnumDataset pEnumDataset = pWorkspace.get_Datasets(esriDatasetType.esriDTAny);
    pEnumDataset.Reset();
    IDataset pDataset = pEnumDataset.Next();
    while (pDataset != null)
    {
    if (pDataset is IRasterDataset) //栅格数据集
    {

    if (!(pDataset.Name.Contains(dataYear.Trim())))
    {
    pDataset = pEnumDataset.Next();
    continue;
    }
    IRasterWorkspaceEx pRasterWorkspace = (IRasterWorkspaceEx)pWorkspace;
    IRasterDataset pRasterDataset = pRasterWorkspace.OpenRasterDataset(pDataset.Name);
    //影像金字塔判断与创建
    IRasterPyramid3 pRasPyrmid;
    pRasPyrmid = pRasterDataset as IRasterPyramid3;
    if (pRasPyrmid != null)
    {
    if (!pRasPyrmid.Present)
    {
    pRasPyrmid.Create(); //创建金字塔
    }
    }

    ILayer mosaicLayer = RasterFilter(pWorkspace, pDataset.Name) as ILayer;
    allLayer.Add(mosaicLayer);
    }
    pDataset = pEnumDataset.Next();
    }
    return allLayer;
    }
    catch (Exception e)
    {
    Console.WriteLine(e);
    return null;
    }
    }

    /// <summary>
    /// 过滤图层显示内容
    /// </summary>
    private static IMosaicLayer RasterFilter(IWorkspace fgdbWorkspace, string CurrentMosaicDsName)
    {

    IMosaicDataset mosaicDataset = GetMosaicDataset(fgdbWorkspace, CurrentMosaicDsName);
    IMosaicLayer pmoslyr = new MosaicLayerClass();
    pmoslyr.CreateFromMosaicDataset(mosaicDataset);
    ITableDefinition pTbldef = pmoslyr as ITableDefinition;
    pTbldef.DefinitionExpression = StageHelper.CurrentDataParams.ToRasterFilterSql(); //Query Expression
    pmoslyr.FootprintLayer.Visible = false;
    return pmoslyr;
    }


    public static IMosaicDataset GetMosaicDataset(IWorkspace fgdbWorkspace, string CurrentMosaicDsName)
    {

    IMosaicWorkspaceExtensionHelper mosaicExtHelper = new MosaicWorkspaceExtensionHelperClass();
    //根据扩展选择合适的工作空间
    IMosaicWorkspaceExtension mosaicExt = mosaicExtHelper.FindExtension(fgdbWorkspace);
    //使用IMosaicWorkspaceExtension接口和ICreateMosaicDatasetParameters参数来创建镶嵌数据集
    IMosaicDataset theMosaicDataset = null;
    try
    {
    theMosaicDataset = mosaicExt.OpenMosaicDataset(CurrentMosaicDsName);
    }
    catch (Exception ex)
    {
    Commons.PublicMethods.CommonMethod.AbnormalLog(ex);
    }
    return theMosaicDataset;
    }

  • 相关阅读:
    MySql状态查看方法 MySql如何查看连接数和状态?
    MySQL连接数超过限制的解决方法
    JS正则表达式获取分组内容实例
    jquery data方法获取某个元素上事件
    javascript浮点数转换成整数三种方法
    ThinkPHP CURD方法中field方法详解
    python3.3使用tkinter实现猜数字游戏代码
    Expo大作战(二十四)--expo sdk api之Accelerometer
    Expo大作战(二十三)--expo中expo kit 高级属性(没干货)
    Expo大作战(二十二)--expo分离后的部署(expokit)
  • 原文地址:https://www.cnblogs.com/liuyongpingblog/p/7605324.html
Copyright © 2011-2022 走看看