本文整理汇总了C#中PolylineClass类的典型用法代码示例。如果您正苦于以下问题:C# PolylineClass类的具体用法?C# PolylineClass怎么用?C# PolylineClass使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
PolylineClass类属于命名空间,在下文中一共展示了PolylineClass类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: GetGeometry
private IGeometry GetGeometry(IGeometry baseGeometry)
{
IGeometry geometry;
IPolyline polyline = new PolylineClass();
polyline.SpatialReference = baseGeometry.SpatialReference;
geometry = polyline as IGeometry;
IPointCollection targetPointCollection = geometry as IPointCollection;
IPointCollection basePointCollection = baseGeometry as IPointCollection;
object missing = Type.Missing;
for (int i = 0; i < basePointCollection.PointCount; i++)
{
targetPointCollection.AddPoint(basePointCollection.get_Point(i), ref missing, ref missing);
}
MakeZAware(geometry);
return geometry;
}
示例2: GetExample2
public static IGeometry GetExample2()
{
const double FromZ = -0.1;
const double ToZ = -8;
//Extrusion: Multiple Point 2D Polyline Extruded To Generate 3D Wall Via ConstructExtrudeFromTo()
IPointCollection polylinePointCollection = new PolylineClass();
polylinePointCollection.AddPoint(GeometryUtilities.ConstructPoint2D(-10, -10), ref _missing, ref _missing);
polylinePointCollection.AddPoint(GeometryUtilities.ConstructPoint2D(-8, -7), ref _missing, ref _missing);
polylinePointCollection.AddPoint(GeometryUtilities.ConstructPoint2D(-5, -5), ref _missing, ref _missing);
polylinePointCollection.AddPoint(GeometryUtilities.ConstructPoint2D(-3, -2), ref _missing, ref _missing);
polylinePointCollection.AddPoint(GeometryUtilities.ConstructPoint2D(0, 0), ref _missing, ref _missing);
polylinePointCollection.AddPoint(GeometryUtilities.ConstructPoint2D(3, 2), ref _missing, ref _missing);
polylinePointCollection.AddPoint(GeometryUtilities.ConstructPoint2D(5, 5), ref _missing, ref _missing);
polylinePointCollection.AddPoint(GeometryUtilities.ConstructPoint2D(8, 7), ref _missing, ref _missing);
polylinePointCollection.AddPoint(GeometryUtilities.ConstructPoint2D(10, 10), ref _missing, ref _missing);
IGeometry polylineGeometry = polylinePointCollection as IGeometry;
ITopologicalOperator topologicalOperator = polylineGeometry as ITopologicalOperator;
topologicalOperator.Simplify();
IConstructMultiPatch constructMultiPatch = new MultiPatchClass();
constructMultiPatch.ConstructExtrudeFromTo(FromZ, ToZ, polylineGeometry);
return constructMultiPatch as IGeometry;
}
示例3: CreateLine
/// <summary>
/// ���ݵ㼯���������Ҫ��
/// </summary>
/// <params name="featureLayer"></params>
/// <params name="lstPoint"></params>
public void CreateLine(IFeatureLayer featureLayer, List<IPoint> lstPoint, int ID)
{
//try
//{
IFeatureClass featureClass = featureLayer.FeatureClass;
if (featureClass.ShapeType == esriGeometryType.esriGeometryPolyline)
{
IPointCollection multipoint = new MultipointClass();
if (lstPoint.Count < 2)
{
MessageBox.Show(@"��ѡ���������������ϵ�����", "��ʾ", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;
}
ISegmentCollection pPath = new PathClass();
ILine pLine;
ISegment pSegment;
object o = Type.Missing;
for (int i = 0; i < lstPoint.Count - 1; i++)
{
pLine = new LineClass();
pLine.PutCoords(lstPoint[i], lstPoint[i + 1]);
pSegment = pLine as ISegment;
pPath.AddSegment(pSegment, ref o, ref o);
}
IGeometryCollection pPolyline = new PolylineClass();
pPolyline.AddGeometry(pPath as IGeometry, ref o, ref o);
IDataset dataset = (IDataset)featureClass;
IWorkspace workspace = dataset.Workspace;
IWorkspaceEdit workspaceEdit = workspace as IWorkspaceEdit;
workspaceEdit.StartEditing(true);
workspaceEdit.StartEditOperation();
IFeature feature = featureClass.CreateFeature();
IGeometry geometry = pPolyline as IGeometry;
DrawCommon.HandleZMValue(feature, geometry);//����ͼ��Zֵ����
feature.Shape = pPolyline as PolylineClass;
int iFieldID = feature.Fields.FindField(GIS_Const.FIELD_BID);
feature.Value[iFieldID] = ID.ToString();
feature.Store();
workspaceEdit.StopEditOperation();
workspaceEdit.StopEditing(false);
IEnvelope envelop = feature.Shape.Envelope;
DataEditCommon.g_pMyMapCtrl.ActiveView.Extent = envelop;
DataEditCommon.g_pMyMapCtrl.ActiveView.PartialRefresh(esriViewDrawPhase.esriViewBackground, null, null);
}
else
{
MessageBox.Show(@"��ѡ����ͼ�㡣", "��ʾ", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
//}
//catch
//{
// return;
//}
}
示例4: CreateFeature
/// <summary>
/// ������ʵ��
/// </summary>
/// <param name="pITable">���ݱ����</param>
/// <param name="entinyNode">VCT�ռ�ʵ��ڵ�</param>
public override void CreateFeature(ITable pITable, EntityNode entinyNode)
{
try
{
IFeatureClass pFeatureCls = pITable as IFeatureClass;
this.Feature = pFeatureCls.CreateFeature();
LineNode pLineNode = entinyNode as LineNode;
if (pLineNode != null)
{
///��ʶ�븳ֵ
int dBSMIndex = -1;
dBSMIndex = this.Feature.Fields.FindField(m_strEntityIDFiled);
if (dBSMIndex != -1)
this.Feature.set_Value(dBSMIndex, pLineNode.EntityID);
///Ҫ�ش��븳ֵ
int dSYDMIndex = -1;
dSYDMIndex = this.Feature.Fields.FindField(m_strYSDMField);
if (dSYDMIndex != -1)
this.Feature.set_Value(dSYDMIndex, pLineNode.FeatureCode);
///�����ռ�����
int dLineNodeCount = pLineNode.SegmentNodes.Count;
IPointCollection pointCollection = new PolylineClass();
for (int i = 0; i < dLineNodeCount; i++)
{
//11��ʾ��������
if (Metadata.MetaDataFile.GraphConfig.GetGraphMark("LINETYPE", pLineNode.SegmentNodes[i].SegmentType.ToString()) == "BrokenLine")
{
BrokenLineNode pBLine = pLineNode.SegmentNodes[i] as BrokenLineNode;
foreach (PointInfoNode pPointInfoNode in pBLine.PointInfoNodes)
{
IPoint pPoint = new PointClass();
pPoint.PutCoords(pPointInfoNode.X, pPointInfoNode.Y);
object objType = Type.Missing;
pointCollection.AddPoint(pPoint, ref objType, ref objType);
}
}
else
{
//�������ʹ�������չ
}
}
(this.Feature as IFeature).Shape = pointCollection as IGeometry;
//feature.set_Value();
this.Feature.Store();
}
}
catch(Exception ex)
{
Logger.WriteErrorLog(ex);
}
}
示例5: DrawAxis
private static void DrawAxis(IGraphicsContainer3D axesGraphicsContainer3D, IPoint axisFromPoint, IPoint axisToPoint, IColor axisColor, esriSimple3DLineStyle axisStyle, double axisWidth)
{
IPointCollection axisPointCollection = new PolylineClass();
axisPointCollection.AddPoint(axisFromPoint, ref _missing, ref _missing);
axisPointCollection.AddPoint(axisToPoint, ref _missing, ref _missing);
GeometryUtilities.MakeZAware(axisPointCollection as IGeometry);
GraphicsLayer3DUtilities.AddAxisToGraphicsLayer3D(axesGraphicsContainer3D, axisPointCollection as IGeometry, axisColor, axisStyle, axisWidth);
}
示例6: CreateTurnGeometry
private static IGeometry CreateTurnGeometry(IPoint ptStart, IPoint ptVia, IPoint ptEnd, ISpatialReference sr)
{
IPolyline lineTurn = new PolylineClass();
lineTurn.SpatialReference = sr;
IPointCollection pcTurn = lineTurn as IPointCollection;
pcTurn.AddPoint(ptStart);
pcTurn.AddPoint(ptVia);
pcTurn.AddPoint(ptEnd);
return (IGeometry)lineTurn;
}
示例7: OnClick
protected override void OnClick()
{
//
// TODO: Sample code showing how to access button host
//
var referenceFactory2 = (ISpatialReferenceFactory2)new SpatialReferenceEnvironment();
ISpatialReference WGS84 = referenceFactory2.CreateSpatialReference((int)esriSRGeoCSType.esriSRGeoCS_WGS1984);
IPointCollection pointCollection = new PolylineClass();
// ------------- Ensure that both points have negative longitude values -------------------
IPoint point = new PointClass();
point.PutCoords(-170, 10); // Equivalent to 170 degrees WEST
point.SpatialReference = WGS84;
pointCollection.AddPoint(point);
point = new PointClass();
point.PutCoords(-200, 10); // Equivalent to 160 degrees EAST
point.SpatialReference = WGS84;
pointCollection.AddPoint(point);
// -----------------------------------------------------------------------
IPolyline polyline = (IPolyline)pointCollection;
polyline.SpatialReference = WGS84;
var geometryDefEdit = (IGeometryDefEdit)new GeometryDef();
geometryDefEdit.GeometryType_2 = esriGeometryType.esriGeometryPolyline;
geometryDefEdit.SpatialReference_2 = WGS84;
var field = (IFieldEdit)new Field();
field.Name_2 = "Shape";
field.Type_2 = esriFieldType.esriFieldTypeGeometry;
field.GeometryDef_2 = geometryDefEdit;
var fields = (IFieldsEdit)new Fields();
fields.AddField(field);
IWorkspaceFactory workspaceFactory = new ShapefileWorkspaceFactory();
var featureWorkspace = (IFeatureWorkspace)workspaceFactory.OpenFromFile("C:\\Temp\\", 0);
IFeatureClass featureClass = featureWorkspace.CreateFeatureClass
("test3.shp", fields, null, null, esriFeatureType.esriFTSimple, "Shape", "");
var feature = featureClass.CreateFeature();
feature.Shape = polyline;
feature.Store();
ArcMap.Application.CurrentTool = null;
}
示例8: drawLineWithText
private void drawLineWithText(IPoint startPt, IPoint endPt, string text, bool horizontal)
{
IPolyline line = new PolylineClass();
IPointCollection ptCol = line as IPointCollection;
ptCol.AddPoint(startPt);
ptCol.AddPoint(endPt);
IPoint midPt = new PointClass();
midPt.X = (startPt.X + endPt.X) / 2;
midPt.Y = (startPt.Y + endPt.Y) / 2;
if (horizontal)
{
midPt.Y = midPt.Y + textAdjustGap;
}
GisUtil.DrawPolyline(line, mapControl);
GisUtil.drawText(text, midPt, textColor, mapControl);
}
示例9: AddDxdLines
/// <summary>
/// 添加导线点线图层元素
/// </summary>
/// <params name="pnts"></params>
/// <params name="layer"></params>
public void AddDxdLines(List<IPoint> pnts, Dictionary<string, string> dics, IFeatureLayer layer, List<WirePoint> cols = null)
{
try
{
IFeatureClass Featureclass = layer.FeatureClass;
IWorkspaceEdit workspace = (IWorkspaceEdit)(Featureclass as IDataset).Workspace;
workspace.StartEditing(false);
workspace.StartEditOperation();
for (int i = 0; i < pnts.Count; i++)
{
IFeature fealin = Featureclass.CreateFeature();
IPolyline plin = new PolylineClass();
ISegmentCollection segcols = plin as ISegmentCollection;
ICurve circle = Global.commonclss.CreateCircleArc(pnts[i], Global.radius, true);
segcols.AddSegment(circle as ISegment);
fealin.Shape = plin;
if (cols != null)
{
string name = cols[i].name;
int NamePos = fealin.Fields.FindField(GIS_Const.FIELD_NAME);
fealin.set_Value(NamePos, name);
}
foreach (string key in dics.Keys)
{
int findex = fealin.Fields.FindField(key);
if (findex != -1)
{
fealin.set_Value(findex, dics[key]);
}
}
fealin.Store();
}
workspace.StopEditOperation();
workspace.StopEditing(true);
}
catch
{
throw;
}
}
示例10: FlatBuffer
private IPolygon FlatBuffer(IPolyline pLline1, double pBufferDis)
{
object o = System.Type.Missing;
//分别对输入的线平移两次(正方向和负方向)
IConstructCurve pCurve1 = new PolylineClass();
pCurve1.ConstructOffset(pLline1, pBufferDis, ref o, ref o);
IPointCollection pCol = pCurve1 as IPointCollection;
IConstructCurve pCurve2 = new PolylineClass();
pCurve2.ConstructOffset(pLline1, -1 * pBufferDis, ref o, ref o);
//把第二次平移的线的所有节点翻转
IPolyline pline2 = pCurve2 as IPolyline;
pline2.ReverseOrientation();
//把第二条的所有节点放到第一条线的IPointCollection里面
IPointCollection pCol2 = pline2 as IPointCollection;
pCol.AddPointCollection(pCol2);
//用面去初始化一个IPointCollection
IPointCollection pPointCol = new PolygonClass();
pPointCol.AddPointCollection(pCol);
//把IPointCollection转换为面
IPolygon pPolygon = pPointCol as IPolygon;
//简化节点次序
pPolygon.SimplifyPreserveFromTo();
return pPolygon;
}
示例11: RotateInnerPoint
private IPoint RotateInnerPoint(IPoint oldPt)
{
IPolyline line = new PolylineClass();
IPoint centerPt = getCenterPt();
IPoint newPt = new PointClass();
IPointCollection ptCol = line as IPointCollection;
ptCol.AddPoint(centerPt);
ptCol.AddPoint(oldPt);
line = RotateGeom(line, rotateAngle, true) as IPolyline;
newPt = (line as IPointCollection).get_Point(1);
return newPt;
}
示例12: rotateCornerPoint
private IPoint rotateCornerPoint(IPoint basePt, IPoint targetPt, double angle)
{
IPolyline line = new PolylineClass();
IPointCollection ptCol = line as IPointCollection;
ptCol.AddPoint(basePt);
ptCol.AddPoint(targetPt);
line = RotateGeom(line, angle, true) as IPolyline;
IPoint afterMovePt = (line as IPointCollection).get_Point(1);
targetPt = MovePoint(targetPt, afterMovePt.X - targetPt.X, afterMovePt.Y - targetPt.Y);
return targetPt;
}
示例13: biImportToGraphic_ItemClick
/// <summary>
/// 从导入的坐标串中生成草图
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
void biImportToGraphic_ItemClick(object sender, ItemClickEventArgs e)
{
string filePath = "";
object pbefore = Type.Missing;
object pafter = Type.Missing;
OpenFileDialog openDlg = new OpenFileDialog();
openDlg.Filter = "Text files(*.txt)|*.txt";
IPointCollection ipPoitCol = null;
IGeometry iGeo = null;
try
{
if (_subType == 1)
{
ipPoitCol = new PolylineClass();
}
else if(_subType == 2)
{
ipPoitCol = new PolygonClass();
}
if (openDlg.ShowDialog() == DialogResult.OK)
{
filePath = openDlg.FileName;
StreamReader strRead = new StreamReader(filePath);
string strLine;
int RowCou = 0;
string strX = string.Empty;
string strY = string.Empty;
string[] strCoor = new string[2];
while ((strLine = strRead.ReadLine()) != null)
{
if (strLine != "")
{
RowCou++;
strCoor = strLine.Split(',');
double x = double.Parse(strCoor[0]);
double y = double.Parse(strCoor[1]);
if (RowCou == 1)
{
strX = strCoor[0];
strY = strCoor[1];
}
IPoint ipNewPoint = new PointClass();
ipNewPoint.PutCoords(x, y);
ipPoitCol.AddPoint(ipNewPoint, ref pbefore, ref pafter);
}
}
//如果第一个点和最后一个点不等,则再加一遍一个点的坐标
if (strX != strCoor[0] && strY != strCoor[1])
{
IPoint ipPoint = new PointClass();
ipPoint.PutCoords(double.Parse(strCoor[0]), double.Parse(strCoor[1]));
ipPoitCol.AddPoint(ipPoint, ref pbefore, ref pafter);
}
strRead.Close();
}
iGeo = ipPoitCol as IGeometry;
if (iGeo != null)
{
if (_subType == 1)
(_geometryFeedback as INewLineFeedback).Stop();
else if(_subType ==2)
(_geometryFeedback as INewPolygonFeedback).Stop();
TheReferenceInstances.TheAEditer.SketchEdit.DrawGeometry = iGeo;
_startPoint = null;
RefreshFeedBack();
}
else
{
XtraMessageBox.Show("导入的点坐标不能构成面!", "提示");
return;
}
}
catch (Exception ex)
{
throw ex;
}
}
示例14: isIntersect
public bool isIntersect(IPolyline line)
{
//需要做四次相交, 分别是和四个边线.
//左边边线.
IPolyline boundLine = new PolylineClass();
IPointCollection ptCol = boundLine as IPointCollection;
ptCol.AddPoint(upperLeftPt);
ptCol.AddPoint(lowerLeftPt);
ITopologicalOperator tpOp = boundLine as ITopologicalOperator;
IGeometry geom = tpOp.Intersect(line, esriGeometryDimension.esriGeometry0Dimension);
if (!geom.IsEmpty)
{
return true;
}
//右边边线.
boundLine = new PolylineClass();
ptCol = boundLine as IPointCollection;
ptCol.AddPoint(upperRightPt);
ptCol.AddPoint(lowerRightPt);
tpOp = boundLine as ITopologicalOperator;
geom = tpOp.Intersect(line, esriGeometryDimension.esriGeometry0Dimension);
if (!geom.IsEmpty)
{
return true;
}
//上边边线.
boundLine = new PolylineClass();
ptCol = boundLine as IPointCollection;
ptCol.AddPoint(upperLeftPt);
ptCol.AddPoint(upperRightPt);
tpOp = boundLine as ITopologicalOperator;
geom = tpOp.Intersect(line, esriGeometryDimension.esriGeometry0Dimension);
if (!geom.IsEmpty)
{
return true;
}
//下边边线.
boundLine = new PolylineClass();
ptCol = boundLine as IPointCollection;
ptCol.AddPoint(lowerLeftPt);
ptCol.AddPoint(lowerRightPt);
tpOp = boundLine as ITopologicalOperator;
geom = tpOp.Intersect(line, esriGeometryDimension.esriGeometry0Dimension);
if (!geom.IsEmpty)
{
return true;
}
return false;
}
示例15: ConnectClosestFeature
//.........这里部分代码省略.........
pEditTemp = Globals.PromptAndGetEditTemplateGraphic(connectLineFLayer, "");
}
sel = pointFeatureSelection.SelectionSet as ISelectionSet2;
//sel.Update(null, false, out pointCursor);
sel.Search(null, false, out pointCursor);
while ((pointFeature = (IFeature)pointCursor.NextRow()) != null)
{
i += 1;
if (suppressDialog == false)
{
//Update progress bar
progressDialog.Description = A4LGSharedFunctions.Localizer.GetString("ConnectAsset") + i.ToString() + A4LGSharedFunctions.Localizer.GetString("Of") + total.ToString() + "." + Environment.NewLine +
A4LGSharedFunctions.Localizer.GetString("CurrentOID") + pointFeature.OID;
stepProgressor.Step();
}
ESRI.ArcGIS.esriSystem.IStatusBar statusBar = app.StatusBar;
statusBar.set_Message(0, i.ToString());
//Check if the cancel button was pressed. If so, stop process
bool boolean_Continue = trackCancel.Continue();
if (!boolean_Continue)
{
break;
}
//IFeature pNearestFeature =
pNearestFeature = Globals.GetClosestFeatureIgnoreExistingLineFeature((connectClosestLayers[k] as ConnectClosestDetails).Search_Threshold,
pointFeature.ShapeCopy, pointFLayer, connectLineFLayer, bSelectedOnly);
if (pNearestFeature == null)
break;
pNewPoly = new PolylineClass();
pNewPoly.FromPoint = pNearestFeature as IPoint;
pNewPoly.ToPoint = pointFeature.ShapeCopy as IPoint;
if (pEditTemp == null)
{
pLine = Globals.CreateFeature(pNewPoly, connectLineFLayer, editor, app, false, false, true);
}
else
{
pLine = Globals.CreateFeature(pNewPoly, pEditTemp, editor, app, false, false, true);
}
pLine.Store();
pRetFeature.Add(pLine);
}
if ((connectClosestLayers[k] as ConnectClosestDetails).Reset_Flow != null)
{
if ((connectClosestLayers[k] as ConnectClosestDetails).Reset_Flow.ToUpper() == "DIGITIZED")
{
retVal.Options = "DIGITIZED";
}
else if ((connectClosestLayers[k] as ConnectClosestDetails).Reset_Flow.ToUpper() == "ROLE")
{
retVal.Options = "ROLE";
}
else if ((connectClosestLayers[k] as ConnectClosestDetails).Reset_Flow.ToUpper() == "Ancillary".ToUpper())
{
retVal.Options = "ANCILLARY";
}