অবশেষে আমি এটি আমার উদ্দেশ্যগুলির জন্য সমাধান করেছি সুতরাং এটি সমাধানটি আমি এখানে এনেছি যদি এটি কাউকে সহায়তা করে:
পাইথন স্ক্রিপ্ট লিখুন (এটির শেষে আমার) যা মূলত এটি করে:
- আগ্রহের পয়েন্ট স্তর ক্ষেত্রে অনন্য বিভাগগুলি চিহ্নিত করুন
- প্রতিটি বিভাগের জন্য, সমস্ত মেলানো পয়েন্ট নির্বাচন করুন এবং এই সেটটির ব্যাপ্তি স্থাপন করুন
- প্রতিটি মাত্রার জন্য একটি বিশিষ্ট "বিভাগের নাম" সহ একটি ফাঁকা অ্যাটলাস কভারেজ স্তরে একটি নতুন বহুভুজ তৈরি করুন
এটি আমাকে প্রতিটি শ্রেণীর আগ্রহের জন্য একটি বহুভুজ সহ আটলাসের কভারেজ স্তরটি দিয়েছে:
স্বাভাবিক হিসাবে অ্যাটলাস এবং মুদ্রণ রচয়িতা কনফিগার করুন - কেবল অফিং এবং বৈশিষ্ট্যগুলি ইস্যু রেখে।
এর জন্য বিকল্পগুলির সঠিক সেটটি কাজ করতে সামান্য পরীক্ষা এবং ত্রুটি:
নীচের অভিব্যক্তিটি আপনাকে বর্তমান আটলাস বৈশিষ্ট্যের জন্য ক্যাটাগরিনাম ফিল্ডে রাখা মানটি পেতে দেয়
attribute ($atlasfeature, 'CategoryName')
এর লাইন বরাবর পয়েন্ট স্তর জন্য নিয়ম ভিত্তিক স্টাইলিং তৈরি করতে এটি ব্যবহার করুন
attribute ($atlasfeature, 'CategoryName') = PointCategory AND PointCategory = "RedDots"
অন্য সমস্ত স্বচ্ছ হয়ে ওঠার গ্যারান্টি দেওয়ার আমারও একটি নিয়ম ছিল
attribute ($atlasfeature, 'CategoryName') IS NOT PointCategory
এটলাস দিয়ে এটি পরীক্ষা করা সত্যিই ভাল কাজ করে। অবশেষে প্রদর্শিত লেবেলগুলিকে ম্যানিপুলেট করার জন্য একই পন্থাটি ব্যবহার করুন, লেবেলগুলিকে গতিশীল এবং ফিল্টার টেবিলগুলি যথাযথ করুন। যদি আপনি সমস্ত মানচিত্রে সমস্ত কিংবদন্তি আইটেম না চান তবে 'ফিল্টার লেজেন্ড ম্যাপের সামগ্রী দ্বারা' টিক দেওয়াও খুব কার্যকর।
ফাইনাল এটলাস সেট:
সম্পাদনা করুন - যেমনটি জিজ্ঞাসা করা হয়েছিল, তা এখানে আমার স্ক্রিপ্ট:
from PyQt4.QtCore import *
#main script----------------------------------------------
#set up the layer references - you will need to change this
targetlayer=QgsMapLayerRegistry.instance().mapLayer("AtlasExtents20150727154732521")
eylayer = QgsMapLayerRegistry.instance().mapLayer("Early_Years_Providers20150727152919862")
#establish the unique categories
names = getUniqueAttributes(eylayer, 'Mapping_La')
#get a set of boxes
boxset = getBoundings(eylayer, names)
#ensure layer is emptied, then add bounding boxes
deleteBoxes(targetlayer)
createBoxes(targetlayer, boxset)
#end main script----------------------------------------------
#------functions-------#
#gets unique set of attributes - returns a set()
def getUniqueAttributes(layer, fieldname):
values = set()
for feature in layer.getFeatures():
values.add(feature[fieldname])
return values
#quickly selects all points on a layer, given a query
def selectionQuick(layer, queryitem):
layer.removeSelection ()
#hardcoded field name
expr = QgsExpression( "\"Mapping_La\" = '" + queryitem +"'")
it = layer.getFeatures( QgsFeatureRequest( expr ) )
ids = [i.id() for i in it]
layer.setSelectedFeatures( ids )
#for a set of unique items, get bounding boxes
def getBoundings(layer, itemset):
bboxes = {}
for itemname in itemset:
selectionQuick(layer,itemname)
box = layer.boundingBoxOfSelected()
bboxes[itemname] = box
return bboxes
#for a layer create a bunch of boxes
def createBoxes(layer, boxes):
id=0
for boxkey in boxes:
id = id +1
box=boxes[boxkey]
feat = QgsFeature(layer.pendingFields())
geom = QgsGeometry.fromRect(box)
feat.setAttribute('id', id)
#hardcoded field name
feat.setAttribute('CareType', boxkey)
feat.setGeometry(geom)
(res, outFeats) = layer.dataProvider().addFeatures([feat])
def deleteBoxes(layer):
ids = [f.id() for f in layer.getFeatures()]
layer.dataProvider().deleteFeatures( ids )