আর্কজিআইএস ডেস্কটপ ব্যবহার করে লাইন তৈরি করা (লাইনটির নিকটতম শীর্ষটি)?


11

আমি আরকিআইএনফো 10 এসপি 3 ব্যবহার করছি।

আমি আমাদের ইউটিলিটি ডেটা পুনর্গঠনে কাজ করছি। দুই বছর আগে, আমরা প্রাইভেট সার্ভিসের জলের লাইন সংগ্রহ শুরু করেছি। আমাদের এখনও পুরানো রেকর্ড অঙ্কন থেকে বের করার অনেক কিছু আছে।

আমি ভাবছিলাম যে লাইন তৈরির কোনও উপায় আছে যা আমাদের বিল্ডিংয়ের পদচিহ্নগুলিতে ওয়াটারমাইন লাইনে যোগ দেবে?

আমি জলের মূলের নিকটতম বিল্ডিংয়ের শীর্ষবিন্দুটিকে একটি সূচনা পয়েন্ট হিসাবে ব্যবহার করতে চাই।

এখানে চিত্র বর্ণনা লিখুন

উত্তর:


10

আপনি যদি এমন কোনও সমাধান খুঁজছেন যা যার জন্য। নেট সরঞ্জাম বিকাশমানের প্রয়োজন হয় না, আপনি নীচের অজগর স্ক্রিপ্টটি আপনার ঠিক কীটি করতে চলেছেন তা সম্পাদন করতে পারেন। আমার ঠিক একই চাহিদা ছিল এবং সমাধান হিসাবে নিম্নলিখিত স্ক্রিপ্টটি লিখেছিলাম। এটি 4 টি প্যারামিটারের সাথে একটি আর্কগ্ল্যাটালজ সরঞ্জাম হিসাবে কনফিগার করুন, বা প্যারামিটারগুলি মন্তব্য করুন এবং হার্ডকোডযুক্ত ভেরিয়েবলগুলিকে সঙ্কলিত করুন এবং এটিকে সরাসরি চালান।

# CreateLineFromNearestVertexToFeature.py
# Author: Jeff Berry
# Description: Creates a line between the nearest vertext on source features
# to the nearest feature in target feature class.
# ---------------------------------------------------------------------------

# Import arcpy module
import arcpy
from arcpy import env

# Local variables:
# 1. SourceFC - Feature Class 
# 2. TargetFC - Feature Class
# 3. Output_gdb - Geodatabase
# 4. Output_fc - String

SourceFC = arcpy.GetParameterAsText(0)
TargetFC = arcpy.GetParameterAsText(1)
Output_gdb = arcpy.GetParameterAsText(2)
Output_fc = arcpy.GetParameterAsText(3)

## Alternatively setup hardcoded variables    
##SourceFC = "Buildings"
##TargetFC = "WaterMains"
##Output_gdb = "D:\\New File Geodatabase.gdb"
##Output_fc = "lines_output"

SourceFeaturePoints = "SrcFtrPoints"
arcpy.env.workspace = Output_gdb

# Process: Feature Vertices To Points
arcpy.FeatureVerticesToPoints_management(SourceFC, SourceFeaturePoints, "ALL")

# Process: Near
arcpy.Near_analysis(SourceFeaturePoints, TargetFC, "1000 Feet", "LOCATION", "NO_ANGLE")

# Process: Create Feature Class...
#arcpy.CreateFeatureclass_management(Output_gdb, Output_fc, "POLYLINE", "", "DISABLED", "DISABLED", "", "", "0", "0", "0")
rows = arcpy.SearchCursor(SourceFeaturePoints)

lstIDs = []

for row in rows:
    lstIDs.append(row.ORIG_FID)

uniqueOBJIDS = set(lstIDs)
newLineList = []
shapeName = arcpy.Describe(SourceFeaturePoints).shapeFieldName

for objID in uniqueOBJIDS:
    rows = arcpy.SearchCursor(SourceFeaturePoints, "\"NEAR_DIST\" = (SELECT MIN( \"NEAR_DIST\") FROM SrcFtrPoints WHERE \"ORIG_FID\"  = " + str(objID) + ")")
    for row in rows:
        arrayLine = arcpy.Array()
        ftr = row.getValue(shapeName)
        pointStart = ftr.firstPoint
        pointEnd = arcpy.Point(row.NEAR_X, row.NEAR_Y)
        arrayLine.add(pointStart)
        arrayLine.add(pointEnd)
        plyLine = arcpy.Polyline(arrayLine)
        newLineList.append(plyLine)


arcpy.CopyFeatures_management(newLineList, Output_fc)
arcpy.Delete_management(SourceFeaturePoints, "FeatureClass")

del rows
del row
del SourceFeaturePoints
del Output_fc
del Output_gdb
arcpy.ClearEnvironment("workspace")

2

IIndexQuery2 এ "নিকটতম বৈশিষ্ট্য" পদ্ধতিটি দেখুন।

প্রতিটি বিল্ডিংয়ের নিকটস্থ জলের মূল বৈশিষ্ট্যটি পেতে আপনি এটি ব্যবহার করতে পারেন। আমার ধারণা আপনি তখন কোনও একটি বৈশিষ্ট্যের নিকটতম দূরত্বটি খুঁজে পেতে প্রতিটি বিল্ডিংয়ের শীর্ষে লুপের প্রয়োজন হবে, তারপরে বিল্ডিং থেকে শীর্ষে এবং শেষ পয়েন্ট হিসাবে ওয়াটারমাইন ব্যবহার করে একটি নতুন পললাইন তৈরি করুন। আমি কেবল একবার এটি করার জন্য দুটি পয়েন্টের বৈশিষ্ট্যযুক্ত ক্লাস ব্যবহার করছিলাম, আশা করি আমি আমার মাথার উপরের অংশের চেয়ে আরও বেশি প্রস্তাব দিতে পারতাম ..: ডি

IFeatureCursor pDepthCursor = pDepthSoundings.Search(null, false);
IFeatureIndex2 pFtrInd = new FeatureIndexClass();
pFtrInd.FeatureClass = pDepthSoundings.FeatureClass;
pFtrInd.FeatureCursor = pDepthCursor;
pFtrInd.Index(null, pCombinedEnvelope);
IIndexQuery2 pIndQry = pFtrInd as IIndexQuery2;

int FtdID = 0;
double dDist2Ftr = 0;
pIndQry.NearestFeature(ppoint, out FtdID, out dDist2Ftr);

IFeature pCloseFeature = pDepthSoundings.FeatureClass.GetFeature(FtdID);
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.