本文整理汇总了C#中IRaster.ContainsFeature方法的典型用法代码示例。如果您正苦于以下问题:C# IRaster.ContainsFeature方法的具体用法?C# IRaster.ContainsFeature怎么用?C# IRaster.ContainsFeature使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类IRaster
的用法示例。
在下文中一共展示了IRaster.ContainsFeature方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ClipRasterWithPolygon
/// <summary>
/// Clips a raster with a polygon feature
/// </summary>
/// <param name="polygon">The clipping polygon feature</param>
/// <param name="input">The input raster object</param>
/// <param name="outputFileName">the output raster file name</param>
/// <param name="cancelProgressHandler">Progress handler for reporting progress status and cancelling the operation</param>
/// <remarks>We assume there is only one part in the polygon.
/// Traverses the raster with a vertical scan line from left to right, bottom to top</remarks>
/// <returns></returns>
public static IRaster ClipRasterWithPolygon(IFeature polygon, IRaster input, string outputFileName,
ICancelProgressHandler cancelProgressHandler = null)
{
//if the polygon is completely outside the raster
if (!input.ContainsFeature(polygon))
return input;
if (cancelProgressHandler != null)
cancelProgressHandler.Progress(null, 16, "Retrieving the borders.");
List<Border> borders = GetBorders(polygon);
if (cancelProgressHandler != null)
cancelProgressHandler.Progress(null, 33, "Copying raster.");
//create output raster
IRaster output = Raster.CreateRaster(outputFileName, input.DriverCode, input.NumColumns, input.NumRows, 1,
input.DataType, new[] { string.Empty });
output.Bounds = input.Bounds.Copy();
output.NoDataValue = input.NoDataValue;
if (input.CanReproject)
{
output.Projection = input.Projection;
}
// set all initial values of Output to NoData
for (int i = 0; i < output.NumRows; i++)
{
for (int j = 0; j < output.NumColumns; j++)
{
output.Value[i, j] = output.NoDataValue;
}
}
double xStart = GetXStart(polygon, output);
int columnStart = GetStartColumn(polygon, output); //get the index of first column
double xCurrent = xStart;
ProgressMeter pm = new ProgressMeter(cancelProgressHandler, "Clipping Raster", output.NumColumns);
pm.StepPercent = 5;
pm.StartValue = 33;
int col = 0;
for (int columnCurrent = columnStart; columnCurrent < output.NumColumns; columnCurrent++)
{
xCurrent = xStart + col * output.CellWidth;
var intersections = GetYIntersections(borders, xCurrent);
intersections.Sort();
ParseIntersections(intersections, xCurrent, columnCurrent, output, input);
// update progess meter
pm.CurrentValue = xCurrent;
//update counter
col++;
// cancel if requested
if (cancelProgressHandler != null && cancelProgressHandler.Cancel)
return null;
}
output.Save();
return output;
}