mirror of
https://github.com/dcs-retribution/dcs-retribution.git
synced 2025-11-10 15:41:24 +00:00
Stop using "CAP". Use BARCAP or TARCAP instead. TARCAP no longer allowed anywhere but front lines, since that's all we have mission planning for right now. Later will add TARCAP and BARCAP for all objective types with different timing profiles. Part two of the fix for https://github.com/Khopa/dcs_liberation/issues/210.
161 lines
5.9 KiB
Python
161 lines
5.9 KiB
Python
from typing import List, Optional
|
|
|
|
from PySide2.QtCore import Signal
|
|
from PySide2.QtWidgets import (
|
|
QFrame,
|
|
QGridLayout,
|
|
QLabel,
|
|
QMessageBox,
|
|
QPushButton,
|
|
QVBoxLayout,
|
|
)
|
|
|
|
from game import Game
|
|
from gen.ato import Package
|
|
from gen.flights.flight import Flight, FlightType
|
|
from gen.flights.flightplan import FlightPlanBuilder
|
|
from qt_ui.windows.mission.flight.waypoints.QFlightWaypointList import \
|
|
QFlightWaypointList
|
|
from qt_ui.windows.mission.flight.waypoints.QPredefinedWaypointSelectionWindow import \
|
|
QPredefinedWaypointSelectionWindow
|
|
from theater import ControlPoint, FrontLine
|
|
|
|
|
|
class QFlightWaypointTab(QFrame):
|
|
|
|
on_flight_changed = Signal()
|
|
|
|
def __init__(self, game: Game, package: Package, flight: Flight):
|
|
super(QFlightWaypointTab, self).__init__()
|
|
self.game = game
|
|
self.package = package
|
|
self.flight = flight
|
|
self.planner = FlightPlanBuilder(self.game, package, is_player=True)
|
|
|
|
self.flight_waypoint_list: Optional[QFlightWaypointList] = None
|
|
self.ascend_waypoint: Optional[QPushButton] = None
|
|
self.descend_waypoint: Optional[QPushButton] = None
|
|
self.rtb_waypoint: Optional[QPushButton] = None
|
|
self.delete_selected: Optional[QPushButton] = None
|
|
self.open_fast_waypoint_button: Optional[QPushButton] = None
|
|
self.recreate_buttons: List[QPushButton] = []
|
|
self.init_ui()
|
|
|
|
def init_ui(self):
|
|
layout = QGridLayout()
|
|
|
|
self.flight_waypoint_list = QFlightWaypointList(self.package,
|
|
self.flight)
|
|
layout.addWidget(self.flight_waypoint_list, 0, 0)
|
|
|
|
rlayout = QVBoxLayout()
|
|
layout.addLayout(rlayout, 0, 1)
|
|
|
|
rlayout.addWidget(QLabel("<strong>Generator :</strong>"))
|
|
rlayout.addWidget(QLabel("<small>AI compatible</small>"))
|
|
|
|
# TODO: Filter by objective type.
|
|
self.recreate_buttons.clear()
|
|
recreate_types = [
|
|
FlightType.CAS,
|
|
FlightType.CAP,
|
|
FlightType.ESCORT,
|
|
FlightType.SEAD,
|
|
FlightType.STRIKE
|
|
]
|
|
for task in recreate_types:
|
|
def make_closure(arg):
|
|
def closure():
|
|
return self.confirm_recreate(arg)
|
|
return closure
|
|
button = QPushButton(f"Recreate as {task.name}")
|
|
button.clicked.connect(make_closure(task))
|
|
rlayout.addWidget(button)
|
|
self.recreate_buttons.append(button)
|
|
|
|
rlayout.addWidget(QLabel("<strong>Advanced : </strong>"))
|
|
rlayout.addWidget(QLabel("<small>Do not use for AI flights</small>"))
|
|
|
|
self.ascend_waypoint = QPushButton("Add Ascend Waypoint")
|
|
self.ascend_waypoint.clicked.connect(self.on_ascend_waypoint)
|
|
rlayout.addWidget(self.ascend_waypoint)
|
|
|
|
self.descend_waypoint = QPushButton("Add Descend Waypoint")
|
|
self.descend_waypoint.clicked.connect(self.on_descend_waypoint)
|
|
rlayout.addWidget(self.descend_waypoint)
|
|
|
|
self.rtb_waypoint = QPushButton("Add RTB Waypoint")
|
|
self.rtb_waypoint.clicked.connect(self.on_rtb_waypoint)
|
|
rlayout.addWidget(self.rtb_waypoint)
|
|
|
|
self.delete_selected = QPushButton("Delete Selected")
|
|
self.delete_selected.clicked.connect(self.on_delete_waypoint)
|
|
rlayout.addWidget(self.delete_selected)
|
|
|
|
self.open_fast_waypoint_button = QPushButton("Add Waypoint")
|
|
self.open_fast_waypoint_button.clicked.connect(self.on_fast_waypoint)
|
|
rlayout.addWidget(self.open_fast_waypoint_button)
|
|
rlayout.addStretch()
|
|
self.setLayout(layout)
|
|
|
|
def on_delete_waypoint(self):
|
|
wpt = self.flight_waypoint_list.selectionModel().currentIndex().row()
|
|
if wpt > 0:
|
|
del self.flight.points[wpt-1]
|
|
self.flight_waypoint_list.update_list()
|
|
self.on_change()
|
|
|
|
def on_fast_waypoint(self):
|
|
self.subwindow = QPredefinedWaypointSelectionWindow(self.game, self.flight, self.flight_waypoint_list)
|
|
self.subwindow.finished.connect(self.on_change)
|
|
self.subwindow.show()
|
|
|
|
def on_ascend_waypoint(self):
|
|
ascend = self.planner.generate_ascend_point(self.flight.from_cp)
|
|
self.flight.points.append(ascend)
|
|
self.flight_waypoint_list.update_list()
|
|
self.on_change()
|
|
|
|
def on_rtb_waypoint(self):
|
|
rtb = self.planner.generate_rtb_waypoint(self.flight.from_cp)
|
|
self.flight.points.append(rtb)
|
|
self.flight_waypoint_list.update_list()
|
|
self.on_change()
|
|
|
|
def on_descend_waypoint(self):
|
|
descend = self.planner.generate_descend_point(self.flight.from_cp)
|
|
self.flight.points.append(descend)
|
|
self.flight_waypoint_list.update_list()
|
|
self.on_change()
|
|
|
|
def confirm_recreate(self, task: FlightType) -> None:
|
|
result = QMessageBox.question(
|
|
self,
|
|
"Regenerate flight?",
|
|
("Changing the flight type will reset its flight plan. Do you want "
|
|
"to continue?"),
|
|
QMessageBox.No,
|
|
QMessageBox.Yes
|
|
)
|
|
if result == QMessageBox.Yes:
|
|
# TODO: Should be buttons for both BARCAP and TARCAP.
|
|
# BARCAP and TARCAP behave differently. TARCAP arrives a few minutes
|
|
# ahead of the rest of the package and stays until the package
|
|
# departs, whereas BARCAP usually isn't part of a strike package and
|
|
# has a fixed mission time.
|
|
if task == FlightType.CAP:
|
|
if isinstance(self.package.target, FrontLine):
|
|
task = FlightType.TARCAP
|
|
elif isinstance(self.package.target, ControlPoint):
|
|
task = FlightType.BARCAP
|
|
self.flight.flight_type = task
|
|
self.planner.populate_flight_plan(self.flight)
|
|
self.flight_waypoint_list.update_list()
|
|
self.on_change()
|
|
|
|
def on_change(self):
|
|
self.flight_waypoint_list.update_list()
|
|
self.on_flight_changed.emit()
|
|
|
|
|