# coding: utf-8 from PyQt4.QtCore import QSizeF from PyQt4.QtGui import QColor, QTextDocument from qgis.core import QgsPoint from qgis.gui import QgsTextAnnotationItem from qgis.utils import iface canvas = iface.mapCanvas() text_annotation_item = QgsTextAnnotationItem(canvas) X, Y = float(3), float(45) point = QgsPoint(X, Y) text_annotation_item.setMapPosition(point) text_annotation_item.setFrameSize(QSizeF(300, 200)) text_annotation_item.setFrameColor(QColor(0, 255, 0)) text_annotation_item.setFrameBackgroundColor(QColor(128, 128, 128)) text_document = QTextDocument() html_content = "<b>New annotation</b>" font_color, font_family, font_size = "#123456", "Times New Roman", 16 text_document.setHtml('<font style="color:' + font_color + "; font-family:" + font_family + "; font-size: " + str(font_size) + 'px">' + html_content + "</font>") text_annotation_item.setDocument(text_document) canvas.refresh() # Then remove # canvas.scene().removeItem(text_annotation_item)
class NpaOnFixDlg(FlightPlanBaseDlg): def __init__(self, parent, dlgType): FlightPlanBaseDlg.__init__(self, parent) # self.dlgType = dlgType self.setObjectName("PaIlsDlg") self.dlgType = dlgType if self.dlgType == "NpaOnFix": self.surfaceType = SurfaceTypes.NpaOnFix else: self.surfaceType = SurfaceTypes.NpaOverheadingNavaid self.initParametersPan() self.setWindowTitle(self.surfaceType) self.resize(540, 600) QgisHelper.matchingDialogSize(self, 650, 700) self.surfaceList = None self.manualPolygon = None self.mapToolPan = None self.toolSelectByPolygon = None self.accepted.connect(self.closed) self.rejected.connect(self.closed) self.wptLayer = None self.arpFeatureArray = [] self.currentLayer = define._canvas.currentLayer() self.rwyFeatureArray = [] self.rwyEndPosition = None self.initAerodromeAndRwyCmb() self.socRubber = None self.socAnnotation = QgsTextAnnotationItem(define._canvas) self.socAnnotation.setDocument(QTextDocument(Captions.SOC)) self.socAnnotation.setFrameBackgroundColor(Qt.white) self.socAnnotation.setFrameSize(QSizeF(30, 20)) self.socAnnotation.setFrameColor(Qt.magenta) self.socAnnotation.hide() self.socPoint3d = None self.daRubber = None self.daAnnotation = QgsTextAnnotationItem(define._canvas) self.daAnnotation.setDocument(QTextDocument(Captions.DA)) self.daAnnotation.setFrameBackgroundColor(Qt.white) self.daAnnotation.setFrameSize(QSizeF(30, 20)) self.daAnnotation.setFrameColor(Qt.magenta) self.daAnnotation.hide() self.daPoint3d = None self.annotationFAWP = self.parametersPanel.pnlFafPosition.annotation self.annotationMAPt = self.parametersPanel.pnlMaPtPosition.annotation # self.surfaceType = self.dlgType def initAerodromeAndRwyCmb(self): if self.currentLayer != None and self.currentLayer.isValid( ) and isinstance(self.currentLayer, QgsVectorLayer): self.arpFeatureArray = self.aerodromeAndRwyCmbFill( self.currentLayer, self.parametersPanel.cmbAerodrome, None, self.parametersPanel.cmbRwyDir) self.calcRwyBearing() def calcRwyBearing(self): try: point3dMapt = self.parametersPanel.pnlMaPtPosition.Point3d point3dFaf = self.parametersPanel.pnlFafPosition.Point3d if point3dMapt == None: self.parametersPanel.pnlInboundTrack.Value = 0.0 return self.parametersPanel.pnlInboundTrack.Value = round( Unit.ConvertRadToDeg( MathHelper.getBearing(point3dFaf, point3dMapt)), 4) # if point3dFaf == None: # self.parametersPanel.pnlInboundTrack.Value = round(Unit.ConvertRadToDeg(MathHelper.getBearing(point3dThr, self.parametersPanel.pnlRwyEndPosition.Point3d)), 4) # point3dFap = self.rwyEndPosition # else: # self.parametersPanel.pnlInboundTrack.Value = round(Unit.ConvertRadToDeg(MathHelper.getBearing(point3dFap, point3dThr)), 4) self.showMarkDaSoc() except: pass # self.ui.horizontalLayout_6.addWidget(self.ui.frame_3) def aerodromeAndRwyCmbFill(self, layer, aerodromeCmbObj, aerodromePositionPanelObj, rwyDirCmbObj=None): idx = layer.fieldNameIndex('Type') idxName = layer.fieldNameIndex('Name') idxLat = layer.fieldNameIndex('Latitude') idxLong = layer.fieldNameIndex('Longitude') idxAltitude = layer.fieldNameIndex('Altitude') arpList = [] arpFeatureList = [] if idx >= 0: featIter = layer.getFeatures() for feat in featIter: attrValue = feat.attributes()[idx].toString() attrValue = QString(attrValue) attrValue = attrValue.replace(" ", "") attrValue = attrValue.toUpper() if attrValue == "AERODROMEREFERENCEPOINT": arpList.append(attrValue) arpFeatureList.append(feat) if len(arpList) != 0: i = -1 attrValueList = [] for feat in arpFeatureList: attrValue = feat.attributes()[idxName].toString() items = attrValueList if len(items) != 0: existFlag = False for item in items: if item == attrValue: existFlag = True if existFlag: continue attrValueList.append(attrValue) attrValueList.sort() # attrValueList.insert(0, "") aerodromeCmbObj.Items = attrValueList aerodromeCmbObj.SelectedIndex = 0 # if idxAttributes for feat in arpFeatureList: attrValue = feat.attributes()[idxName].toString() if attrValue != aerodromeCmbObj.SelectedItem: continue attrValue = feat.attributes()[idxLat].toDouble() lat = attrValue[0] attrValue = feat.attributes()[idxLong].toDouble() long = attrValue[0] attrValue = feat.attributes()[idxAltitude].toDouble() alt = attrValue[0] # aerodromePositionPanelObj.Point3d = Point3D(long, lat, alt) self.connect(aerodromeCmbObj, SIGNAL("Event_0"), self.aerodromeCmbObj_Event_0) break if rwyDirCmbObj != None: idxAttr = layer.fieldNameIndex('Attributes') if idxAttr >= 0: rwyFeatList = [] featIter = layer.getFeatures() rwyDirCmbObjItems = [] for feat in featIter: attrValue = feat.attributes()[idxAttr].toString() if attrValue == aerodromeCmbObj.SelectedItem: attrValue = feat.attributes()[idxName].toString() s = attrValue.replace(" ", "") compStr = s.left(6).toUpper() if compStr == "THRRWY": valStr = s.right(s.length() - 6) rwyDirCmbObjItems.append( aerodromeCmbObj.SelectedItem + " RWY " + valStr) rwyFeatList.append(feat) rwyDirCmbObjItems.sort() rwyDirCmbObj.Items = rwyDirCmbObjItems self.connect(rwyDirCmbObj, SIGNAL("Event_0"), self.rwyDirCmbObj_Event_0) self.rwyFeatureArray = rwyFeatList self.rwyDirCmbObj_Event_0() self.aerodromeCmbObj_Event_0() return arpFeatureList def rwyDirCmbObj_Event_0(self): if len(self.rwyFeatureArray) == 0: self.calcRwyBearing() return idxName = self.currentLayer.fieldNameIndex('Name') idxLat = self.currentLayer.fieldNameIndex('Latitude') idxLong = self.currentLayer.fieldNameIndex('Longitude') idxAltitude = self.currentLayer.fieldNameIndex('Altitude') idxAttr = self.currentLayer.fieldNameIndex('Attributes') # rwyFeatList = [] featIter = self.currentLayer.getFeatures() # for feat in featIter: # attrValue = feat.attributes()[idxAttr].toString() # if attrValue == self.cmbAerodrome.SelectedItem: # attrValue = feat.attributes()[idxName].toString() # s = attrValue.replace(" ", "") # compStr = s.left(6).toUpper() # if compStr == "THRRWY": # valStr = s.right(s.length() - 6) # rwyFeatList.append(feat) for feat in self.rwyFeatureArray: attrValue = feat.attributes()[idxName].toString() attrValueStr = QString(attrValue) attrValueStr = attrValueStr.replace( " ", "").right(attrValueStr.length() - 3) itemStr = self.parametersPanel.cmbRwyDir.SelectedItem itemStr = QString(itemStr) itemStr = itemStr.replace(" ", "").right(itemStr.length() - 4) if attrValueStr != itemStr: continue latAttrValue = feat.attributes()[idxLat].toDouble() lat = latAttrValue[0] longAttrValue = feat.attributes()[idxLong].toDouble() long = longAttrValue[0] altAttrValue = feat.attributes()[idxAltitude].toDouble() alt = altAttrValue[0] self.parametersPanel.pnlThrPosition.Point3d = Point3D( long, lat, alt) valStr = None if attrValue.right(1).toUpper() == "L" or attrValue.right( 1).toUpper() == "R": s = attrValue.left(attrValue.length() - 1) valStr = s.right(2) else: valStr = attrValue.right(2) val = int(valStr) val += 18 if val > 36: val -= 36 newValStr = None if len(str(val)) == 1: newValStr = "0" + str(val) else: newValStr = str(val) otherAttrValue = attrValue.replace(valStr, newValStr) ss = otherAttrValue.right(1) if ss.toUpper() == "L": otherAttrValue = otherAttrValue.left(otherAttrValue.length() - 1) + "R" elif ss.toUpper() == "R": otherAttrValue = otherAttrValue.left(otherAttrValue.length() - 1) + "L" for feat in self.rwyFeatureArray: attrValue = feat.attributes()[idxName].toString() if attrValue != otherAttrValue: continue latAttrValue = feat.attributes()[idxLat].toDouble() lat = latAttrValue[0] longAttrValue = feat.attributes()[idxLong].toDouble() long = longAttrValue[0] altAttrValue = feat.attributes()[idxAltitude].toDouble() alt = altAttrValue[0] self.parametersPanel.pnlRwyEndPosition.Point3d = Point3D( long, lat, alt) break break self.calcRwyBearing() def aerodromeCmbObj_Event_0(self): if len(self.arpFeatureArray) == 0: return # self.parametersPanel.pnlArp.Point3d = None self.parametersPanel.pnlRwyEndPosition.Point3d = None self.parametersPanel.pnlThrPosition.Point3d = None idxName = self.currentLayer.fieldNameIndex('Name') idxLat = self.currentLayer.fieldNameIndex('Latitude') idxLong = self.currentLayer.fieldNameIndex('Longitude') idxAltitude = self.currentLayer.fieldNameIndex('Altitude') self.rwyFeatureArray = [] # if idxAttributes for feat in self.arpFeatureArray: attrValue = feat.attributes()[idxName].toString() if attrValue != self.parametersPanel.cmbAerodrome.SelectedItem: continue attrValue = feat.attributes()[idxLat].toDouble() lat = attrValue[0] attrValue = feat.attributes()[idxLong].toDouble() long = attrValue[0] attrValue = feat.attributes()[idxAltitude].toDouble() alt = attrValue[0] # self.parametersPanel.pnlArp.Point3d = Point3D(long, lat, alt) break idxAttr = self.currentLayer.fieldNameIndex('Attributes') if idxAttr >= 0: self.parametersPanel.cmbRwyDir.Clear() rwyFeatList = [] featIter = self.currentLayer.getFeatures() for feat in featIter: attrValue = feat.attributes()[idxAttr].toString() if attrValue == self.parametersPanel.cmbAerodrome.SelectedItem: attrValue = feat.attributes()[idxName].toString() s = attrValue.replace(" ", "") compStr = s.left(6).toUpper() if compStr == "THRRWY": valStr = s.right(s.length() - 6) self.parametersPanel.cmbRwyDir.Add( self.parametersPanel.cmbAerodrome.SelectedItem + " RWY " + valStr) rwyFeatList.append(feat) self.rwyFeatureArray = rwyFeatList self.rwyDirCmbObj_Event_0() def closed(self): if self.mapToolPan != None: self.mapToolPan.deactivate() if self.toolSelectByPolygon != None: self.toolSelectByPolygon.deactivate() def initObstaclesModel(self): self.obstaclesModel.MocMultiplier = self.parametersPanel.mocSpinBox.value( ) return FlightPlanBaseDlg.initObstaclesModel(self) def exportResult(self): result, resultHideColumnNames = FlightPlanBaseDlg.exportResult(self) if not result: return filePathDir = QFileDialog.getSaveFileName( self, "Export Obstacle Data", QCoreApplication.applicationDirPath(), "ExportObstaclefiles(*.xml)") if filePathDir == "": return parameterList = self.getParameterList() DataHelper.saveExportResult(filePathDir, self.surfaceType, self.ui.tblObstacles, None, parameterList, resultHideColumnNames) def getParameterList(self): parameterList = [] parameterList.append(("general", "group")) parameterList.append( ("RNAV Specification", self.parametersPanel.cmbRnavSpecification.SelectedItem)) if self.parametersPanel.cmbRnavSpecification.SelectedIndex == 0: parameterList.append( ("ATT", self.parametersPanel.pnlTolerances.txtAtt.text() + "nm")) parameterList.append( ("XTT", self.parametersPanel.pnlTolerances.txtXtt.text() + "nm")) parameterList.append( ("1/2 A/W", self.parametersPanel.pnlTolerances.txtAsw.text() + "nm")) else: if self.parametersPanel.cmbPhaseOfFlight.currentIndex() != 0: parameterList.append( ("Aerodrome Reference Point(ARP)", "group")) longLatPoint = QgisHelper.Meter2Degree( float(self.parametersPanel.pnlArp.txtPointX.text()), float(self.parametersPanel.pnlArp.txtPointY.text())) parameterList.append( ("Lat", self.parametersPanel.pnlArp.txtLat.Value)) parameterList.append( ("Lon", self.parametersPanel.pnlArp.txtLong.Value)) parameterList.append( ("X", self.parametersPanel.pnlArp.txtPointX.text())) parameterList.append( ("Y", self.parametersPanel.pnlArp.txtPointY.text())) parameterList.append(("Waypoint", "group")) longLatPoint = QgisHelper.Meter2Degree( float(self.parametersPanel.pnlWaypoint1.txtPointX.text()), float(self.parametersPanel.pnlWaypoint1.txtPointY.text())) parameterList.append( ("Lat", self.parametersPanel.pnlWaypoint1.txtLat.Value)) parameterList.append( ("Lon", self.parametersPanel.pnlWaypoint1.txtLong.Value)) parameterList.append( ("X", self.parametersPanel.pnlWaypoint1.txtPointX.text())) parameterList.append( ("Y", self.parametersPanel.pnlWaypoint1.txtPointY.text())) parameterList.append( ("Cat.H", str(self.parametersPanel.chbCatH.Checked))) parameterList.append( (self.parametersPanel.chbCircularArcs.Caption, str(self.parametersPanel.chbCircularArcs.Checked))) parameterList.append(("Parameters", "group")) parameterList.append( ("Selection Mode", self.parametersPanel.cmbSelectionMode.SelectedItem)) parameterList.append( ("In-bound Track", "Plan : " + str(self.parametersPanel.pnlInbound.txtRadialPlan.Value) + define._degreeStr)) parameterList.append( ("", "Geodetic : " + str(self.parametersPanel.pnlInbound.txtRadialGeodetic.Value) + define._degreeStr)) # parameterList.append(("In-bound Track", self.parametersPanel.txtInbound.Value)) parameterList.append( ("Out-bound Track", "Plan : " + str(self.parametersPanel.pnlOutbound.txtRadialPlan.Value) + define._degreeStr)) parameterList.append( ("", "Geodetic : " + str(self.parametersPanel.pnlOutbound.txtRadialGeodetic.Value) + define._degreeStr)) # parameterList.append(("Out-bound Track", self.parametersPanel.txtOutbound.Value)) parameterList.append( ("IAS", str(self.parametersPanel.pnlIas.Value.Knots) + "kts")) parameterList.append( ("Altitude", str(self.parametersPanel.pnlAltitude.Value.Feet) + "ft")) parameterList.append(("ISA", str(self.parametersPanel.pnlIsa.Value))) parameterList.append( ("Bank Angle", str(self.parametersPanel.pnlBankAngle.Value))) parameterList.append( ("Wind", str(self.parametersPanel.pnlWind.Value.Knots) + "kts")) parameterList.append( ("Primary Moc", str(self.parametersPanel.pnlPrimaryMoc.Value.Metres) + "m")) parameterList.append( ("Construction Type", self.parametersPanel.cmbConstructionType.SelectedItem)) parameterList.append( ("MOCmultipiler", str(self.parametersPanel.mocSpinBox.value()))) if self.parametersPanel.cmbConstructionType.SelectedIndex == 0: parameterList.append( ("Draw Waypoint Tolerance", str(self.parametersPanel.chbDrawTolerance.Checked))) parameterList.append(("Results / Checked Obstacles", "group")) parameterList.append(("Checked Obstacles", "group")) c = self.obstaclesModel.rowCount() parameterList.append(("Number of Checked Obstacles", str(c))) return parameterList def uiStateInit(self): self.ui.grbMostCritical.setVisible(False) self.ui.grbResult_2.setVisible(False) self.ui.btnUpdateQA.setVisible(False) self.ui.btnUpdateQA_2.setVisible(False) self.ui.frm_cmbObstSurface.setVisible(False) self.ui.btnPDTCheck.setVisible(False) self.ui.tabCtrlGeneral.removeTab(2) self.ui.tabCtrlGeneral.removeTab(1) self.ui.btnEvaluate.setVisible(False) self.ui.btnConstruct.setVisible(False) # self.ui.btnPDTCheck.clicked.connect(self.btnPDTCheck_Click) return FlightPlanBaseDlg.uiStateInit(self) # def btnPDTCheck_Click(self): # pdtResultStr = MathHelper.pdtCheckResultToString(float(self.parametersPanel.txtIsa.text()), Altitude(float(self.parametersPanel.txtAltitude.text()), AltitudeUnits.FT), float(self.parametersPanel.txtIas.text()), float(self.parametersPanel.txtTime.text())) # # QMessageBox.warning(self, "PDT Check", pdtResultStr) def btnEvaluate_Click(self): # self.complexObstacleArea.ObstacleArea = None # # ObstacleTable.MocMultiplier = self.parametersPanel.mocSpinBox.value() # self.obstaclesModel = TurnProtectionAndObstacleAssessmentObstacles(self.complexObstacleArea, self.parametersPanel.pnlPrimaryMoc.Value, self.parametersPanel.pnlAltitude.Value, self.manualPolygon ) FlightPlanBaseDlg.btnEvaluate_Click(self) self.ui.btnLocate.setEnabled(True) def btnConstruct_Click(self): flag = FlightPlanBaseDlg.btnConstruct_Click(self) if not flag: return def outputResultMethod(self): self.manualPolygon = self.toolSelectByPolygon.polygonGeom def manualEvent(self, index): QgisHelper.ClearRubberBandInCanvas(define._canvas) self.manualPolygon = None if index != 0: self.toolSelectByPolygon = RubberBandPolygon(define._canvas) define._canvas.setMapTool(self.toolSelectByPolygon) self.connect(self.toolSelectByPolygon, SIGNAL("outputResult"), self.outputResultMethod) else: self.mapToolPan = QgsMapToolPan(define._canvas) define._canvas.setMapTool(self.mapToolPan) def initParametersPan(self): ui = Ui_NpaOnFix() self.parametersPanel = ui FlightPlanBaseDlg.initParametersPan(self) if self.dlgType != "NpaOnFix": self.parametersPanel.pnlDistFixTolerance.Visible = False self.parametersPanel.cmbAircraftCategory.Items = [ "A", "B", "C", "D", "E", "H", "Custom" ] self.connect(self.parametersPanel.pnlAerodromeAltitude, SIGNAL("editingFinished"), self.altitudeChanged) self.connect(self.parametersPanel.pnlIas, SIGNAL("Event_0"), self.altitudeChanged) self.connect(self.parametersPanel.pnlTas, SIGNAL("Event_0"), self.showMarkDaSoc) self.connect(self.parametersPanel.pnlIsa, SIGNAL("editingFinished"), self.altitudeChanged) self.connect(self.parametersPanel.pnlEstimatedAltitude, SIGNAL("Event_0"), self.pnlEstimatedAltitude_Event_0) self.connect(self.parametersPanel.pnlEstimatedAltitude, SIGNAL("editingFinished"), self.showMarkDaSoc) self.connect(self.parametersPanel.cmbAircraftCategory, SIGNAL("Event_0"), self.cmbAircraftCategory_Event_0) # # self.connect(self.parametersPanel.cmbPhaseOfFlight, SIGNAL("Event_0"), self.cmbPhaseOfFlightChanged) # # self.connect(self.parametersPanel.cmbSelectionMode, SIGNAL("Event_0"), self.manualEvent) # self.connect(self.parametersPanel.pnlHeightLoss, SIGNAL("Event_0"), self.pnlHeightLoss_Event_0) self.connect(self.parametersPanel.pnlDistFixTolerance, SIGNAL("editingFinished"), self.showMarkDaSoc) # self.connect(self.parametersPanel.pnlRDH, SIGNAL("editingFinished"), self.pnlRDH_Event_0) self.connect(self.parametersPanel.pnlDistX, SIGNAL("Event_0"), self.showMarkDaSoc) # # self.connect(self.parametersPanel.cmbType2, SIGNAL("Event_0"), self.method_31) # self.connect(self.parametersPanel.pnlFafPosition, SIGNAL("positionChanged"), self.calcRwyBearing) self.connect(self.parametersPanel.pnlMaPtPosition, SIGNAL("positionChanged"), self.calcRwyBearing) self.connect(self.parametersPanel.pnlThrPosition, SIGNAL("positionChanged"), self.showMarkDaSoc) self.parametersPanel.pnlFafPosition.btnCalculater.clicked.connect( self.pnlFafPosition_btnCalculater_clicked) self.parametersPanel.pnlMaPtPosition.btnCalculater.clicked.connect( self.pnlMaPtPosition_btnCalculater_clicked) # self.parametersPanel.cmbAircraftCategory.SelectedIndex = 0 # self.putAircraftSpeed() self.altitudeChanged() # self.putWithInHeightLoss() self.calcSocAltitude() def pnlFafPosition_btnCalculater_clicked(self): self.gbFAWP = self.parametersPanel.pnlFafPosition dlg = CalcDlg(self, RnavCommonWaypoint.FAWP, self.parametersPanel.cmbAircraftCategory.SelectedIndex, None, None, [ self.parametersPanel.pnlThrPosition.Point3d, self.parametersPanel.pnlRwyEndPosition.Point3d, None ]) dlg.setWindowTitle("Calculate FAF") dlg.groupBox_4.setVisible(False) dlg.groupBox_5.setVisible(False) dlg.resize(200, 100) dlg.txtForm.setText("") self.parameterCalcList = [] dlg.txtDistance.setEnabled(True) self.annotationFAWP.show() dlg.show() def pnlMaPtPosition_btnCalculater_clicked(self): self.gbMAWP = self.parametersPanel.pnlMaPtPosition dlg = CalcDlg(self, RnavCommonWaypoint.MAWP, self.parametersPanel.cmbAircraftCategory.SelectedIndex, None, None, [ self.parametersPanel.pnlThrPosition.Point3d, self.parametersPanel.pnlRwyEndPosition.Point3d, None ]) dlg.setWindowTitle("Calculate MAPt") dlg.groupBox_4.setVisible(False) dlg.groupBox_5.setVisible(False) dlg.resize(200, 100) dlg.txtForm.setText("") self.parameterCalcList = [] dlg.txtDistance.setEnabled(True) self.annotationMAPt.show() dlg.show() def putDistances(self): try: point3dThr = self.parametersPanel.pnlThrPosition.Point3d point3dFaf = self.parametersPanel.pnlFafPosition.Point3d point3dMapt = self.parametersPanel.pnlMaPtPosition.Point3d self.parametersPanel.pnlDistOfFafMapt.Value = Distance( MathHelper.calcDistance(point3dFaf, point3dMapt)) inboundTrackRad = Unit.ConvertDegToRad( self.parametersPanel.pnlInboundTrack.Value) inboundTrack180Rad = MathHelper.smethod_4(inboundTrackRad + math.pi) speedTas = self.parametersPanel.pnlTas.Value xDist = self.calcDAndXDistance(speedTas, Speed(10), 15) self.parametersPanel.pnlDistX.Caption = "X(10kts/15s)" if self.parametersPanel.cmbAircraftCategory.SelectedIndex == 5: xDist = self.calcDAndXDistance(speedTas, Speed(10), 5) self.parametersPanel.pnlDistX.Caption = "X(10kts/5s)" dDist = self.calcDAndXDistance(speedTas, Speed(10), 3) fixTolerance = 0.0 if self.dlgType == "NpaOnFix": fixTolerance = self.parametersPanel.pnlDistFixTolerance.Value.Metres socMaptDistMeters = fixTolerance + dDist + xDist socThrDistMeters = MathHelper.calcDistance( point3dMapt, point3dThr) - socMaptDistMeters sockBearing = inboundTrackRad self.socPoint3d = MathHelper.distanceBearingPoint( point3dMapt, sockBearing, socMaptDistMeters).smethod_167(self.calcSocAltitude()) self.parametersPanel.pnlDistD.Value = Distance(dDist) self.parametersPanel.pnlDistX.Value = Distance(xDist) self.parametersPanel.pnlDistOfMaptSoc.Value = Distance( socMaptDistMeters) self.parametersPanel.pnlDistOfSocThr.Value = Distance( MathHelper.calcDistance(self.socPoint3d, point3dThr) ) #MathHelper.calcDistance(point3dThr, self.daPoint3d)) # self.parametersPanel.pnlDistOfFafMapt.Value = Distance(MathHelper.calcDistance(point3dFaf, point3dMapt))#MathHelper.calcDistance(point3dThr, self.socPoint3d)) self.parametersPanel.pnlDistOfMaptThr.Value = Distance( MathHelper.calcDistance(point3dMapt, point3dThr)) except: pass def calcDAndXDistance(self, speed_0, speed_1, double_0): return Distance((speed_0 + speed_1).MetresPerSecond * double_0).Metres def showMarkDaSoc(self): try: flag = FlightPlanBaseDlg.btnConstruct_Click(self) self.putDistances() point3dMapt = self.parametersPanel.pnlMaPtPosition.Point3d socLayer = AcadHelper.createVectorLayer( "SOC_MAPt_" + self.surfaceType, QGis.Point) AcadHelper.setGeometryAndAttributesInLayer(socLayer, self.socPoint3d, False, {"Caption": "SOC"}) AcadHelper.setGeometryAndAttributesInLayer(socLayer, point3dMapt, False, {"Caption": "MAPt"}) QgisHelper.appendToCanvas(define._canvas, [socLayer], self.surfaceType) palSetting = QgsPalLayerSettings() palSetting.readFromLayer(socLayer) palSetting.enabled = True palSetting.fieldName = "Caption" palSetting.isExpression = True palSetting.placement = QgsPalLayerSettings.AroundPoint palSetting.setDataDefinedProperty(QgsPalLayerSettings.Size, True, True, '8', "") palSetting.writeToLayer(socLayer) self.resultLayerList = [socLayer] return socLayer except: pass def pnlEstimatedAltitude_Event_0(self): self.calcSocAltitude() def cmbAircraftCategory_Event_0(self): self.putAircraftSpeed() self.showMarkDaSoc() def calcSocAltitude(self): # val = self.parametersPanel.pnlEstimatedAltitude.Value.Metres - self.parametersPanel.pnlHeightLoss.Value.Metres self.parametersPanel.pnlSocAltitude.Value = Altitude( self.parametersPanel.pnlEstimatedAltitude.Value.Metres) return self.parametersPanel.pnlEstimatedAltitude.Value.Metres def altitudeChanged(self): self.parametersPanel.pnlWind.setAltitude( self.parametersPanel.pnlAerodromeAltitude.Value) try: self.parametersPanel.pnlTas.Value = Speed.smethod_0( self.parametersPanel.pnlIas.Value, self.parametersPanel.pnlIsa.Value, self.parametersPanel.pnlAerodromeAltitude.Value) self.showMarkDaSoc() except: raise ValueError("Value Invalid") def WPT2Layer(self): mapUnits = define._canvas.mapUnits() if define._mapCrs == None: if mapUnits == QGis.Meters: resultLayer = QgsVectorLayer( "Point?crs=EPSG:32633", "WPT_" + self.surfaceType.replace(" ", "_").replace("-", "_"), "memory") else: resultLayer = QgsVectorLayer( "Point?crs=EPSG:4326", "WPT_" + self.surfaceType.replace(" ", "_").replace("-", "_"), "memory") else: resultLayer = QgsVectorLayer( "Point?crs=%s" % define._mapCrs.authid(), "WPT_" + self.surfaceType.replace(" ", "_").replace("-", "_"), "memory") shpPath = "" if define.obstaclePath != None: shpPath = define.obstaclePath elif define.xmlPath != None: shpPath = define.xmlPath else: shpPath = define.appPath er = QgsVectorFileWriter.writeAsVectorFormat( resultLayer, shpPath + "/" + "RnavTurningSegmentAnalyserWpt" + ".shp", "utf-8", resultLayer.crs()) resultLayer = QgsVectorLayer( shpPath + "/" + "RnavTurningSegmentAnalyserWpt" + ".shp", "WPT_RnavTurningSegmentAnalyser", "ogr") fieldName = "CATEGORY" resultLayer.dataProvider().addAttributes( [QgsField(fieldName, QVariant.String)]) resultLayer.startEditing() fields = resultLayer.pendingFields() i = 1 feature = QgsFeature() feature.setFields(fields) feature.setGeometry( QgsGeometry.fromPoint(self.parametersPanel.pnlWaypoint1.Point3d)) feature.setAttribute(fieldName, "Waypoint1") pr = resultLayer.dataProvider() pr.addFeatures([feature]) # resultLayer.addFeature(feature) feature.setGeometry( QgsGeometry.fromPoint(self.parametersPanel.pnlWaypoint2.Point3d)) feature.setAttribute(fieldName, "Waypoint2") pr = resultLayer.dataProvider() pr.addFeatures([feature]) # resultLayer.addFeature(feature) resultLayer.commitChanges() renderCatFly = None if self.parametersPanel.cmbType1.SelectedIndex == 1: '''FlyOver''' symbolFlyOver = QgsSymbolV2.defaultSymbol( resultLayer.geometryType()) symbolFlyOver.deleteSymbolLayer(0) svgSymLayer = QgsSvgMarkerSymbolLayerV2("Resource/flyover.svg", 10.0, 0.0) symbolFlyOver.appendSymbolLayer(svgSymLayer) renderCatFly = QgsRendererCategoryV2(0, symbolFlyOver, "Fly Over") elif self.parametersPanel.cmbType1.SelectedIndex == 0: '''FlyBy''' symbolFlyBy = QgsSymbolV2.defaultSymbol(resultLayer.geometryType()) symbolFlyBy.deleteSymbolLayer(0) svgSymLayer = QgsSvgMarkerSymbolLayerV2("Resource/flyby.svg", 10.0, 0.0) symbolFlyBy.appendSymbolLayer(svgSymLayer) renderCatFly = QgsRendererCategoryV2(0, symbolFlyBy, "Fly By") else: return None WPT_EXPRESION = "CASE WHEN \"CATEGORY\" = 'Waypoint1' THEN 0 " + \ "END" symRenderer = QgsCategorizedSymbolRendererV2(WPT_EXPRESION, [renderCatFly]) resultLayer.setRendererV2(symRenderer) return resultLayer def putAircraftSpeed(self): speedTas = self.parametersPanel.pnlTas.Value if self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.H: xDist = self.calcDAndXDistance(speedTas, Speed(10), 5) self.parametersPanel.pnlDistX.Caption = "X(10kts/5s)" self.parametersPanel.pnlDistX.Value = Distance(xDist) else: xDist = self.calcDAndXDistance(speedTas, Speed(10), 15) self.parametersPanel.pnlDistX.Caption = "X(10kts/15s)" self.parametersPanel.pnlDistX.Value = Distance(xDist) if self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.A: self.parametersPanel.pnlIas.Value = Speed(100) # self.parametersPanel.pnlIas.Value = Speed(90) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.B: self.parametersPanel.pnlIas.Value = Speed(130) # self.parametersPanel.pnlIas.Value = Speed(120) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.C: self.parametersPanel.pnlIas.Value = Speed(160) # self.parametersPanel.pnlIas.Value = Speed(140) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.D: self.parametersPanel.pnlIas.Value = Speed(185) # self.parametersPanel.pnlIas.Value = Speed(165) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.E: self.parametersPanel.pnlIas.Value = Speed(230) # self.parametersPanel.pnlIas.Value = Speed(210) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.Custom: # self.parametersPanel.pnlIas.Value = self.customIas self.parametersPanel.pnlIas.Value = Speed(185) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.H: # self.parametersPanel.pnlIas.Value = self.customIas self.parametersPanel.pnlIas.Value = Speed(90) self.parametersPanel.pnlIas.Enabled = self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.Custom
def wplaceAnnotationsButton_click(self): annotations = self.getSelectedAnnotations() for anno in annotations: annoData = anno.data(1) annotation = QgsTextAnnotationItem(self.iface.mapCanvas()) #Make data accessible from annotation annotation.setData(1, annoData) doc = annotation.document() #"layer": self.getLayer(), #"srid": crs.postgisSrid(), #"label": label[0:256] , #"content": annotation.document().toHtml().replace("'","''"), doc.setHtml(annoData.get('content', None)) annotation.setDocument(doc) #"frame_color":annotation.frameColor().name(), color = QColor() color.setNamedColor(annoData.get('frame_color')) annotation.setFrameColor(color) #"bg_color": annotation.frameBackgroundColor().name(), color = QColor() color.setNamedColor(annoData.get('bg_color')) annotation.setFrameBackgroundColor(color) #"frame_width": frame_size.width(), #"frame_height": frame_size.height(), size = QSizeF() size.setWidth(annoData.get('frame_width')) size.setHeight(annoData.get('frame_height')) annotation.setFrameSize(size) #"frame_border_width": annotation.frameBorderWidth(), width = float(annoData.get('frame_border_width')) annotation.setFrameBorderWidth(width) #"map_position_x": map_position_x, #"map_position_y": map_position_y, map_position_x = float(annoData.get('map_position_x')) map_position_y = float(annoData.get('map_position_y')) annotation.setMapPosition(QgsPoint(map_position_x, map_position_y)) #"offset_x": ref_offset.x(), #"offset_y": ref_offset.y(), offset_x = float(annoData.get('offset_x')) offset_y = float(annoData.get('offset_y')) annotation.setOffsetFromReferencePoint(QPointF(offset_x, offset_y)) #"marker_symbol": json.dumps(self.dumpMarkerSymbol(marker)) marker_symbol = annoData.get('marker_symbol') new_marker_symbol = QgsMarkerSymbolV2() #'color':marker.color().name(), color = QColor() color.setNamedColor(marker_symbol.get('color')) new_marker_symbol.setColor(color) #'alpha':marker.alpha(), alpha = float(marker_symbol.get('alpha')) new_marker_symbol.setAlpha(alpha) #'output_unit': marker.outputUnit(), output_unit = marker_symbol.get('output_unit') new_marker_symbol.setOutputUnit(output_unit) #'angle': marker.angle(), angle = float(marker_symbol.get('angle')) new_marker_symbol.setAngle(angle) #'size': marker.size(), size = float(marker_symbol.get('size')) new_marker_symbol.setSize(size) #'size_unit': marker.sizeUnit(), size_unit = marker_symbol.get('size_unit') new_marker_symbol.setSizeUnit(size_unit) #'symbol_layers': [self.dumpSymbolLayer(layer) for layer in marker.symbolLayers()] for properties in marker_symbol.get('symbol_layers'): print properties #properties = json.loads(properties) new_symbol_layer = QgsSimpleMarkerSymbolLayerV2() new_symbol_layer.restoreDataDefinedProperties(properties) new_marker_symbol.appendSymbolLayer(new_symbol_layer) annotation.setMarkerSymbol(new_marker_symbol)
class PaIlsDlg(FlightPlanBaseDlg): def __init__(self, parent, dlgType): FlightPlanBaseDlg.__init__(self, parent) self.dlgType = dlgType self.setObjectName("PaIlsDlg") self.surfaceType = self.dlgType self.initParametersPan() self.setWindowTitle(self.dlgType) self.resize(540, 600) QgisHelper.matchingDialogSize(self, 720, 700) self.surfaceList = None self.manualPolygon = None self.mapToolPan = None self.toolSelectByPolygon = None self.accepted.connect(self.closed) self.rejected.connect(self.closed) self.wptLayer = None self.arpFeatureArray = [] self.currentLayer = define._canvas.currentLayer() self.rwyFeatureArray = [] self.rwyEndPosition = None self.initAerodromeAndRwyCmb() self.socRubber = None self.socAnnotation = QgsTextAnnotationItem(define._canvas) self.socAnnotation.setDocument(QTextDocument(Captions.SOC)) self.socAnnotation.setFrameBackgroundColor(Qt.white) self.socAnnotation.setFrameSize(QSizeF(30, 20)) self.socAnnotation.setFrameColor(Qt.magenta) self.socAnnotation.hide() self.socPoint3d = None self.daRubber = None self.daAnnotation = QgsTextAnnotationItem(define._canvas) self.daAnnotation.setDocument(QTextDocument(Captions.DA)) self.daAnnotation.setFrameBackgroundColor(Qt.white) self.daAnnotation.setFrameSize(QSizeF(30, 20)) self.daAnnotation.setFrameColor(Qt.magenta) self.daAnnotation.hide() self.daPoint3d = None self.annotationFAWP = self.parametersPanel.pnlFapPosition.annotation self.surfaceType = self.dlgType def initAerodromeAndRwyCmb(self): if self.currentLayer != None and self.currentLayer.isValid() and isinstance(self.currentLayer, QgsVectorLayer): self.arpFeatureArray = self.aerodromeAndRwyCmbFill(self.currentLayer, self.parametersPanel.cmbAerodrome, None, self.parametersPanel.cmbRwyDir) self.calcRwyBearing() def calcRwyBearing(self): try: point3dThr = self.parametersPanel.pnlThrPosition.Point3d point3dFap = self.parametersPanel.pnlFapPosition.Point3d if point3dThr == None: self.parametersPanel.pnlInboundTrack.Value = 0.0 return if point3dFap == None: self.parametersPanel.pnlInboundTrack.Value = round(Unit.ConvertRadToDeg(MathHelper.getBearing(point3dThr, self.parametersPanel.pnlRwyEndPosition.Point3d)), 4) point3dFap = self.rwyEndPosition else: self.parametersPanel.pnlInboundTrack.Value = round(Unit.ConvertRadToDeg(MathHelper.getBearing(point3dFap, point3dThr)), 4) self.showMarkDaSoc() except: pass # self.ui.horizontalLayout_6.addWidget(self.ui.frame_3) def aerodromeAndRwyCmbFill(self, layer, aerodromeCmbObj, aerodromePositionPanelObj, rwyDirCmbObj = None): idx = layer.fieldNameIndex('Type') idxName = layer.fieldNameIndex('Name') idxLat = layer.fieldNameIndex('Latitude') idxLong = layer.fieldNameIndex('Longitude') idxAltitude = layer.fieldNameIndex('Altitude') arpList = [] arpFeatureList = [] if idx >= 0: featIter = layer.getFeatures() for feat in featIter: attrValue = feat.attributes()[idx].toString() attrValue = QString(attrValue) attrValue = attrValue.replace(" ", "") attrValue = attrValue.toUpper() if attrValue == "AERODROMEREFERENCEPOINT": arpList.append(attrValue) arpFeatureList.append(feat) if len(arpList) != 0: i = -1 attrValueList = [] for feat in arpFeatureList: attrValue = feat.attributes()[idxName].toString() items = attrValueList if len(items) != 0: existFlag = False for item in items: if item == attrValue: existFlag = True if existFlag: continue attrValueList.append(attrValue) attrValueList.sort() # attrValueList.insert(0, "") aerodromeCmbObj.Items = attrValueList aerodromeCmbObj.SelectedIndex = 0 # if idxAttributes for feat in arpFeatureList: attrValue = feat.attributes()[idxName].toString() if attrValue != aerodromeCmbObj.SelectedItem: continue attrValue = feat.attributes()[idxLat].toDouble() lat = attrValue[0] attrValue = feat.attributes()[idxLong].toDouble() long = attrValue[0] attrValue = feat.attributes()[idxAltitude].toDouble() alt = attrValue[0] # aerodromePositionPanelObj.Point3d = Point3D(long, lat, alt) self.connect(aerodromeCmbObj, SIGNAL("Event_0"), self.aerodromeCmbObj_Event_0) break if rwyDirCmbObj != None: idxAttr = layer.fieldNameIndex('Attributes') if idxAttr >= 0: rwyFeatList = [] featIter = layer.getFeatures() rwyDirCmbObjItems = [] for feat in featIter: attrValue = feat.attributes()[idxAttr].toString() if attrValue == aerodromeCmbObj.SelectedItem: attrValue = feat.attributes()[idxName].toString() s = attrValue.replace(" ", "") compStr = s.left(6).toUpper() if compStr == "THRRWY": valStr = s.right(s.length() - 6) rwyDirCmbObjItems.append(aerodromeCmbObj.SelectedItem + " RWY " + valStr) rwyFeatList.append(feat) rwyDirCmbObjItems.sort() rwyDirCmbObj.Items = rwyDirCmbObjItems self.connect(rwyDirCmbObj, SIGNAL("Event_0"), self.rwyDirCmbObj_Event_0) self.rwyFeatureArray = rwyFeatList self.rwyDirCmbObj_Event_0() self.aerodromeCmbObj_Event_0() return arpFeatureList def rwyDirCmbObj_Event_0(self): if len(self.rwyFeatureArray) == 0: self.calcRwyBearing() return idxName = self.currentLayer.fieldNameIndex('Name') idxLat = self.currentLayer.fieldNameIndex('Latitude') idxLong = self.currentLayer.fieldNameIndex('Longitude') idxAltitude = self.currentLayer.fieldNameIndex('Altitude') idxAttr = self.currentLayer.fieldNameIndex('Attributes') # rwyFeatList = [] featIter = self.currentLayer.getFeatures() # for feat in featIter: # attrValue = feat.attributes()[idxAttr].toString() # if attrValue == self.cmbAerodrome.SelectedItem: # attrValue = feat.attributes()[idxName].toString() # s = attrValue.replace(" ", "") # compStr = s.left(6).toUpper() # if compStr == "THRRWY": # valStr = s.right(s.length() - 6) # rwyFeatList.append(feat) for feat in self.rwyFeatureArray: attrValue = feat.attributes()[idxName].toString() attrValueStr = QString(attrValue) attrValueStr = attrValueStr.replace(" ", "").right(attrValueStr.length() - 3) itemStr = self.parametersPanel.cmbRwyDir.SelectedItem itemStr = QString(itemStr) itemStr = itemStr.replace(" ", "").right(itemStr.length() - 4) if attrValueStr != itemStr: continue latAttrValue = feat.attributes()[idxLat].toDouble() lat = latAttrValue[0] longAttrValue = feat.attributes()[idxLong].toDouble() long = longAttrValue[0] altAttrValue = feat.attributes()[idxAltitude].toDouble() alt = altAttrValue[0] self.parametersPanel.pnlThrPosition.Point3d = Point3D(long, lat, alt) valStr = None if attrValue.right(1).toUpper() =="L" or attrValue.right(1).toUpper() =="R": s = attrValue.left(attrValue.length() - 1) valStr = s.right(2) else: valStr = attrValue.right(2) val = int(valStr) val += 18 if val > 36: val -= 36 newValStr = None if len(str(val)) == 1: newValStr = "0" + str(val) else: newValStr = str(val) otherAttrValue = attrValue.replace(valStr, newValStr) ss = otherAttrValue.right(1) if ss.toUpper() == "L": otherAttrValue = otherAttrValue.left(otherAttrValue.length() - 1) + "R" elif ss.toUpper() == "R": otherAttrValue = otherAttrValue.left(otherAttrValue.length() - 1) + "L" for feat in self.rwyFeatureArray: attrValue = feat.attributes()[idxName].toString() if attrValue != otherAttrValue: continue latAttrValue = feat.attributes()[idxLat].toDouble() lat = latAttrValue[0] longAttrValue = feat.attributes()[idxLong].toDouble() long = longAttrValue[0] altAttrValue = feat.attributes()[idxAltitude].toDouble() alt = altAttrValue[0] self.parametersPanel.pnlRwyEndPosition.Point3d = Point3D(long, lat, alt) break break self.calcRwyBearing() def aerodromeCmbObj_Event_0(self): if len(self.arpFeatureArray) == 0: return # self.parametersPanel.pnlArp.Point3d = None self.parametersPanel.pnlRwyEndPosition.Point3d = None self.parametersPanel.pnlThrPosition.Point3d = None idxName = self.currentLayer.fieldNameIndex('Name') idxLat = self.currentLayer.fieldNameIndex('Latitude') idxLong = self.currentLayer.fieldNameIndex('Longitude') idxAltitude = self.currentLayer.fieldNameIndex('Altitude') self.rwyFeatureArray = [] # if idxAttributes for feat in self.arpFeatureArray: attrValue = feat.attributes()[idxName].toString() if attrValue != self.parametersPanel.cmbAerodrome.SelectedItem: continue attrValue = feat.attributes()[idxLat].toDouble() lat = attrValue[0] attrValue = feat.attributes()[idxLong].toDouble() long = attrValue[0] attrValue = feat.attributes()[idxAltitude].toDouble() alt = attrValue[0] # self.parametersPanel.pnlArp.Point3d = Point3D(long, lat, alt) break idxAttr = self.currentLayer.fieldNameIndex('Attributes') if idxAttr >= 0: self.parametersPanel.cmbRwyDir.Clear() rwyFeatList = [] featIter = self.currentLayer.getFeatures() for feat in featIter: attrValue = feat.attributes()[idxAttr].toString() if attrValue == self.parametersPanel.cmbAerodrome.SelectedItem: attrValue = feat.attributes()[idxName].toString() s = attrValue.replace(" ", "") compStr = s.left(6).toUpper() if compStr == "THRRWY": valStr = s.right(s.length() - 6) self.parametersPanel.cmbRwyDir.Add(self.parametersPanel.cmbAerodrome.SelectedItem + " RWY " + valStr) rwyFeatList.append(feat) self.rwyFeatureArray = rwyFeatList self.rwyDirCmbObj_Event_0() def closed(self): if self.mapToolPan != None: self.mapToolPan.deactivate() if self.toolSelectByPolygon != None: self.toolSelectByPolygon.deactivate() def initObstaclesModel(self): self.obstaclesModel.MocMultiplier = self.parametersPanel.mocSpinBox.value() return FlightPlanBaseDlg.initObstaclesModel(self) def exportResult(self): result, resultHideColumnNames = FlightPlanBaseDlg.exportResult(self) if not result: return filePathDir = QFileDialog.getSaveFileName(self, "Export Obstacle Data", QCoreApplication.applicationDirPath (),"ExportObstaclefiles(*.xml)") if filePathDir == "": return parameterList = self.getParameterList() DataHelper.saveExportResult(filePathDir, self.surfaceType, self.ui.tblObstacles, None, parameterList, resultHideColumnNames) def getParameterList(self): parameterList = [] parameterList.append(("general", "group")) parameterList.append(("RNAV Specification", self.parametersPanel.cmbRnavSpecification.SelectedItem)) if self.parametersPanel.cmbRnavSpecification.SelectedIndex == 0: parameterList.append(("ATT", self.parametersPanel.pnlTolerances.txtAtt.text() + "nm")) parameterList.append(("XTT", self.parametersPanel.pnlTolerances.txtXtt.text() + "nm")) parameterList.append(("1/2 A/W", self.parametersPanel.pnlTolerances.txtAsw.text() + "nm")) else: if self.parametersPanel.cmbPhaseOfFlight.currentIndex() != 0: parameterList.append(("Aerodrome Reference Point(ARP)", "group")) longLatPoint = QgisHelper.Meter2Degree(float(self.parametersPanel.pnlArp.txtPointX.text()), float(self.parametersPanel.pnlArp.txtPointY.text())) parameterList.append(("Lat", self.parametersPanel.pnlArp.txtLat.Value)) parameterList.append(("Lon", self.parametersPanel.pnlArp.txtLong.Value)) parameterList.append(("X", self.parametersPanel.pnlArp.txtPointX.text())) parameterList.append(("Y", self.parametersPanel.pnlArp.txtPointY.text())) parameterList.append(("Waypoint", "group")) longLatPoint = QgisHelper.Meter2Degree(float(self.parametersPanel.pnlWaypoint1.txtPointX.text()), float(self.parametersPanel.pnlWaypoint1.txtPointY.text())) parameterList.append(("Lat", self.parametersPanel.pnlWaypoint1.txtLat.Value)) parameterList.append(("Lon", self.parametersPanel.pnlWaypoint1.txtLong.Value)) parameterList.append(("X", self.parametersPanel.pnlWaypoint1.txtPointX.text())) parameterList.append(("Y", self.parametersPanel.pnlWaypoint1.txtPointY.text())) parameterList.append(("Cat.H", str(self.parametersPanel.chbCatH.Checked))) parameterList.append((self.parametersPanel.chbCircularArcs.Caption, str(self.parametersPanel.chbCircularArcs.Checked))) parameterList.append(("Parameters", "group")) parameterList.append(("Selection Mode", self.parametersPanel.cmbSelectionMode.SelectedItem)) parameterList.append(("In-bound Track", "Plan : " + str(self.parametersPanel.pnlInbound.txtRadialPlan.Value) + define._degreeStr)) parameterList.append(("", "Geodetic : " + str(self.parametersPanel.pnlInbound.txtRadialGeodetic.Value) + define._degreeStr)) # parameterList.append(("In-bound Track", self.parametersPanel.txtInbound.Value)) parameterList.append(("Out-bound Track", "Plan : " + str(self.parametersPanel.pnlOutbound.txtRadialPlan.Value) + define._degreeStr)) parameterList.append(("", "Geodetic : " + str(self.parametersPanel.pnlOutbound.txtRadialGeodetic.Value) + define._degreeStr)) # parameterList.append(("Out-bound Track", self.parametersPanel.txtOutbound.Value)) parameterList.append(("IAS", str(self.parametersPanel.pnlIas.Value.Knots) + "kts")) parameterList.append(("Altitude", str(self.parametersPanel.pnlAltitude.Value.Feet) + "ft")) parameterList.append(("ISA", str(self.parametersPanel.pnlIsa.Value))) parameterList.append(("Bank Angle", str(self.parametersPanel.pnlBankAngle.Value))) parameterList.append(("Wind", str(self.parametersPanel.pnlWind.Value.Knots) + "kts")) parameterList.append(("Primary Moc", str(self.parametersPanel.pnlPrimaryMoc.Value.Metres) + "m")) parameterList.append(("Construction Type", self.parametersPanel.cmbConstructionType.SelectedItem)) parameterList.append(("MOCmultipiler", str(self.parametersPanel.mocSpinBox.value()))) if self.parametersPanel.cmbConstructionType.SelectedIndex == 0: parameterList.append(("Draw Waypoint Tolerance", str(self.parametersPanel.chbDrawTolerance.Checked))) parameterList.append(("Results / Checked Obstacles", "group")) parameterList.append(("Checked Obstacles", "group")) c = self.obstaclesModel.rowCount() parameterList.append(("Number of Checked Obstacles", str(c))) return parameterList def uiStateInit(self): self.ui.grbMostCritical.setVisible(False) self.ui.grbResult_2.setVisible(False) self.ui.btnUpdateQA.setVisible(False) self.ui.btnUpdateQA_2.setVisible(False) self.ui.frm_cmbObstSurface.setVisible(False) self.ui.btnPDTCheck.setVisible(False) self.ui.tabCtrlGeneral.removeTab(2) self.ui.tabCtrlGeneral.removeTab(1) self.ui.btnEvaluate.setVisible(False) self.ui.btnConstruct.setVisible(False) # self.ui.btnPDTCheck.clicked.connect(self.btnPDTCheck_Click) return FlightPlanBaseDlg.uiStateInit(self) # def btnPDTCheck_Click(self): # pdtResultStr = MathHelper.pdtCheckResultToString(float(self.parametersPanel.txtIsa.text()), Altitude(float(self.parametersPanel.txtAltitude.text()), AltitudeUnits.FT), float(self.parametersPanel.txtIas.text()), float(self.parametersPanel.txtTime.text())) # # QMessageBox.warning(self, "PDT Check", pdtResultStr) def btnEvaluate_Click(self): self.complexObstacleArea.ObstacleArea = None ObstacleTable.MocMultiplier = self.parametersPanel.mocSpinBox.value() # self.obstaclesModel = TurnProtectionAndObstacleAssessmentObstacles(self.complexObstacleArea, self.parametersPanel.pnlPrimaryMoc.Value, self.parametersPanel.pnlAltitude.Value, self.manualPolygon ) FlightPlanBaseDlg.btnEvaluate_Click(self) self.ui.btnLocate.setEnabled(True) def btnConstruct_Click(self): flag = FlightPlanBaseDlg.btnConstruct_Click(self) if not flag: return def outputResultMethod(self): self.manualPolygon = self.toolSelectByPolygon.polygonGeom def manualEvent(self, index): QgisHelper.ClearRubberBandInCanvas(define._canvas) self.manualPolygon = None if index != 0: self.toolSelectByPolygon = RubberBandPolygon(define._canvas) define._canvas.setMapTool(self.toolSelectByPolygon) self.connect(self.toolSelectByPolygon, SIGNAL("outputResult"), self.outputResultMethod) else: self.mapToolPan = QgsMapToolPan(define._canvas) define._canvas.setMapTool(self.mapToolPan ) def getVPA(self): num = 2.5 for i in range(0, self.parametersPanel.cmbVPA.SelectedIndex): num = num + 0.1 return num def putWithInHeightLoss(self): if self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.H: self.parametersPanel.pnlHeightLoss.Value = Altitude(35) return try: num = self.getVPA() num1 = self.parametersPanel.pnlThrPosition.Altitude().Metres num2 = self.parametersPanel.pnlIas.Value.Knots num3 = round(0.125 * num2 + 28.3) num4 = round(0.177 * num2 - 3.2) num5 = 0 if (num1 > 900): num5 = num5 + num4 * 0.02 * (num1 / 300) if (num > 3.2): num5 = num5 + num4 * 0.05 * ((num - 3.2) / 0.1) num5 = MathHelper.smethod_0(num5, 0) self.parametersPanel.pnlHeightLoss.Value = Altitude(num3 + num5) except: self.parametersPanel.pnlHeightLoss.Value = Altitude(0.0) def initParametersPan(self): ui = Ui_PaIls() self.parametersPanel = ui FlightPlanBaseDlg.initParametersPan(self) items = [] for i in range(25, 71): num = float(i) / 10 items.append(QString(str(num)) + define._degreeStr) self.parametersPanel.cmbVPA.Items = items self.parametersPanel.cmbVPA.SelectedIndex = 5 self.parametersPanel.cmbAircraftCategory.Items = ["A", "B", "C", "D", "E", "H", "Custom"] # self.parametersPanel.pnlWind.setAltitude(self.parametersPanel.pnlAltitude.Value) # # self.parametersPanel.cmbSelectionMode.Items = ["Automatic", "Manual"] # # self.parametersPanel.cmbConstructionType.Items = ["2D", "3D"] # self.parametersPanel.cmbType1.Items = ["Fly-By", "Fly-Over", "RF"] # self.parametersPanel.cmbType2.Items = ["Fly-By", "Fly-Over", "RF"] # # self.parametersPanel.cmbRnavSpecification.Items = ["", "Rnav5", "Rnav2", "Rnav1", "Rnp4", "Rnp2", "Rnp1", "ARnp2", "ARnp1", "ARnp09", "ARnp08", "ARnp07", "ARnp06", "ARnp05", "ARnp04", "ARnp03", "RnpApch"] # # self.connect(self.parametersPanel.pnlAerodromeAltitude, SIGNAL("Event_0"), self.altitudeChanged) self.connect(self.parametersPanel.pnlIas, SIGNAL("Event_0"), self.altitudeChanged) self.connect(self.parametersPanel.pnlIsa, SIGNAL("Event_0"), self.altitudeChanged) self.connect(self.parametersPanel.pnlEstimatedAltitude, SIGNAL("Event_0"), self.pnlEstimatedAltitude_Event_0) self.connect(self.parametersPanel.pnlEstimatedAltitude, SIGNAL("editingFinished"), self.showMarkDaSoc) self.connect(self.parametersPanel.cmbVPA, SIGNAL("Event_0"), self.cmbVPA_Event_0) self.connect(self.parametersPanel.cmbAircraftCategory, SIGNAL("Event_0"), self.cmbAircraftCategory_Event_0) # self.connect(self.parametersPanel.cmbPhaseOfFlight, SIGNAL("Event_0"), self.cmbPhaseOfFlightChanged) # self.connect(self.parametersPanel.cmbSelectionMode, SIGNAL("Event_0"), self.manualEvent) self.connect(self.parametersPanel.pnlHeightLoss, SIGNAL("Event_0"), self.pnlHeightLoss_Event_0) self.connect(self.parametersPanel.pnlHeightLoss, SIGNAL("editingFinished"), self.showMarkDaSoc) self.connect(self.parametersPanel.pnlRDH, SIGNAL("editingFinished"), self.pnlRDH_Event_0) self.connect(self.parametersPanel.pnlDistXz, SIGNAL("Event_0"), self.showMarkDaSoc) # self.connect(self.parametersPanel.cmbType2, SIGNAL("Event_0"), self.method_31) # self.connect(self.parametersPanel.pnlFapPosition, SIGNAL("positionChanged"), self.calcRwyBearing) self.connect(self.parametersPanel.pnlThrPosition, SIGNAL("positionChanged"), self.calcRwyBearing) self.parametersPanel.pnlFapPosition.btnCalculater.clicked.connect(self.pnlFapPosition_btnCalculater_clicked) # self.parametersPanel.cmbAircraftCategory.SelectedIndex = 0 self.putAircraftSpeed() self.altitudeChanged() self.putWithInHeightLoss() self.calcSocAltitude() self.putDistances() def pnlFapPosition_btnCalculater_clicked(self): self.gbFAWP = self.parametersPanel.pnlFapPosition dlg = CalcDlg(self, RnavCommonWaypoint.FAWP, self.parametersPanel.cmbAircraftCategory.SelectedIndex, None, None, [self.parametersPanel.pnlThrPosition.Point3d, self.parametersPanel.pnlRwyEndPosition.Point3d, None]) dlg.setWindowTitle("Calculate FAP") dlg.groupBox_4.setVisible(False) dlg.groupBox_5.setVisible(False) dlg.resize(200,100) dlg.txtForm.setText("") self.parameterCalcList = [] # if len(self.parameterCalcList) > 0 and self.parameterCalcList[0] != None : # str1, str2 = self.parameterCalcList[0] # calcFAWPDlg.txtBearing.setText(str1) # calcFAWPDlg.txtDistance.setText(str2) # calcFAWPDlg.txtBearing.setText("007.86") # calcFAWPDlg.txtDistance.setText("") dlg.txtDistance.setEnabled(True) self.annotationFAWP.show() dlg.show() # dlg = None # if self.parametersPanel.pnlRwyEndPosition.Point3d == None: # dlg = DlgFapCalcPosition(self, self.parametersPanel.pnlThrPosition, None, self.parametersPanel.pnlInboundTrack.Value) # else: # dlg = DlgFapCalcPosition(self, self.parametersPanel.pnlThrPosition, self.parametersPanel.pnlRwyEndPosition.Point3d) # dlg.show() # ` nauticalMiles = float(self.txtDistance.text()) # value = float(self.txtBearing.text()) # num1 = math.fabs(self.rethr - value) # if (num1 > 180): # num1 = 360 - num1 # num2 = math.sin(Unit.smethod_0(num1)) * 0.7559395 # num3 = Unit.smethod_1(math.asin(num2 / nauticalMiles)) # num4 = math.cos(Unit.smethod_0(num1)) * 0.755939525 # num5 = math.cos(Unit.smethod_0(num3)) * nauticalMiles # return RnavWaypoints.smethod_3(self.pos1400m, float(self.txtBearing.text()), Distance(math.fabs(num5 - num4), DistanceUnits.NM)) def putDistances(self): try: point3dThr = self.parametersPanel.pnlThrPosition.Point3d point3dFaf = self.parametersPanel.pnlFapPosition.Point3d point3dThr = self.parametersPanel.pnlThrPosition.Point3d # point3dFaf = self.parametersPanel.pnlFapPosition.Point3d inboundTrackRad = MathHelper.smethod_4(self.parametersPanel.pnlInboundTrack.Value)#MathHelper.getBearing(point3dFaf, point3dThr) inboundTrack180Rad = MathHelper.smethod_4(inboundTrackRad + math.pi) estimatedAltitdeMeters = self.parametersPanel.pnlEstimatedAltitude.Value.Metres thrAltitudeMeters = self.parametersPanel.pnlThrPosition.Altitude().Metres heightLossAltitudeMeters = self.parametersPanel.pnlHeightLoss.Value.Metres rdhAltitudeMeters = self.parametersPanel.pnlRDH.Value.Metres vpa = Unit.ConvertDegToRad(self.getVPA()) xz = self.parametersPanel.pnlDistXz.Value.Metres socThrDistMeters = ((estimatedAltitdeMeters - thrAltitudeMeters - heightLossAltitudeMeters) / math.tan(vpa)) + xz daThrDistMeters = (estimatedAltitdeMeters - thrAltitudeMeters - rdhAltitudeMeters) / math.tan(vpa) self.parametersPanel.pnlDistOfDaThr.Value = Distance(daThrDistMeters)#MathHelper.calcDistance(point3dThr, self.daPoint3d)) self.parametersPanel.pnlDistOfSocThr.Value = Distance(socThrDistMeters)#MathHelper.calcDistance(point3dThr, self.socPoint3d)) self.parametersPanel.pnlDistOfFafDA.Value = Distance(MathHelper.calcDistance(point3dFaf, self.daPoint3d)) except: pass def showMarkDaSoc(self): try: flag = FlightPlanBaseDlg.btnConstruct_Click(self) # if not flag: # return point3dThr = self.parametersPanel.pnlThrPosition.Point3d point3dFaf = self.parametersPanel.pnlFapPosition.Point3d inboundTrackRad = Unit.ConvertDegToRad(self.parametersPanel.pnlInboundTrack.Value)#MathHelper.getBearing(point3dFaf, point3dThr) inboundTrack180Rad = MathHelper.smethod_4(inboundTrackRad + math.pi) estimatedAltitdeMeters = self.parametersPanel.pnlEstimatedAltitude.Value.Metres thrAltitudeMeters = self.parametersPanel.pnlThrPosition.Altitude().Metres heightLossAltitudeMeters = self.parametersPanel.pnlHeightLoss.Value.Metres rdhAltitudeMeters = self.parametersPanel.pnlRDH.Value.Metres vpa = Unit.ConvertDegToRad(self.getVPA()) xz = self.parametersPanel.pnlDistXz.Value.Metres socThrDistMeters = ((estimatedAltitdeMeters - thrAltitudeMeters - heightLossAltitudeMeters) / math.tan(vpa)) + xz daThrDistMeters = (estimatedAltitdeMeters - thrAltitudeMeters - rdhAltitudeMeters) / math.tan(vpa) sockBearing = inboundTrackRad # if socThrDistMeters < 0: # sockBearing = inboundTrack180Rad # socThrDistMeters = math.fabs(socThrDistMeters) # else: # sockBearing = inboundTrackRad daBearing = inboundTrack180Rad # if daThrDistMeters < 0: # daBearing = inboundTrackRad # daThrDistMeters = math.fabs(daThrDistMeters) # else: # daBearing = inboundTrack180Rad self.socPoint3d = MathHelper.distanceBearingPoint(point3dThr, sockBearing, -socThrDistMeters).smethod_167(self.calcSocAltitude()) self.daPoint3d = MathHelper.distanceBearingPoint(point3dThr, daBearing, daThrDistMeters) daSocLayer = AcadHelper.createVectorLayer("DA_SOC_" + self.surfaceType, QGis.Point) AcadHelper.setGeometryAndAttributesInLayer(daSocLayer, self.socPoint3d, False, {"Caption":"SOC"}) AcadHelper.setGeometryAndAttributesInLayer(daSocLayer, self.daPoint3d, False, {"Caption":"DA"}) QgisHelper.appendToCanvas(define._canvas, [daSocLayer], self.surfaceType) palSetting = QgsPalLayerSettings() palSetting.readFromLayer(daSocLayer) palSetting.enabled = True palSetting.fieldName = "Caption" palSetting.isExpression = True palSetting.placement = QgsPalLayerSettings.AroundPoint palSetting.setDataDefinedProperty(QgsPalLayerSettings.Size, True, True, '8', "") palSetting.writeToLayer(daSocLayer) QgisHelper.zoomToLayers([daSocLayer]) self.resultLayerList = [daSocLayer] # # show SOC Mark # point3d = MathHelper.distanceBearingPoint(self.socPoint3d, Unit.ConvertDegToRad(450) - 0, 100) # point3d1 = MathHelper.distanceBearingPoint(self.socPoint3d, Unit.ConvertDegToRad(450) - math.pi / 2, 100) # point3d2 = MathHelper.distanceBearingPoint(self.socPoint3d, Unit.ConvertDegToRad(450) - math.pi, 100) # point3d3 = MathHelper.distanceBearingPoint(self.socPoint3d, Unit.ConvertDegToRad(450) - (math.pi * 3) / 2 , 100) # # if self.socRubber == None: # self.socRubber = QgsRubberBand(define._canvas, QGis.Line) # self.socRubber.setColor(Qt.yellow) # else: # self.socRubber.reset(QGis.Line) # self.socRubber.addGeometry(QgsGeometry.fromPolyline([point3d, point3d2]), None) # self.socRubber.addGeometry(QgsGeometry.fromPolyline([point3d1, point3d3]), None) # circle = MathHelper.constructCircle(self.socPoint3d, 100, 16) # self.socRubber.addGeometry(QgsGeometry.fromPolyline(circle), None) # self.socRubber.show() # # self.socAnnotation.setMapPosition(self.socPoint3d) # self.socAnnotation.show() # # # show DA Mark # point3d = MathHelper.distanceBearingPoint(self.daPoint3d, Unit.ConvertDegToRad(450) - 0, 100) # point3d1 = MathHelper.distanceBearingPoint(self.daPoint3d, Unit.ConvertDegToRad(450) - math.pi / 2, 100) # point3d2 = MathHelper.distanceBearingPoint(self.daPoint3d, Unit.ConvertDegToRad(450) - math.pi, 100) # point3d3 = MathHelper.distanceBearingPoint(self.daPoint3d, Unit.ConvertDegToRad(450) - (math.pi * 3) / 2 , 100) # # if self.daRubber == None: # self.daRubber = QgsRubberBand(define._canvas, QGis.Line) # self.daRubber.setColor(Qt.yellow) # else: # self.daRubber.reset(QGis.Line) # self.daRubber.addGeometry(QgsGeometry.fromPolyline([point3d, point3d2]), None) # self.daRubber.addGeometry(QgsGeometry.fromPolyline([point3d1, point3d3]), None) # circle = MathHelper.constructCircle(self.daPoint3d, 100, 16) # self.daRubber.addGeometry(QgsGeometry.fromPolyline(circle), None) # self.daRubber.show() # # self.daAnnotation.setMapPosition(self.daPoint3d) # self.daAnnotation.show() self.putDistances() return daSocLayer except: pass def pnlHeightLoss_Event_0(self): self.calcSocAltitude() self.putDistances() def pnlRDH_Event_0(self): self.showMarkDaSoc() def pnlEstimatedAltitude_Event_0(self): self.calcSocAltitude() self.putDistances() def cmbVPA_Event_0(self): self.putWithInHeightLoss() self.showMarkDaSoc() def cmbAircraftCategory_Event_0(self): if self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.H: self.parametersPanel.pnlDistXz.Value = Distance(-700) self.parametersPanel.pnlDistXz.Enabled = False elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.Custom: self.parametersPanel.pnlDistXz.Enabled = True else: self.parametersPanel.pnlDistXz.Enabled = False if self.dlgType == SurfaceTypes.BARO_VNAV: for case in switch(self.parametersPanel.cmbAircraftCategory.SelectedIndex): if case(AircraftSpeedCategory.A) or case(AircraftSpeedCategory.B): self.parametersPanel.pnlDistXz.Value = Distance(-900) elif case(AircraftSpeedCategory.C): self.parametersPanel.pnlDistXz.Value = Distance(-1100) elif case(AircraftSpeedCategory.D): self.parametersPanel.pnlDistXz.Value = Distance(-1400) elif case(AircraftSpeedCategory.E): self.parametersPanel.pnlDistXz.Value = Distance(-1400) else: self.parametersPanel.pnlDistXz.Value = Distance(-900) self.putAircraftSpeed() self.putWithInHeightLoss() def calcSocAltitude(self): val = self.parametersPanel.pnlEstimatedAltitude.Value.Metres - self.parametersPanel.pnlHeightLoss.Value.Metres self.parametersPanel.pnlSocAltitude.Value = Altitude(val) return val def altitudeChanged(self): self.parametersPanel.pnlWind.setAltitude(self.parametersPanel.pnlAerodromeAltitude.Value) try: self.parametersPanel.pnlTas.Value = Speed.smethod_0(self.parametersPanel.pnlIas.Value, self.parametersPanel.pnlIsa.Value, self.parametersPanel.pnlAerodromeAltitude.Value) except: raise ValueError("Value Invalid") def WPT2Layer(self): mapUnits = define._canvas.mapUnits() if define._mapCrs == None: if mapUnits == QGis.Meters: resultLayer = QgsVectorLayer("Point?crs=EPSG:32633", "WPT_" + self.surfaceType.replace(" ", "_").replace("-", "_"), "memory") else: resultLayer = QgsVectorLayer("Point?crs=EPSG:4326", "WPT_" + self.surfaceType.replace(" ", "_").replace("-", "_"), "memory") else: resultLayer = QgsVectorLayer("Point?crs=%s"%define._mapCrs.authid (), "WPT_" + self.surfaceType.replace(" ", "_").replace("-", "_"), "memory") shpPath = "" if define.obstaclePath != None: shpPath = define.obstaclePath elif define.xmlPath != None: shpPath = define.xmlPath else: shpPath = define.appPath er = QgsVectorFileWriter.writeAsVectorFormat(resultLayer, shpPath + "/" + "RnavTurningSegmentAnalyserWpt" + ".shp", "utf-8", resultLayer.crs()) resultLayer = QgsVectorLayer(shpPath + "/" + "RnavTurningSegmentAnalyserWpt" + ".shp", "WPT_RnavTurningSegmentAnalyser", "ogr") fieldName = "CATEGORY" resultLayer.dataProvider().addAttributes( [QgsField(fieldName, QVariant.String)] ) resultLayer.startEditing() fields = resultLayer.pendingFields() i = 1 feature = QgsFeature() feature.setFields(fields) feature.setGeometry(QgsGeometry.fromPoint (self.parametersPanel.pnlWaypoint1.Point3d)) feature.setAttribute(fieldName, "Waypoint1") pr = resultLayer.dataProvider() pr.addFeatures([feature]) # resultLayer.addFeature(feature) feature.setGeometry(QgsGeometry.fromPoint (self.parametersPanel.pnlWaypoint2.Point3d)) feature.setAttribute(fieldName, "Waypoint2") pr = resultLayer.dataProvider() pr.addFeatures([feature]) # resultLayer.addFeature(feature) resultLayer.commitChanges() renderCatFly = None if self.parametersPanel.cmbType1.SelectedIndex == 1: '''FlyOver''' symbolFlyOver = QgsSymbolV2.defaultSymbol(resultLayer.geometryType()) symbolFlyOver.deleteSymbolLayer(0) svgSymLayer = QgsSvgMarkerSymbolLayerV2("Resource/flyover.svg", 10.0, 0.0) symbolFlyOver.appendSymbolLayer(svgSymLayer) renderCatFly = QgsRendererCategoryV2(0, symbolFlyOver,"Fly Over") elif self.parametersPanel.cmbType1.SelectedIndex == 0: '''FlyBy''' symbolFlyBy = QgsSymbolV2.defaultSymbol(resultLayer.geometryType()) symbolFlyBy.deleteSymbolLayer(0) svgSymLayer = QgsSvgMarkerSymbolLayerV2("Resource/flyby.svg", 10.0, 0.0) symbolFlyBy.appendSymbolLayer(svgSymLayer) renderCatFly = QgsRendererCategoryV2(0, symbolFlyBy,"Fly By") else: return None WPT_EXPRESION = "CASE WHEN \"CATEGORY\" = 'Waypoint1' THEN 0 " + \ "END" symRenderer = QgsCategorizedSymbolRendererV2(WPT_EXPRESION, [renderCatFly]) resultLayer.setRendererV2(symRenderer) return resultLayer def putAircraftSpeed(self): if self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.A: # self.parametersPanel.pnlIas.Value = Speed(100) self.parametersPanel.pnlIas.Value = Speed(90) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.B: # self.parametersPanel.pnlIas.Value = Speed(130) self.parametersPanel.pnlIas.Value = Speed(120) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.C: # self.parametersPanel.pnlIas.Value = Speed(160) self.parametersPanel.pnlIas.Value = Speed(140) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.D: # self.parametersPanel.pnlIas.Value = Speed(185) self.parametersPanel.pnlIas.Value = Speed(165) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.E: # self.parametersPanel.pnlIas.Value = Speed(230) self.parametersPanel.pnlIas.Value = Speed(210) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.Custom: # self.parametersPanel.pnlIas.Value = self.customIas self.parametersPanel.pnlIas.Value = Speed(165) elif self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.H: # self.parametersPanel.pnlIas.Value = self.customIas self.parametersPanel.pnlIas.Value = Speed(90) self.parametersPanel.pnlIas.Enabled = self.parametersPanel.cmbAircraftCategory.SelectedIndex == AircraftSpeedCategory.Custom
def run(self): project_id = self.settings.value("project/id") epsg = self.settings.value("project/epsg") locale = QSettings().value('locale/userLocale')[0:2] if not project_id: self.message_bar.pushCritical( "Error", _translate("VeriSO_EE_Geb_LokTest", "project_id not set", None)) return QApplication.setOverrideCursor(Qt.WaitCursor) try: group = _translate("VeriSO_EE_Geb_LokTest", "Gebaeudeadressen - Lokalisationstest", None) group += " (" + str(project_id) + ")" # TODO: Check "tid" vs. t_ili_tid... in queries. Do not import # i_ili_tid? # define layer names here lokalisation = _translate("VeriSO_EE_Geb_LokTest", "Lokalisation Lokalisationstest", None) strassenstueck_geometrie = _translate( "VeriSO_EE_Geb_LokTest", "Strassenstueck (geometrie) " "Lokalisationstest", None) strassenstueck_anfangspunkt = _translate( "VeriSO_EE_Geb_LokTest", "Strassenstueck (" "anfangspunkt) " "Lokalisationstest", None) benanntesgebiet = _translate("VeriSO_EE_Geb_LokTest", "Benanntes Gebiet Lokalisationstest", None) gebaeudeeingang = _translate("VeriSO_EE_Geb_LokTest", "Gebaeudeeingang Lokalisationstest", None) shortestline = _translate("VeriSO_EE_Geb_LokTest", "Kuerzeste Linie Lokalisationstest", None) hausnummerpos = _translate("VeriSO_EE_Geb_LokTest", "HausnummerPos Lokalisationstest", None) lokalisationsname = _translate("VeriSO_EE_Geb_LokTest", "LokalisationsName", None) vlayer_lokalisation = self.get_vector_layer_by_name(lokalisation) if not vlayer_lokalisation: layer = { "type": "postgres", "title": lokalisation, "featuretype": "gebaeudeadressen_lokalisation", "key": "ogc_fid", "sql": "ogc_fid = -1", "readonly": True, "group": group } vlayer_lokalisation = self.layer_loader.load(layer) vlayer_strassenstueck_geometrie = self.get_vector_layer_by_name( strassenstueck_geometrie) if not vlayer_strassenstueck_geometrie: layer = { "type": "postgres", "title": "Strassenstueck (geometrie) Lokalisationstest", "featuretype": "gebaeudeadressen_strassenstueck", "geom": "geometrie", "key": "ogc_fid", "sql": "strassenstueck_von = -1", "readonly": True, "group": group, "style": "global_qml/gebaeudeadressen/strassenachsen_rot" ".qml" } vlayer_strassenstueck_geometrie = self.layer_loader.load(layer) vlayer_strassenstueck_anfangspunkt = self.get_vector_layer_by_name( strassenstueck_anfangspunkt) if not vlayer_strassenstueck_anfangspunkt: layer = { "type": "postgres", "title": "Strassenstueck (anfangspunkt) Lokalisationstest", "featuretype": "gebaeudeadressen_strassenstueck", "geom": "anfangspunkt", "key": "ogc_fid", "sql": "strassenstueck_von = -1", "readonly": True, "group": group, "style": "global_qml/gebaeudeadressen/anfangspunkt_rot.qml" } vlayer_strassenstueck_anfangspunkt = self.layer_loader.load( layer) vlayer_benanntesgebiet = self.get_vector_layer_by_name( benanntesgebiet) if not vlayer_benanntesgebiet: layer = { "type": "postgres", "title": "Benanntes Gebiet Lokalisationstest", "featuretype": "gebaeudeadressen_benanntesgebiet", "geom": "flaeche", "key": "ogc_fid", "sql": "benanntesgebiet_von = -1", "readonly": True, "group": group, "style": "global_qml/gebaeudeadressen/benanntesgebiet_rot" ".qml" } vlayer_benanntesgebiet = self.layer_loader.load(layer) vlayer_gebaeudeeingang = self.get_vector_layer_by_name( gebaeudeeingang) if not vlayer_gebaeudeeingang: layer = { "type": "postgres", "title": "Gebaeudeeingang Lokalisationstest", "featuretype": "gebaeudeadressen_gebaeudeeingang", "geom": "lage", "key": "ogc_fid", "sql": "gebaeudeeingang_von = -1", "readonly": True, "group": group, "style": "global_qml/gebaeudeadressen/gebaeudeeingang_rot" ".qml" } vlayer_gebaeudeeingang = self.layer_loader.load(layer) vlayer_shortestline = self.get_vector_layer_by_name(shortestline) if not vlayer_shortestline: layer = { "type": "postgres", "title": "Kuerzeste Linie Lokalisationstest", "featuretype": "t_shortestline_hausnummerpos", "geom": "the_geom", "key": "ogc_fid", "sql": "lok_tid = -1", "readonly": True, "group": group, "style": "global_qml/gebaeudeadressen/shortestline_linie_rot.qml" } vlayer_shortestline = self.layer_loader.load(layer) vlayer_hausnummerpos = self.get_vector_layer_by_name(hausnummerpos) if not vlayer_hausnummerpos: layer = { "type": "postgres", "title": "HausnummerPos Lokalisationstest", "featuretype": "v_gebaeudeadressen_hausnummerpos", "geom": "pos", "key": "ogc_fid", "sql": "lok_tid = -1", "readonly": True, "group": group, "style": "global_qml/gebaeudeadressen/hausnummerpos_rot.qml" } vlayer_hausnummerpos = self.layer_loader.load(layer) vlayer_lokalisationsname = self.get_vector_layer_by_name( lokalisationsname) if not vlayer_lokalisationsname: self.message_bar.pushMessage( "Error", _translate("VeriSO_EE_Geb_LokTest", "Layer _LokalisationsName_ not found.", None), level=QgsMessageBar.CRITICAL, duration=0) QApplication.restoreOverrideCursor() return iterator = vlayer_lokalisationsname.getFeatures() ids = [] for feature in iterator: ids.append(feature.id()) if vlayer_lokalisationsname.selectedFeatureCount() < 1: self.message_bar.pushCritical( "Error", _translate("VeriSO_EE_Geb_LokTest", "No _LokalisationsName_ selected.", None)) QApplication.restoreOverrideCursor() return if vlayer_lokalisationsname.selectedFeatureCount() > 1: self.message_bar.pushCritical( "Error", _translate( "VeriSO_EE_Geb_LokTest", "Please select only one (1) _LokalisationsName_.", None)) QApplication.restoreOverrideCursor() return feat = QgsFeature() id = vlayer_lokalisationsname.selectedFeaturesIds()[0] feat = vlayer_lokalisationsname.selectedFeatures()[0] idx = ids.index(id) benannte_idx = vlayer_lokalisationsname.fieldNameIndex("benannte") text_idx = vlayer_lokalisationsname.fieldNameIndex("atext") if benannte_idx == -1 or text_idx == -1: self.message_bar.pushCritical( "Error", _translate("VeriSO_EE_Geb_LokTest", "Field _benannte_ or _text_ not found.", None)) QApplication.restoreOverrideCursor() return benannte = feat.attributes()[benannte_idx] lokalisationsname = feat.attributes()[text_idx] vlayer_strassenstueck_geometrie.setSubsetString( "(strassenstueck_von = " + str(benannte) + ")") vlayer_strassenstueck_anfangspunkt.setSubsetString( "(strassenstueck_von = " + str(benannte) + ")") vlayer_benanntesgebiet.setSubsetString("(benanntesgebiet_von = " + str(benannte) + ")") vlayer_gebaeudeeingang.setSubsetString("(gebaeudeeingang_von = " + str(benannte) + ")") vlayer_lokalisation.setSubsetString("(ogc_fid = " + str(benannte) + ")") vlayer_shortestline.setSubsetString("(lok_tid = " + str(benannte) + ")") vlayer_hausnummerpos.setSubsetString("(lok_tid = " + str(benannte) + ")") if vlayer_strassenstueck_geometrie.featureCount() > 0: x_min = vlayer_strassenstueck_geometrie.extent().xMinimum() y_min = vlayer_strassenstueck_geometrie.extent().yMinimum() x_max = vlayer_strassenstueck_geometrie.extent().xMaximum() y_max = vlayer_strassenstueck_geometrie.extent().yMaximum() if vlayer_benanntesgebiet.featureCount() > 0: x_min = vlayer_benanntesgebiet.extent().xMinimum() y_min = vlayer_benanntesgebiet.extent().yMinimum() x_max = vlayer_benanntesgebiet.extent().xMaximum() y_max = vlayer_benanntesgebiet.extent().yMaximum() try: if vlayer_gebaeudeeingang.featureCount() > 0: if vlayer_gebaeudeeingang.extent().xMinimum() < x_min: x_min = vlayer_gebaeudeeingang.extent().xMinimum() if vlayer_gebaeudeeingang.extent().yMinimum() < y_min: y_min = vlayer_gebaeudeeingang.extent().yMinimum() if vlayer_gebaeudeeingang.extent().xMaximum() > x_max: x_max = vlayer_gebaeudeeingang.extent().xMaximum() if vlayer_gebaeudeeingang.extent().yMaximum() > y_max: y_max = vlayer_gebaeudeeingang.extent().yMaximum() rect = QgsRectangle(x_min, y_min, x_max, y_max) rect.scale(1.3) except UnboundLocalError: vlayer_gemeindegrenze = self.getVectorLayerByName( "Gemeindegrenze") if vlayer_gemeindegrenze is None: rect = self.canvas.fullExtent() else: rect = vlayer_gemeindegrenze.extent() self.iface.mapCanvas().setExtent(rect) self.iface.mapCanvas().refresh() iterator = vlayer_lokalisation.getFeatures() # only one feature is selected for feature in iterator: prinzip_idx = vlayer_lokalisation.fieldNameIndex( "nummerierungsprinzip_txt") attributeprovisorisch_idx = vlayer_lokalisation.fieldNameIndex( "attributeprovisorisch_txt") offiziell_idx = vlayer_lokalisation.fieldNameIndex( "istoffiziellebezeichnung_txt") status_idx = vlayer_lokalisation.fieldNameIndex("status_txt") inaenderung_idx = vlayer_lokalisation.fieldNameIndex( "inaenderung_txt") art_idx = vlayer_lokalisation.fieldNameIndex("art_txt") something_missing = (prinzip_idx == -1 or attributeprovisorisch_idx == -1 or offiziell_idx == -1 or status_idx == -1 or inaenderung_idx == -1 or art_idx == -1) if something_missing: self.message_bar.pushMessage("Error", _translate( "VeriSO_EE_Geb_LokTest", "Field not found.", None), level=QgsMessageBar.CRITICAL, duration=0) QApplication.restoreOverrideCursor() return prinzip = feature.attributes()[prinzip_idx] attributeprovisorisch = feature.attributes( )[attributeprovisorisch_idx] offiziell = feature.attributes()[offiziell_idx] status = feature.attributes()[status_idx] inaenderung = feature.attributes()[inaenderung_idx] art = feature.attributes()[art_idx] map_extent = self.canvas.extent() x = map_extent.xMinimum() y = map_extent.yMaximum() text_item_found = False items = list(self.iface.mapCanvas().scene().items()) for i in range(len(items)): try: name = items[i].data(0) if str(name) == "LokalisationsInfo": text_item = items[i] text_item_found = True except Exception: pass if not text_item_found: text_item = QgsTextAnnotationItem(self.canvas) text_item.setData(0, "LokalisationsInfo") # noinspection PyUnboundLocalVariable text_item.setMapPosition( QgsPoint(x + 10 * self.canvas.mapUnitsPerPixel(), y - 10 * self.canvas.mapUnitsPerPixel())) text_item.setMapPositionFixed(False) text_item.setFrameBorderWidth(0.0) text_item.setFrameColor(QColor(250, 250, 250, 255)) text_item.setFrameBackgroundColor(QColor(250, 250, 250, 123)) text_item.setFrameSize(QSizeF(250, 150)) text_document = QTextDocument() text_document.setHtml( "<table style='font-size:12px;'><tr><td>Lok.Name: </td><td>" + lokalisationsname + "</td></tr><tr><td>TID: </td><td>" + str(benannte) + "</td></tr> <tr><td>Num.prinzip: " "</td><td>" + str(prinzip) + "</td></tr> <tr><td>Attr. prov.: </td><td>" + str(attributeprovisorisch) + "</td></tr> <tr><td>ist " "offiziell: </td><td>" + str(offiziell) + "</td></tr> <tr><td>Status: " "</td><td>" + str(status) + "</td></tr> <tr><td>in Aenderung: " "</td><td>" + str(inaenderung) + "</td></tr> <tr><td>Art: " "</td><td>" + str(art) + "</td></tr> </table>") text_item.setDocument(text_document) # This is a workaround: first ever position is not correct. text_item.setMapPosition( QgsPoint(x + 10 * self.canvas.mapUnitsPerPixel(), y - 10 * self.canvas.mapUnitsPerPixel())) text_item.update() self.iface.mapCanvas().refresh() try: vlayer_lokalisationsname.setSelectedFeatures([ids[idx + 1]]) except IndexError: self.message_bar.pushInfo( "Information", _translate("VeriSO_EE_Geb_LokTest", "End of table.", None)) except Exception as e: QApplication.restoreOverrideCursor() exc_type, exc_value, exc_traceback = sys.exc_info() self.message_bar.pushMessage( "Error", str(traceback.format_exc(exc_traceback)), level=QgsMessageBar.CRITICAL, duration=0) QApplication.restoreOverrideCursor() QApplication.restoreOverrideCursor()