Skip to content
GitLab
Explore
Projects
Groups
Topics
Snippets
Projects
Groups
Topics
Snippets
/
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Печенин Данила Михайлович
Pacman
Commits
4643588f
Commit
4643588f
authored
1 week ago
by
Печенин Данила Михайлович
Browse files
Options
Download
Patches
Plain Diff
Bug with dark/light mode was fixed
parent
4820a463
main
No related merge requests found
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
source/States/SelectState/Menu.cpp
+5
-5
source/States/SelectState/Menu.cpp
source/States/SelectState/Menu.h
+1
-3
source/States/SelectState/Menu.h
source/States/SelectState/SelectState.h
+2
-1
source/States/SelectState/SelectState.h
source/Themes/ChangeThemeCommand.cpp
+4
-63
source/Themes/ChangeThemeCommand.cpp
source/Themes/ChangeThemeCommand.h
+3
-3
source/Themes/ChangeThemeCommand.h
with
15 additions
and
75 deletions
+15
-75
source/States/SelectState/Menu.cpp
+
5
−
5
View file @
4643588f
...
@@ -4,7 +4,7 @@
...
@@ -4,7 +4,7 @@
#include
<Themes/ChangeThemeCommand.h>
#include
<Themes/ChangeThemeCommand.h>
#include
<Themes/Themes.h>
#include
<Themes/Themes.h>
Menu
::
Menu
(
IStateManager
&
state_manager
)
:
m_state_manager
(
state_manager
)
{
Menu
::
Menu
(
IStateManager
&
state_manager
,
SelectState
&
select_state
)
{
const
float
pos_left
=
(
static_cast
<
float
>
(
config
::
SELECT_LEVEL_VIDEO_MODE
.
width
)
-
config
::
BUTTON_SIZE
.
x
)
/
2
;
const
float
pos_left
=
(
static_cast
<
float
>
(
config
::
SELECT_LEVEL_VIDEO_MODE
.
width
)
-
config
::
BUTTON_SIZE
.
x
)
/
2
;
const
float
pos_diff
=
(
static_cast
<
float
>
(
config
::
SELECT_LEVEL_VIDEO_MODE
.
height
)
-
config
::
BUTTON_SIZE
.
y
*
5
-
config
::
BUTTON_CHANGE_THEME_SIZE
.
y
)
/
10
;
const
float
pos_diff
=
(
static_cast
<
float
>
(
config
::
SELECT_LEVEL_VIDEO_MODE
.
height
)
-
config
::
BUTTON_SIZE
.
y
*
5
-
config
::
BUTTON_CHANGE_THEME_SIZE
.
y
)
/
10
;
const
float
pos_top
=
(
static_cast
<
float
>
(
config
::
SELECT_LEVEL_VIDEO_MODE
.
height
)
-
config
::
BUTTON_SIZE
.
y
*
5
-
pos_diff
*
5
-
config
::
BUTTON_CHANGE_THEME_SIZE
.
y
)
/
2
;
const
float
pos_top
=
(
static_cast
<
float
>
(
config
::
SELECT_LEVEL_VIDEO_MODE
.
height
)
-
config
::
BUTTON_SIZE
.
y
*
5
-
pos_diff
*
5
-
config
::
BUTTON_CHANGE_THEME_SIZE
.
y
)
/
2
;
...
@@ -22,7 +22,7 @@ Menu::Menu(IStateManager& state_manager) : m_state_manager(state_manager) {
...
@@ -22,7 +22,7 @@ Menu::Menu(IStateManager& state_manager) : m_state_manager(state_manager) {
config
::
EASY_GAME_ENEMY_RATIO
));
config
::
EASY_GAME_ENEMY_RATIO
));
auto
medium_level_command
=
std
::
make_unique
<
GameCommand
>
(
auto
medium_level_command
=
std
::
make_unique
<
GameCommand
>
(
m_
state_manager
,
state_manager
,
std
::
make_unique
<
GameBuilderDirector
>
(
std
::
make_unique
<
GameBuilderDirector
>
(
std
::
make_unique
<
SimpleBuilder
>
(
width
,
height
,
config
::
ROOM_SIZE
,
room_color
,
config
::
ENEMY_SPEED_MEDIEUM
),
std
::
make_unique
<
SimpleBuilder
>
(
width
,
height
,
config
::
ROOM_SIZE
,
room_color
,
config
::
ENEMY_SPEED_MEDIEUM
),
config
::
GAME_VIDEO_MODE
,
config
::
GAME_VIDEO_MODE
,
...
@@ -30,7 +30,7 @@ Menu::Menu(IStateManager& state_manager) : m_state_manager(state_manager) {
...
@@ -30,7 +30,7 @@ Menu::Menu(IStateManager& state_manager) : m_state_manager(state_manager) {
config
::
MEDIUM_GAME_ENEMY_RATIO
));
config
::
MEDIUM_GAME_ENEMY_RATIO
));
auto
hard_level_command
=
std
::
make_unique
<
GameCommand
>
(
auto
hard_level_command
=
std
::
make_unique
<
GameCommand
>
(
m_
state_manager
,
state_manager
,
std
::
make_unique
<
GameBuilderDirector
>
(
std
::
make_unique
<
GameBuilderDirector
>
(
std
::
make_unique
<
ComplexBuilder
>
(
width
,
height
,
config
::
ROOM_SIZE
,
room_color
,
config
::
ENEMY_SPEED_HARD
),
std
::
make_unique
<
ComplexBuilder
>
(
width
,
height
,
config
::
ROOM_SIZE
,
room_color
,
config
::
ENEMY_SPEED_HARD
),
config
::
GAME_VIDEO_MODE
,
config
::
GAME_VIDEO_MODE
,
...
@@ -38,14 +38,14 @@ Menu::Menu(IStateManager& state_manager) : m_state_manager(state_manager) {
...
@@ -38,14 +38,14 @@ Menu::Menu(IStateManager& state_manager) : m_state_manager(state_manager) {
config
::
HARD_GAME_ENEMY_RATIO
));
config
::
HARD_GAME_ENEMY_RATIO
));
auto
extreme_level_command
=
std
::
make_unique
<
GameCommand
>
(
auto
extreme_level_command
=
std
::
make_unique
<
GameCommand
>
(
m_
state_manager
,
state_manager
,
std
::
make_unique
<
GameBuilderDirector
>
(
std
::
make_unique
<
GameBuilderDirector
>
(
std
::
make_unique
<
ComplexRandomBuilder
>
(
width
,
height
,
config
::
ROOM_SIZE
,
room_color
,
config
::
ENEMY_SPEED_EXTREME
),
std
::
make_unique
<
ComplexRandomBuilder
>
(
width
,
height
,
config
::
ROOM_SIZE
,
room_color
,
config
::
ENEMY_SPEED_EXTREME
),
config
::
GAME_VIDEO_MODE
,
config
::
GAME_VIDEO_MODE
,
config
::
EXTREME_GAME_TITLE
,
config
::
EXTREME_GAME_TITLE
,
config
::
HARD_GAME_ENEMY_RATIO
));
config
::
HARD_GAME_ENEMY_RATIO
));
auto
change_theme_command
=
std
::
make_unique
<
ChangeThemeCommand
>
(
*
this
);
auto
change_theme_command
=
std
::
make_unique
<
ChangeThemeCommand
>
(
select_state
);
m_buttons
[
0
].
set
(
sf
::
Vector2f
{
pos_left
,
pos_top
},
config
::
BUTTON_SIZE
,
config
::
BUTTON_TEXT_EASY
,
m_buttons
[
0
].
set
(
sf
::
Vector2f
{
pos_left
,
pos_top
},
config
::
BUTTON_SIZE
,
config
::
BUTTON_TEXT_EASY
,
config
::
BUTTON_FONT_SIZE
,
std
::
move
(
easy_level_command
));
config
::
BUTTON_FONT_SIZE
,
std
::
move
(
easy_level_command
));
...
...
This diff is collapsed.
Click to expand it.
source/States/SelectState/Menu.h
+
1
−
3
View file @
4643588f
...
@@ -8,11 +8,9 @@ class SelectState;
...
@@ -8,11 +8,9 @@ class SelectState;
class
Menu
final
:
public
IDrawable
{
class
Menu
final
:
public
IDrawable
{
public:
public:
explicit
Menu
(
IStateManager
&
state_manager
);
explicit
Menu
(
IStateManager
&
state_manager
,
SelectState
&
select_state
);
void
process_mouse
(
sf
::
Vector2f
pos
,
bool
is_pressed
);
void
process_mouse
(
sf
::
Vector2f
pos
,
bool
is_pressed
);
void
draw_into
(
sf
::
RenderWindow
&
window
)
const
override
;
void
draw_into
(
sf
::
RenderWindow
&
window
)
const
override
;
friend
class
ChangeThemeCommand
;
private:
private:
std
::
array
<
Button
,
6
>
m_buttons
;
std
::
array
<
Button
,
6
>
m_buttons
;
IStateManager
&
m_state_manager
;
};
};
\ No newline at end of file
This diff is collapsed.
Click to expand it.
source/States/SelectState/SelectState.h
+
2
−
1
View file @
4643588f
...
@@ -6,10 +6,11 @@
...
@@ -6,10 +6,11 @@
class
SelectState
final
:
public
IState
,
public
IWindowKeeper
{
class
SelectState
final
:
public
IState
,
public
IWindowKeeper
{
public:
public:
explicit
SelectState
(
IStateManager
&
state_manager
,
const
sf
::
VideoMode
&
video_mode
,
const
sf
::
String
&
window_title
)
:
explicit
SelectState
(
IStateManager
&
state_manager
,
const
sf
::
VideoMode
&
video_mode
,
const
sf
::
String
&
window_title
)
:
IState
(
state_manager
),
IWindowKeeper
(
video_mode
,
window_title
),
m_menu
(
state_manager
)
{
IState
(
state_manager
),
IWindowKeeper
(
video_mode
,
window_title
),
m_menu
(
state_manager
,
*
this
)
{
m_window
.
setFramerateLimit
(
config
::
FRAME_RATE_LIMIT
);
m_window
.
setFramerateLimit
(
config
::
FRAME_RATE_LIMIT
);
}
}
bool
do_step
()
override
;
bool
do_step
()
override
;
friend
class
ChangeThemeCommand
;
private
:
private
:
void
event_handling
()
override
;
void
event_handling
()
override
;
void
update
()
override
;
void
update
()
override
;
...
...
This diff is collapsed.
Click to expand it.
source/Themes/ChangeThemeCommand.cpp
+
4
−
63
View file @
4643588f
#include
"ChangeThemeCommand.h"
#include
"ChangeThemeCommand.h"
#include
"Themes.h"
#include
"Themes.h"
#include
<States/ChangeStateCommand.h>
#include
<States/ChangeStateCommand.h>
#include
<thread>
void
ChangeThemeCommand
::
execute
()
{
void
ChangeThemeCommand
::
execute
()
{
Themes
::
Instance
().
change_theme
();
Themes
::
Instance
().
change_theme
();
std
::
this_thread
::
sleep_for
(
std
::
chrono
::
milliseconds
(
100
));
const
auto
width
=
config
::
GAME_VIDEO_MODE
.
width
;
m_select_state
.
m_menu
=
std
::
move
(
Menu
{
m_select_state
.
m_state_manager
,
m_select_state
});
const
auto
height
=
config
::
GAME_VIDEO_MODE
.
height
;
std
::
this_thread
::
sleep_for
(
std
::
chrono
::
milliseconds
(
100
));
const
auto
room_color
=
Themes
::
Instance
().
get_game_color_room
();
auto
easy_level_command
=
std
::
make_unique
<
GameCommand
>
(
m_menu
.
m_state_manager
,
std
::
make_unique
<
GameBuilderDirector
>
(
std
::
make_unique
<
SimpleBuilder
>
(
width
,
height
,
config
::
ROOM_SIZE
,
room_color
,
0
),
config
::
GAME_VIDEO_MODE
,
config
::
EASY_GAME_TITLE
,
config
::
EASY_GAME_ENEMY_RATIO
));
auto
medium_level_command
=
std
::
make_unique
<
GameCommand
>
(
m_menu
.
m_state_manager
,
std
::
make_unique
<
GameBuilderDirector
>
(
std
::
make_unique
<
SimpleBuilder
>
(
width
,
height
,
config
::
ROOM_SIZE
,
room_color
,
config
::
ENEMY_SPEED_MEDIEUM
),
config
::
GAME_VIDEO_MODE
,
config
::
MEDIUM_GAME_TITLE
,
config
::
MEDIUM_GAME_ENEMY_RATIO
));
auto
hard_level_command
=
std
::
make_unique
<
GameCommand
>
(
m_menu
.
m_state_manager
,
std
::
make_unique
<
GameBuilderDirector
>
(
std
::
make_unique
<
ComplexBuilder
>
(
width
,
height
,
config
::
ROOM_SIZE
,
room_color
,
config
::
ENEMY_SPEED_HARD
),
config
::
GAME_VIDEO_MODE
,
config
::
HARD_GAME_TITLE
,
config
::
HARD_GAME_ENEMY_RATIO
));
auto
extreme_level_command
=
std
::
make_unique
<
GameCommand
>
(
m_menu
.
m_state_manager
,
std
::
make_unique
<
GameBuilderDirector
>
(
std
::
make_unique
<
ComplexRandomBuilder
>
(
width
,
height
,
config
::
ROOM_SIZE
,
room_color
,
config
::
ENEMY_SPEED_EXTREME
),
config
::
GAME_VIDEO_MODE
,
config
::
EXTREME_GAME_TITLE
,
config
::
HARD_GAME_ENEMY_RATIO
));
auto
change_theme_command
=
std
::
make_unique
<
ChangeThemeCommand
>
(
m_menu
);
m_menu
.
m_buttons
[
0
].
change_text_color
();
m_menu
.
m_buttons
[
0
].
change_button_color
();
m_menu
.
m_buttons
[
0
].
change_command
(
std
::
move
(
easy_level_command
));
m_menu
.
m_buttons
[
1
].
change_text_color
();
m_menu
.
m_buttons
[
1
].
change_button_color
();
m_menu
.
m_buttons
[
1
].
change_command
(
std
::
move
(
medium_level_command
));
m_menu
.
m_buttons
[
2
].
change_text_color
();
m_menu
.
m_buttons
[
2
].
change_button_color
();
m_menu
.
m_buttons
[
2
].
change_command
(
std
::
move
(
hard_level_command
));
m_menu
.
m_buttons
[
3
].
change_text_color
();
m_menu
.
m_buttons
[
3
].
change_button_color
();
m_menu
.
m_buttons
[
3
].
change_command
(
std
::
move
(
extreme_level_command
));
m_menu
.
m_buttons
[
4
].
change_text_color
();
m_menu
.
m_buttons
[
4
].
change_button_color
();
m_menu
.
m_buttons
[
4
].
change_command
(
std
::
make_unique
<
ExitCommand
>
(
m_menu
.
m_state_manager
));
m_menu
.
m_buttons
[
5
].
change_text_color
();
m_menu
.
m_buttons
[
5
].
change_button_color
();
m_menu
.
m_buttons
[
5
].
change_button_text
(
Themes
::
Instance
().
get_button_change_theme_text
());
m_menu
.
m_buttons
[
5
].
change_command
(
std
::
move
(
change_theme_command
));
}
}
\ No newline at end of file
This diff is collapsed.
Click to expand it.
source/Themes/ChangeThemeCommand.h
+
3
−
3
View file @
4643588f
...
@@ -4,8 +4,8 @@
...
@@ -4,8 +4,8 @@
class
ChangeThemeCommand
final
:
public
ISelectCommand
{
class
ChangeThemeCommand
final
:
public
ISelectCommand
{
public:
public:
explicit
ChangeThemeCommand
(
Menu
&
menu
)
:
m_menu
(
menu
)
{}
explicit
ChangeThemeCommand
(
SelectState
&
select_state
)
:
m_select_state
(
select_state
)
{}
void
execute
()
override
;
void
execute
()
override
;
private
:
private
:
Menu
&
m_menu
;
SelectState
&
m_select_state
;
};
};
\ No newline at end of file
This diff is collapsed.
Click to expand it.
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment
Menu
Explore
Projects
Groups
Topics
Snippets