এই কোড কিউজিআইএস-এর সর্বশেষতম দেব বিল্ডে কাজ করবে।
from qgis.utils import iface
from qgis.core import *
from PyQt4.QtCore import QVariant
import random
def createRandomPoints(count):
# Create a new memory layer to store the points.
vl = QgsVectorLayer("Point", "distance nodes", "memory")
pr = vl.dataProvider()
pr.addAttributes( [ QgsField("distance", QVariant.Int) ] )
layer = iface.mapCanvas().currentLayer()
# For each selected object
for feature in layer.selectedFeatures():
geom = feature.geometry()
length = geom.length()
feats = []
# Loop until we reach the needed count of points.
for i in xrange(0,count):
# Get the random distance along the line.
distance = random.uniform(0, length)
# Work out the location of the point at that distance.
point = geom.interpolate(distance)
# Create the new feature.
fet = QgsFeature()
fet.setAttributeMap( { 0 : distance } )
fet.setGeometry(point)
feats.append(fet)
pr.addFeatures(feats)
vl.updateExtents()
QgsMapLayerRegistry.instance().addMapLayer(vl)
আমি জানি আপনি বলেছেন যে আপনি পাইথন কোডের সাথে খুব বেশি পরিচিত নন তবে আপনার এটি খুব সহজ চালাতে সক্ষম হওয়া উচিত। উপরের কোডটি কোনও ফাইলে অনুলিপি করুন (আমার কল হয় locate.py
) এবং আপনার ~/.qgis/python
যদি উইন্ডোজ 7 এ থাকে যা C:\Users\{your user name}\.qgis\python\
উইন্ডোজ এক্সপিতে বা উইন্ডোজ এক্সপিতে থাকে তবে আপনার এটিতে রাখুনC:\Documents and Settings\{your user name}\.qgis\python\
ফাইলটি পাইথন ফোল্ডারে আসলে কিউজিআইএস খুলুন এবং কয়েকটি লাইন অবজেক্ট নির্বাচন করুন।
তারপরে পাইথন কনসোলটি খুলুন এবং নিম্নলিখিত কোডটি চালান:
import locate.py
locate.createRandomPoints(10)
ফলাফলটি এর মতো দেখতে হবে
আপনি যদি এটি আবার চালাতে চান তবে আরও কয়েকটি লাইন নির্বাচন করুন এবং locate.createRandomPoints(10)
পাইথন কনসোলে আবার চালনা করুন ।
দ্রষ্টব্য: সন্ধান করুন ক্রেটআর্যান্ডমপয়েন্টস (10) 10 এখানে প্রতি লাইনে উত্পন্ন পয়েন্টের সংখ্যা