forked from ArchipelagoMW/Archipelago
-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #254 from MatthewMarinets/mm/misc_client_fixes
Mm/misc client fixes
- Loading branch information
Showing
6 changed files
with
133 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
""" | ||
Import this before importing client_gui.py to set window defaults from world settings. | ||
""" | ||
from .settings import Starcraft2Settings | ||
from typing import List | ||
|
||
def apply_window_defaults() -> List[str]: | ||
""" | ||
Set the kivy config keys from the sc2world user settings. | ||
Returns a list of warnings to be printed once the GUI is started. | ||
""" | ||
from . import SC2World | ||
# This is necessary to prevent kivy from failing because it got invalid command-line args, | ||
# or from spamming the logs. | ||
# Must happen before importing kivy.config | ||
import os | ||
os.environ["KIVY_NO_CONSOLELOG"] = "1" | ||
os.environ["KIVY_NO_FILELOG"] = "1" | ||
os.environ["KIVY_NO_ARGS"] = "1" | ||
os.environ["KIVY_LOG_ENABLE"] = "0" | ||
|
||
# validate settings | ||
warnings: List[str] = [] | ||
if isinstance(SC2World.settings.window_height, int) and SC2World.settings.window_height > 0: | ||
window_height = SC2World.settings.window_height | ||
else: | ||
warnings.append(f"Invalid value for options.yaml key sc2_options.window_height: '{SC2World.settings.window_height}'. Expected a positive integer.") | ||
window_height = Starcraft2Settings.window_height | ||
if isinstance(SC2World.settings.window_width, int) and SC2World.settings.window_width > 0: | ||
window_width = SC2World.settings.window_width | ||
else: | ||
warnings.append(f"Invalid value for options.yaml key sc2_options.window_width: '{SC2World.settings.window_width}'. Expected a positive integer.") | ||
window_width = Starcraft2Settings.window_width | ||
|
||
from kivy.config import Config | ||
Config.set('graphics', 'width', str(window_width)) | ||
Config.set('graphics', 'height', str(window_height)) | ||
if SC2World.settings.window_maximized: | ||
Config.set('graphics', 'window_state', 'maximized') | ||
return warnings |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
from typing import Union | ||
import settings | ||
|
||
|
||
class Starcraft2Settings(settings.Group): | ||
class WindowWidth(int): | ||
"""The starting width the client window in pixels""" | ||
class WindowHeight(int): | ||
"""The starting height the client window in pixels""" | ||
class StartMaximized(settings.Bool): | ||
"""Controls whether the client window should start maximized""" | ||
class GameWindowedMode(settings.Bool): | ||
"""Controls whether the game should start in windowed mode""" | ||
|
||
window_width = WindowWidth(1080) | ||
window_height = WindowHeight(720) | ||
window_maximized: Union[StartMaximized, bool] = False | ||
game_windowed_mode: Union[GameWindowedMode, bool] = False |