author | alfadur |
Wed, 11 Nov 2020 21:18:31 +0300 | |
changeset 15756 | 1d652bca512e |
parent 15457 | 751b992656ab |
child 15788 | acf70c44065b |
permissions | -rw-r--r-- |
184 | 1 |
/* |
1066 | 2 |
* Hedgewars, a free turn based strategy game |
11046 | 3 |
* Copyright (c) 2004-2015 Andrey Korotaev <unC0Rr@gmail.com> |
184 | 4 |
* |
5 |
* This program is free software; you can redistribute it and/or modify |
|
6 |
* it under the terms of the GNU General Public License as published by |
|
7 |
* the Free Software Foundation; version 2 of the License |
|
8 |
* |
|
9 |
* This program is distributed in the hope that it will be useful, |
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
12 |
* GNU General Public License for more details. |
|
13 |
* |
|
14 |
* You should have received a copy of the GNU General Public License |
|
15 |
* along with this program; if not, write to the Free Software |
|
10108
c68cf030eded
update FSF address. note: two sdl include files (by Sam Lantinga) still have the old FSF address in their copyright - but I ain't gonna touch their copyright headers
sheepluva
parents:
10017
diff
changeset
|
16 |
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
184 | 17 |
*/ |
18 |
||
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
19 |
#include <QDir> |
184 | 20 |
#include <QFile> |
21 |
#include <QTextStream> |
|
407 | 22 |
#include <QMessageBox> |
502
bc178daca088
Fix build with CMake & gcc 4.1.2 on my system (treating #include <QtGui> as including directory)
unc0rr
parents:
496
diff
changeset
|
23 |
#include <QPushButton> |
8415
02acf6b92f52
Moved room name edit box from footer to top of page. Also shows room name when in slave mode.
dag10
parents:
8407
diff
changeset
|
24 |
#include <QSpinBox> |
502
bc178daca088
Fix build with CMake & gcc 4.1.2 on my system (treating #include <QtGui> as including directory)
unc0rr
parents:
496
diff
changeset
|
25 |
#include <QListWidget> |
bc178daca088
Fix build with CMake & gcc 4.1.2 on my system (treating #include <QtGui> as including directory)
unc0rr
parents:
496
diff
changeset
|
26 |
#include <QStackedLayout> |
bc178daca088
Fix build with CMake & gcc 4.1.2 on my system (treating #include <QtGui> as including directory)
unc0rr
parents:
496
diff
changeset
|
27 |
#include <QLineEdit> |
bc178daca088
Fix build with CMake & gcc 4.1.2 on my system (treating #include <QtGui> as including directory)
unc0rr
parents:
496
diff
changeset
|
28 |
#include <QLabel> |
636 | 29 |
#include <QRadioButton> |
654 | 30 |
#include <QSpinBox> |
674 | 31 |
#include <QCloseEvent> |
1235 | 32 |
#include <QCheckBox> |
1377 | 33 |
#include <QTextBrowser> |
1409
d1cbe4a57ebf
Add button for controlling room options (no usefull yet)
unc0rr
parents:
1405
diff
changeset
|
34 |
#include <QAction> |
1418 | 35 |
#include <QTimer> |
1419 | 36 |
#include <QScrollBar> |
1885 | 37 |
#include <QDataWidgetMapper> |
1887 | 38 |
#include <QTableView> |
2874
3c7c2bf1ba38
A simple hat reservation mechanism. Can be worked around with a little effort, but to make it useful, you'd have to get everyone you played with to work around it too. Quite a bit of effort for a small reward feature.
nemo
parents:
2845
diff
changeset
|
39 |
#include <QCryptographicHash> |
4509
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
40 |
#include <QSignalMapper> |
4759 | 41 |
#include <QShortcut> |
5651
a7de68f4f87f
allow accessing the snapshot folder from the about page in the frontend (button could use a nicer icon)
koda
parents:
5567
diff
changeset
|
42 |
#include <QDesktopServices> |
8328 | 43 |
#include <QDesktopWidget> |
44 |
#include <QApplication> |
|
5734 | 45 |
#include <QInputDialog> |
6428 | 46 |
#include <QPropertyAnimation> |
6604
9cc612a24b43
this should lower compatibility with qt4.5 again, but i have no way to test it
koda
parents:
6574
diff
changeset
|
47 |
#include <QSettings> |
8891
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
48 |
#include <QSortFilterProxyModel> |
11863 | 49 |
#include <QIcon> |
50 |
#include <QImage> |
|
6604
9cc612a24b43
this should lower compatibility with qt4.5 again, but i have no way to test it
koda
parents:
6574
diff
changeset
|
51 |
|
9cc612a24b43
this should lower compatibility with qt4.5 again, but i have no way to test it
koda
parents:
6574
diff
changeset
|
52 |
#if (QT_VERSION >= 0x040600) |
6428 | 53 |
#include <QGraphicsEffect> |
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
54 |
#include <QParallelAnimationGroup> |
6604
9cc612a24b43
this should lower compatibility with qt4.5 again, but i have no way to test it
koda
parents:
6574
diff
changeset
|
55 |
#endif |
184 | 56 |
|
57 |
#include "hwform.h" |
|
58 |
#include "game.h" |
|
59 |
#include "team.h" |
|
14462
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
60 |
#include "mission.h" |
7201
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
61 |
#include "campaign.h" |
184 | 62 |
#include "teamselect.h" |
681 | 63 |
#include "selectWeapon.h" |
184 | 64 |
#include "gameuiconfig.h" |
5204 | 65 |
#include "pageinfo.h" |
66 |
#include "pagetraining.h" |
|
67 |
#include "pagesingleplayer.h" |
|
68 |
#include "pageselectweapon.h" |
|
69 |
#include "pageadmin.h" |
|
70 |
#include "pagecampaign.h" |
|
71 |
#include "pagescheme.h" |
|
72 |
#include "pagenetgame.h" |
|
73 |
#include "pageroomslist.h" |
|
74 |
#include "pageconnecting.h" |
|
75 |
#include "pageoptions.h" |
|
76 |
#include "pageeditteam.h" |
|
77 |
#include "pagemultiplayer.h" |
|
78 |
#include "pagenet.h" |
|
79 |
#include "pagemain.h" |
|
80 |
#include "pagenetserver.h" |
|
81 |
#include "pagedrawmap.h" |
|
5205
78138ae93820
some headers cleanup and rename of stats and playrecord pages for consistency
koda
parents:
5204
diff
changeset
|
82 |
#include "pagegamestats.h" |
5567
44c9a577b082
Tiny bit of progress on download page - hooked it up to "Info" button for now.
nemo
parents:
5255
diff
changeset
|
83 |
#include "pageplayrecord.h" |
44c9a577b082
Tiny bit of progress on download page - hooked it up to "Info" button for now.
nemo
parents:
5255
diff
changeset
|
84 |
#include "pagedata.h" |
7235
baa69bd025d9
1. Implement new page in frontend with options for video recording.
Stepan777 <stepik-777@mail.ru>
parents:
7180
diff
changeset
|
85 |
#include "pagevideos.h" |
184 | 86 |
#include "hwconsts.h" |
314 | 87 |
#include "newnetclient.h" |
329
4c3aad46baa5
Send game parameters by net... Currently it leads to infinite loop, flooding traffic with messages about changes
unc0rr
parents:
328
diff
changeset
|
88 |
#include "gamecfgwidget.h" |
632
5e09ae25729f
Half implement possibility for different backends of servers list
unc0rr
parents:
625
diff
changeset
|
89 |
#include "netserverslist.h" |
634 | 90 |
#include "netudpserver.h" |
461 | 91 |
#include "chatwidget.h" |
653
4f44fc06ca45
Class to ask host/port to connect to ('Specify' button on PageNet)
unc0rr
parents:
647
diff
changeset
|
92 |
#include "input_ip.h" |
6910
ea058558c68b
add a checkbox for the password field prompt (issue 316)
Stepan777
parents:
6907
diff
changeset
|
93 |
#include "input_password.h" |
13197
0bc5f618ca7c
Rename the misleadingly-named AmmoSchemeModel to GameSchemeModel
Wuzzy <Wuzzy2@mail.ru>
parents:
13086
diff
changeset
|
94 |
#include "gameSchemeModel.h" |
2012 | 95 |
#include "bgwidget.h" |
4520
e7882bd1a894
Allow to draw maps in frontend and play them (only locally, some bugs to fix)
unc0rr
parents:
4518
diff
changeset
|
96 |
#include "drawmapwidget.h" |
6477 | 97 |
#include "mouseoverfilter.h" |
6732
c906dc78091f
Start switching to rooms list model. To be continued.
unc0rr
parents:
6720
diff
changeset
|
98 |
#include "roomslistmodel.h" |
7180 | 99 |
#include "recorder.h" |
7723 | 100 |
#include "playerslistmodel.h" |
8385
9e8924ff9813
Convert feedback page to dialog (+some fixes from unC0Rr)
dag10
parents:
8384
diff
changeset
|
101 |
#include "feedbackdialog.h" |
184 | 102 |
|
8383 | 103 |
#include "MessageDialog.h" |
6930 | 104 |
#include "DataManager.h" |
8284 | 105 |
#include "AutoUpdater.h" |
6160
863d3edf5690
cleaning up some more, also adding a WIP file. changes: hats in the hat selection are now sorted like this: NoHat, Reserved hats (alphabetically), All other hats (alphabeticall)
sheepluva
parents:
6151
diff
changeset
|
106 |
|
9163
67334acaaac7
port all Q_WS_* to Q_OS_* so that we are forward compatible with Qt5
koda
parents:
9100
diff
changeset
|
107 |
#ifdef Q_OS_WIN |
11803 | 108 |
#ifndef WINVER |
8328 | 109 |
#define WINVER 0x0500 |
11803 | 110 |
#endif |
8328 | 111 |
#include <windows.h> |
112 |
#else |
|
113 |
#include <unistd.h> |
|
114 |
#include <sys/types.h> |
|
115 |
#endif |
|
116 |
||
9163
67334acaaac7
port all Q_WS_* to Q_OS_* so that we are forward compatible with Qt5
koda
parents:
9100
diff
changeset
|
117 |
#ifdef Q_OS_MAC |
8328 | 118 |
#include <sys/sysctl.h> |
119 |
#endif |
|
120 |
||
2400
2422ea85d100
added a utility that warns the user to install hedgewars when it's run from the diskimage
koda
parents:
2399
diff
changeset
|
121 |
#ifdef __APPLE__ |
2422ea85d100
added a utility that warns the user to install hedgewars when it's run from the diskimage
koda
parents:
2399
diff
changeset
|
122 |
#include "M3Panel.h" |
2422ea85d100
added a utility that warns the user to install hedgewars when it's run from the diskimage
koda
parents:
2399
diff
changeset
|
123 |
#ifdef SPARKLE_ENABLED |
2261 | 124 |
#include "SparkleAutoUpdater.h" |
125 |
#endif |
|
2400
2422ea85d100
added a utility that warns the user to install hedgewars when it's run from the diskimage
koda
parents:
2399
diff
changeset
|
126 |
#endif |
2261 | 127 |
|
6561 | 128 |
|
2098
c977d7f2aa09
Toggle for stars ("frontend effects") - also turns off optimisations for stars that were causing problems onone machine
nemo
parents:
2080
diff
changeset
|
129 |
// I started handing this down to each place it touches, but it was getting ridiculous |
c977d7f2aa09
Toggle for stars ("frontend effects") - also turns off optimisations for stars that were causing problems onone machine
nemo
parents:
2080
diff
changeset
|
130 |
// and this one flag does not warrant a static class |
c977d7f2aa09
Toggle for stars ("frontend effects") - also turns off optimisations for stars that were causing problems onone machine
nemo
parents:
2080
diff
changeset
|
131 |
bool frontendEffects = true; |
15278
16f389fcd462
Prevent saving of demo after /lua command was used
Wuzzy <Wuzzy2@mail.ru>
parents:
15276
diff
changeset
|
132 |
bool demoIsPresent = true; |
2874
3c7c2bf1ba38
A simple hat reservation mechanism. Can be worked around with a little effort, but to make it useful, you'd have to get everyone you played with to work around it too. Quite a bit of effort for a small reward feature.
nemo
parents:
2845
diff
changeset
|
133 |
QString playerHash; |
2098
c977d7f2aa09
Toggle for stars ("frontend effects") - also turns off optimisations for stars that were causing problems onone machine
nemo
parents:
2080
diff
changeset
|
134 |
|
11950
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
135 |
QIcon finishedIcon; |
11978
4a2da00bbedc
Align drop-down text of unfinished campaign missions with finished icons
Wuzzy <almikes@aol.com>
parents:
11968
diff
changeset
|
136 |
QIcon notFinishedIcon; |
6572 | 137 |
GameUIConfig* HWForm::config = NULL; |
138 |
||
5849 | 139 |
HWForm::HWForm(QWidget *parent, QString styleSheet) |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
140 |
: QMainWindow(parent) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
141 |
, game(0) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
142 |
, pnetserver(0) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
143 |
, pRegisterServer(0) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
144 |
, editedTeam(0) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
145 |
, hwnet(0) |
184 | 146 |
{ |
6166 | 147 |
// set music track |
8049 | 148 |
SDLInteraction::instance().setMusicTrack("/Music/main_theme.ogg"); |
6166 | 149 |
|
5849 | 150 |
this->setStyleSheet(styleSheet); |
11863 | 151 |
|
152 |
||
153 |
QIcon * hwIcon = new QIcon(); |
|
154 |
hwIcon->addFile(":/res/hh_small.png"); |
|
155 |
//hwIcon->addFile(":/res/hh25x25.png"); |
|
156 |
// crop-workaround for the fact that hh25x25.png is actually 25x35 |
|
157 |
QPixmap pm(":/res/hh25x25.png"); |
|
158 |
hwIcon->addPixmap(pm.copy(0,(pm.height()-25)/2,25,25)); |
|
159 |
hwIcon->addFile(":/res/teamicon.png"); |
|
160 |
hwIcon->addFile(":/res/teamicon2.png"); |
|
161 |
||
162 |
this->setWindowIcon(*hwIcon); |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
163 |
ui.setupUi(this); |
8424
225ede46e3dc
On pagenetgame, when window is too small the map/game options becomes a tabbed interface to allow for a few lines of chat to always be visible.
dag10
parents:
8416
diff
changeset
|
164 |
setMinimumSize(760, 580); |
4592
b1fe47b11b99
disable fix for issue 24 in order to fix issue 123, as suggested by koda
sheepluva
parents:
4576
diff
changeset
|
165 |
//setFocusPolicy(Qt::StrongFocus); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
166 |
CustomizePalettes(); |
3697 | 167 |
|
6165
6fe3e922246e
moving and renaming SDLs.*, making it a singleton; cleaning up class responsibilties wrt SDLInteraction; some comments
sheepluva
parents:
6160
diff
changeset
|
168 |
ui.pageOptions->CBResolution->addItems(SDLInteraction::instance().getResolutions()); |
1225
f882a92ef872
Play music in menu also, with fading effects when run game
unc0rr
parents:
1223
diff
changeset
|
169 |
|
8918
512753ea4b1b
Switch to 'settings.ini'. Copies old ini file if necessary on startup.
unc0rr
parents:
8901
diff
changeset
|
170 |
config = new GameUIConfig(this, DataManager::instance().settingsFileName()); |
8179
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
171 |
frontendEffects = config->value("frontend/effects", true).toBool(); |
15090
33eca3f0a9aa
PageEditTeam: Disable sound test button when frontend sounds are disabled
Wuzzy <Wuzzy2@mail.ru>
parents:
14934
diff
changeset
|
172 |
bool frontendSounds = config->value("frontend/sound", true).toBool(); |
33eca3f0a9aa
PageEditTeam: Disable sound test button when frontend sounds are disabled
Wuzzy <Wuzzy2@mail.ru>
parents:
14934
diff
changeset
|
173 |
onFrontendSoundsToggled(frontendSounds); |
33eca3f0a9aa
PageEditTeam: Disable sound test button when frontend sounds are disabled
Wuzzy <Wuzzy2@mail.ru>
parents:
14934
diff
changeset
|
174 |
|
14740
7b2bd37d7503
Fix inconsistencies in guest nick name generation
Wuzzy <Wuzzy2@mail.ru>
parents:
14677
diff
changeset
|
175 |
playerHash = QString(QCryptographicHash::hash(config->value("net/nick", config->getRandomNick()).toString().toUtf8(), QCryptographicHash::Md5).toHex()); |
2377 | 176 |
|
11978
4a2da00bbedc
Align drop-down text of unfinished campaign missions with finished icons
Wuzzy <almikes@aol.com>
parents:
11968
diff
changeset
|
177 |
// Icons for finished missions |
11950
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
178 |
finishedIcon.addFile(":/res/missionFinished.png", QSize(), QIcon::Normal, QIcon::On); |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
179 |
finishedIcon.addFile(":/res/missionFinishedSelected.png", QSize(), QIcon::Selected, QIcon::On); |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
180 |
|
11978
4a2da00bbedc
Align drop-down text of unfinished campaign missions with finished icons
Wuzzy <almikes@aol.com>
parents:
11968
diff
changeset
|
181 |
// A transparent icon, used to nicely align the unfinished missions with the finished ones |
4a2da00bbedc
Align drop-down text of unfinished campaign missions with finished icons
Wuzzy <almikes@aol.com>
parents:
11968
diff
changeset
|
182 |
QPixmap emptySpace = QPixmap(15, 15); |
4a2da00bbedc
Align drop-down text of unfinished campaign missions with finished icons
Wuzzy <almikes@aol.com>
parents:
11968
diff
changeset
|
183 |
emptySpace.fill(QColor(0, 0, 0, 0)); |
4a2da00bbedc
Align drop-down text of unfinished campaign missions with finished icons
Wuzzy <almikes@aol.com>
parents:
11968
diff
changeset
|
184 |
notFinishedIcon = QIcon(emptySpace); |
4a2da00bbedc
Align drop-down text of unfinished campaign missions with finished icons
Wuzzy <almikes@aol.com>
parents:
11968
diff
changeset
|
185 |
|
8179
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
186 |
ui.pageRoomsList->setSettings(config); |
8453
06541556df53
Reorganized layout and appearance of rooms list page.
dag10
parents:
8451
diff
changeset
|
187 |
ui.pageNetGame->setSettings(config); |
8179
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
188 |
ui.pageNetGame->chatWidget->setSettings(config); |
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
189 |
ui.pageRoomsList->chatWidget->setSettings(config); |
8346 | 190 |
ui.pageOptions->setConfig(config); |
8151
25b95d6224fc
Google Code-in: Move video preferences in settings tab
Mitchell Kember <mk12360@gmail.com>
parents:
8140
diff
changeset
|
191 |
#ifdef VIDEOREC |
8196
ed5001115265
Fixed crash that occured after recording a video (pagevideos' config wasn't set).
Mitchell Kember <mk12360@gmail.com>
parents:
8183
diff
changeset
|
192 |
ui.pageVideos->init(config); |
8151
25b95d6224fc
Google Code-in: Move video preferences in settings tab
Mitchell Kember <mk12360@gmail.com>
parents:
8140
diff
changeset
|
193 |
#endif |
7235
baa69bd025d9
1. Implement new page in frontend with options for video recording.
Stepan777 <stepik-777@mail.ru>
parents:
7180
diff
changeset
|
194 |
|
10971 | 195 |
#if defined(__APPLE__) && defined(SPARKLE_ENABLED) |
8284 | 196 |
if (config->isAutoUpdateEnabled()) |
197 |
{ |
|
9393 | 198 |
AutoUpdater* updater = NULL; |
199 |
||
8284 | 200 |
updater = new SparkleAutoUpdater(); |
201 |
if (updater) |
|
202 |
{ |
|
203 |
updater->checkForUpdates(); |
|
204 |
delete updater; |
|
205 |
} |
|
206 |
} |
|
8287
e2a5dece221f
Fix non-osx build broken in ra874d00df4a4. Dudes... :(
unc0rr
parents:
8284
diff
changeset
|
207 |
#endif |
8284 | 208 |
|
2400
2422ea85d100
added a utility that warns the user to install hedgewars when it's run from the diskimage
koda
parents:
2399
diff
changeset
|
209 |
#ifdef __APPLE__ |
3937 | 210 |
panel = new M3Panel; |
5087
d3af455a868e
cmd+m should minimize the app as per apple human guidelines
koda
parents:
5061
diff
changeset
|
211 |
|
d3af455a868e
cmd+m should minimize the app as per apple human guidelines
koda
parents:
5061
diff
changeset
|
212 |
QShortcut *hideFrontend = new QShortcut(QKeySequence("Ctrl+M"), this); |
d3af455a868e
cmd+m should minimize the app as per apple human guidelines
koda
parents:
5061
diff
changeset
|
213 |
connect (hideFrontend, SIGNAL(activated()), this, SLOT(showMinimized())); |
4759 | 214 |
#else |
215 |
// ctrl+q closes frontend for consistency |
|
6960
822f8269e13f
map, theme & style selection won't be lost on data updata now (except the selected map/theme/style is deleted ofc). enabling F5 key to reload data :>
sheepluva
parents:
6952
diff
changeset
|
216 |
QShortcut * closeFrontend = new QShortcut(QKeySequence("Ctrl+Q"), this); |
4759 | 217 |
connect (closeFrontend, SIGNAL(activated()), this, SLOT(close())); |
7824 | 218 |
//QShortcut * updateData = new QShortcut(QKeySequence("F5"), this); |
219 |
//connect (updateData, SIGNAL(activated()), &DataManager::instance(), SLOT(reload())); |
|
2261 | 220 |
#endif |
2377 | 221 |
|
9219 | 222 |
previousCampaignName = ""; |
223 |
previousTeamName = ""; |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
224 |
UpdateTeamsLists(); |
7201
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
225 |
InitCampaignPage(); |
14470
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
226 |
RestoreSingleplayerTeamSelection(); |
3760 | 227 |
UpdateCampaignPage(0); |
11950
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
228 |
UpdateCampaignPageTeam(0); |
9286
c89b992ff5fe
fixed bug about starting campaign page with not descriptions/images and with wrong description/image mathcing
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9284
diff
changeset
|
229 |
UpdateCampaignPageMission(0); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
230 |
UpdateWeapons(); |
184 | 231 |
|
6009 | 232 |
// connect all goBack signals |
233 |
int nPages = ui.Pages->count(); |
|
234 |
||
235 |
for (int i = 0; i < nPages; i++) |
|
236 |
connect(ui.Pages->widget(i), SIGNAL(goBack()), this, SLOT(GoBack())); |
|
237 |
||
4509
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
238 |
pageSwitchMapper = new QSignalMapper(this); |
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
239 |
connect(pageSwitchMapper, SIGNAL(mapped(int)), this, SLOT(GoToPage(int))); |
13330 | 240 |
|
4509
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
241 |
connect(ui.pageMain->BtnSinglePlayer, SIGNAL(clicked()), pageSwitchMapper, SLOT(map())); |
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
242 |
pageSwitchMapper->setMapping(ui.pageMain->BtnSinglePlayer, ID_PAGE_SINGLEPLAYER); |
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
243 |
|
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
244 |
connect(ui.pageMain->BtnSetup, SIGNAL(clicked()), pageSwitchMapper, SLOT(map())); |
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
245 |
pageSwitchMapper->setMapping(ui.pageMain->BtnSetup, ID_PAGE_SETUP); |
6561 | 246 |
|
8385
9e8924ff9813
Convert feedback page to dialog (+some fixes from unC0Rr)
dag10
parents:
8384
diff
changeset
|
247 |
connect(ui.pageMain->BtnFeedback, SIGNAL(clicked()), this, SLOT(showFeedbackDialog())); |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
248 |
|
14804
d7b40d61729f
Add extra button in main menu for opening credits page
Wuzzy <Wuzzy2@mail.ru>
parents:
14740
diff
changeset
|
249 |
connect(ui.pageMain->BtnTitle, SIGNAL(clicked()), pageSwitchMapper, SLOT(map())); |
d7b40d61729f
Add extra button in main menu for opening credits page
Wuzzy <Wuzzy2@mail.ru>
parents:
14740
diff
changeset
|
250 |
pageSwitchMapper->setMapping(ui.pageMain->BtnTitle, ID_PAGE_INFO); |
d7b40d61729f
Add extra button in main menu for opening credits page
Wuzzy <Wuzzy2@mail.ru>
parents:
14740
diff
changeset
|
251 |
|
4509
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
252 |
connect(ui.pageMain->BtnInfo, SIGNAL(clicked()), pageSwitchMapper, SLOT(map())); |
5763
d7a887c7e2d0
Add a crappy button to encourage artists to make another one. Restore Info page.
nemo
parents:
5746
diff
changeset
|
253 |
pageSwitchMapper->setMapping(ui.pageMain->BtnInfo, ID_PAGE_INFO); |
d7a887c7e2d0
Add a crappy button to encourage artists to make another one. Restore Info page.
nemo
parents:
5746
diff
changeset
|
254 |
|
d7a887c7e2d0
Add a crappy button to encourage artists to make another one. Restore Info page.
nemo
parents:
5746
diff
changeset
|
255 |
connect(ui.pageMain->BtnDataDownload, SIGNAL(clicked()), pageSwitchMapper, SLOT(map())); |
d7a887c7e2d0
Add a crappy button to encourage artists to make another one. Restore Info page.
nemo
parents:
5746
diff
changeset
|
256 |
pageSwitchMapper->setMapping(ui.pageMain->BtnDataDownload, ID_PAGE_DATADOWNLOAD); |
4509
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
257 |
|
13818
a8fd5490932f
Add help button in main menu (opens Hedgewars Wiki in browser)
Wuzzy <Wuzzy2@mail.ru>
parents:
13689
diff
changeset
|
258 |
connect(ui.pageMain->BtnHelp, SIGNAL(clicked()), this, SLOT(GoToHelp())); |
7015 | 259 |
|
7617 | 260 |
#ifdef VIDEOREC |
7235
baa69bd025d9
1. Implement new page in frontend with options for video recording.
Stepan777 <stepik-777@mail.ru>
parents:
7180
diff
changeset
|
261 |
connect(ui.pageMain->BtnVideos, SIGNAL(clicked()), pageSwitchMapper, SLOT(map())); |
baa69bd025d9
1. Implement new page in frontend with options for video recording.
Stepan777 <stepik-777@mail.ru>
parents:
7180
diff
changeset
|
262 |
pageSwitchMapper->setMapping(ui.pageMain->BtnVideos, ID_PAGE_VIDEOS); |
7617 | 263 |
#endif |
7235
baa69bd025d9
1. Implement new page in frontend with options for video recording.
Stepan777 <stepik-777@mail.ru>
parents:
7180
diff
changeset
|
264 |
|
6042
8b5345758f62
some more cleanups/refactoring/blahblah, some button positions may are a bit off atm. also I added a new picture for one of the buttons
sheepluva
parents:
6036
diff
changeset
|
265 |
//connect(ui.pageMain->BtnExit, SIGNAL(pressed()), this, SLOT(btnExitPressed())); |
8b5345758f62
some more cleanups/refactoring/blahblah, some button positions may are a bit off atm. also I added a new picture for one of the buttons
sheepluva
parents:
6036
diff
changeset
|
266 |
//connect(ui.pageMain->BtnExit, SIGNAL(clicked()), this, SLOT(btnExitClicked())); |
184 | 267 |
|
7553 | 268 |
connect(ui.pageEditTeam, SIGNAL(goBack()), this, SLOT(AfterTeamEdit())); |
1840 | 269 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
270 |
connect(ui.pageMultiplayer->BtnStartMPGame, SIGNAL(clicked()), this, SLOT(StartMPGame())); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
271 |
connect(ui.pageMultiplayer->teamsSelect, SIGNAL(setEnabledGameStart(bool)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
272 |
ui.pageMultiplayer->BtnStartMPGame, SLOT(setEnabled(bool))); |
4410
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
273 |
connect(ui.pageMultiplayer, SIGNAL(SetupClicked()), this, SLOT(IntermediateSetup())); |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
274 |
connect(ui.pageMultiplayer->gameCFG, SIGNAL(goToSchemes(int)), this, SLOT(GoToScheme(int))); |
12665
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
275 |
connect(ui.pageMultiplayer->gameCFG, SIGNAL(goToWeapons(int)), this, SLOT(GoToWeapons(int))); |
4511 | 276 |
connect(ui.pageMultiplayer->gameCFG, SIGNAL(goToDrawMap()), pageSwitchMapper, SLOT(map())); |
277 |
pageSwitchMapper->setMapping(ui.pageMultiplayer->gameCFG, ID_PAGE_DRAWMAP); |
|
184 | 278 |
|
6009 | 279 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
280 |
connect(ui.pagePlayDemo->BtnPlayDemo, SIGNAL(clicked()), this, SLOT(PlayDemo())); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
281 |
connect(ui.pagePlayDemo->DemosList, SIGNAL(doubleClicked (const QModelIndex &)), this, SLOT(PlayDemo())); |
184 | 282 |
|
6024 | 283 |
connect(ui.pageOptions, SIGNAL(newTeamRequested()), this, SLOT(NewTeam())); |
284 |
connect(ui.pageOptions, SIGNAL(editTeamRequested(const QString&)), this, SLOT(EditTeam(const QString&))); |
|
285 |
connect(ui.pageOptions, SIGNAL(deleteTeamRequested(const QString&)), this, SLOT(DeleteTeam(const QString&))); |
|
6525
6c97379c584b
[GCI] backz task: unify the back button functionality, avoid using the save button
m4tx
parents:
6477
diff
changeset
|
286 |
connect(ui.pageOptions, SIGNAL(goBack()), config, SLOT(SaveOptions())); |
3932 | 287 |
connect(ui.pageOptions->BtnAssociateFiles, SIGNAL(clicked()), this, SLOT(AssociateFiles())); |
695 | 288 |
|
12665
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
289 |
connect(ui.pageOptions->WeaponEdit, SIGNAL(clicked()), this, SLOT(GoToEditWeapons())); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
290 |
connect(ui.pageOptions->WeaponNew, SIGNAL(clicked()), this, SLOT(GoToNewWeapons())); |
4416
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
291 |
connect(ui.pageOptions->WeaponDelete, SIGNAL(clicked()), this, SLOT(DeleteWeaponSet())); |
4410
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
292 |
connect(ui.pageOptions->SchemeEdit, SIGNAL(clicked()), this, SLOT(GoToEditScheme())); |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
293 |
connect(ui.pageOptions->SchemeNew, SIGNAL(clicked()), this, SLOT(GoToNewScheme())); |
4416
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
294 |
connect(ui.pageOptions->SchemeDelete, SIGNAL(clicked()), this, SLOT(DeleteScheme())); |
6574 | 295 |
connect(ui.pageOptions->CBFrontendEffects, SIGNAL(toggled(bool)), this, SLOT(onFrontendEffects(bool)) ); |
15090
33eca3f0a9aa
PageEditTeam: Disable sound test button when frontend sounds are disabled
Wuzzy <Wuzzy2@mail.ru>
parents:
14934
diff
changeset
|
296 |
connect(ui.pageOptions->CBFrontendSound, SIGNAL(toggled(bool)), this, SLOT(onFrontendSoundsToggled(bool))); |
184 | 297 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
298 |
connect(ui.pageNet->BtnSpecifyServer, SIGNAL(clicked()), this, SLOT(NetConnect())); |
4518 | 299 |
connect(ui.pageNet->BtnNetSvrStart, SIGNAL(clicked()), pageSwitchMapper, SLOT(map())); |
300 |
pageSwitchMapper->setMapping(ui.pageNet->BtnNetSvrStart, ID_PAGE_NETSERVER); |
|
301 |
||
14865 | 302 |
connect(ui.pageNet, SIGNAL(connectClicked(const QString &, quint16, bool)), this, SLOT(NetConnectServer(const QString &, quint16, bool))); |
2377 | 303 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
304 |
connect(ui.pageNetServer->BtnStart, SIGNAL(clicked()), this, SLOT(NetStartServer())); |
184 | 305 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
306 |
connect(ui.pageNetGame->pNetTeamsWidget, SIGNAL(setEnabledGameStart(bool)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
307 |
ui.pageNetGame->BtnStart, SLOT(setEnabled(bool))); |
4410
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
308 |
connect(ui.pageNetGame, SIGNAL(SetupClicked()), this, SLOT(IntermediateSetup())); |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
309 |
connect(ui.pageNetGame->pGameCFG, SIGNAL(goToSchemes(int)), this, SLOT(GoToScheme(int))); |
12665
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
310 |
connect(ui.pageNetGame->pGameCFG, SIGNAL(goToWeapons(int)), this, SLOT(GoToWeapons(int))); |
4511 | 311 |
connect(ui.pageNetGame->pGameCFG, SIGNAL(goToDrawMap()), pageSwitchMapper, SLOT(map())); |
312 |
pageSwitchMapper->setMapping(ui.pageNetGame->pGameCFG, ID_PAGE_DRAWMAP); |
|
184 | 313 |
|
4518 | 314 |
connect(ui.pageRoomsList->BtnAdmin, SIGNAL(clicked()), pageSwitchMapper, SLOT(map())); |
315 |
pageSwitchMapper->setMapping(ui.pageRoomsList->BtnAdmin, ID_PAGE_ADMIN); |
|
187 | 316 |
|
5651
a7de68f4f87f
allow accessing the snapshot folder from the about page in the frontend (button could use a nicer icon)
koda
parents:
5567
diff
changeset
|
317 |
connect(ui.pageInfo->BtnSnapshots, SIGNAL(clicked()), this, SLOT(OpenSnapshotFolder())); |
1312 | 318 |
|
5734 | 319 |
connect(ui.pageGameStats, SIGNAL(saveDemoRequested()), this, SLOT(saveDemoWithCustomName())); |
8901
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
320 |
connect(ui.pageGameStats, SIGNAL(restartGameRequested()), this, SLOT(restartGame())); |
306 | 321 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
322 |
connect(ui.pageSinglePlayer->BtnSimpleGamePage, SIGNAL(clicked()), this, SLOT(SimpleGame())); |
4509
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
323 |
connect(ui.pageSinglePlayer->BtnTrainPage, SIGNAL(clicked()), pageSwitchMapper, SLOT(map())); |
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
324 |
pageSwitchMapper->setMapping(ui.pageSinglePlayer->BtnTrainPage, ID_PAGE_TRAINING); |
4518 | 325 |
|
4509
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
326 |
connect(ui.pageSinglePlayer->BtnCampaignPage, SIGNAL(clicked()), pageSwitchMapper, SLOT(map())); |
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
327 |
pageSwitchMapper->setMapping(ui.pageSinglePlayer->BtnCampaignPage, ID_PAGE_CAMPAIGN); |
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
328 |
|
4518 | 329 |
connect(ui.pageSinglePlayer->BtnMultiplayer, SIGNAL(clicked()), pageSwitchMapper, SLOT(map())); |
330 |
pageSwitchMapper->setMapping(ui.pageSinglePlayer->BtnMultiplayer, ID_PAGE_MULTIPLAYER); |
|
331 |
||
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
332 |
connect(ui.pageSinglePlayer->BtnLoad, SIGNAL(clicked()), this, SLOT(GoToSaves())); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
333 |
connect(ui.pageSinglePlayer->BtnDemos, SIGNAL(clicked()), this, SLOT(GoToDemos())); |
311 | 334 |
|
11968
1de4d6b35748
Mission recategorization into trainings, challenges and scenarios.
Wuzzy <almikes@aol.com>
parents:
11959
diff
changeset
|
335 |
connect(ui.pageTraining, SIGNAL(startMission(const QString&, const QString&)), this, SLOT(startTraining(const QString&, const QString&))); |
587 | 336 |
|
3760 | 337 |
connect(ui.pageCampaign->BtnStartCampaign, SIGNAL(clicked()), this, SLOT(StartCampaign())); |
9324
98368198a75d
added slot for starting campaign by clicking the image and some events in moon mission
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9308
diff
changeset
|
338 |
connect(ui.pageCampaign->btnPreview, SIGNAL(clicked()), this, SLOT(StartCampaign())); |
3760 | 339 |
connect(ui.pageCampaign->CBTeam, SIGNAL(currentIndexChanged(int)), this, SLOT(UpdateCampaignPage(int))); |
11950
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
340 |
connect(ui.pageCampaign->CBTeam, SIGNAL(currentIndexChanged(int)), this, SLOT(UpdateCampaignPageTeam(int))); |
7201
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
341 |
connect(ui.pageCampaign->CBCampaign, SIGNAL(currentIndexChanged(int)), this, SLOT(UpdateCampaignPage(int))); |
9182
f92e205bc167
issue 562, image and description for the campaign page
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9163
diff
changeset
|
342 |
connect(ui.pageCampaign->CBMission, SIGNAL(currentIndexChanged(int)), this, SLOT(UpdateCampaignPageMission(int))); |
14462
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
343 |
connect(ui.pageTraining->CBTeam, SIGNAL(currentIndexChanged(int)), this, SLOT(UpdateTrainingPageTeam(int))); |
14469
bfacce4ff920
Sync team comboboxes in campaign and training page
Wuzzy <Wuzzy2@mail.ru>
parents:
14468
diff
changeset
|
344 |
connect(ui.pageCampaign->CBTeam, SIGNAL(currentIndexChanged(int)), ui.pageTraining->CBTeam, SLOT(setCurrentIndex(int))); |
bfacce4ff920
Sync team comboboxes in campaign and training page
Wuzzy <Wuzzy2@mail.ru>
parents:
14468
diff
changeset
|
345 |
connect(ui.pageTraining->CBTeam, SIGNAL(currentIndexChanged(int)), ui.pageCampaign->CBTeam, SLOT(setCurrentIndex(int))); |
600 | 346 |
|
12665
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
347 |
connect(ui.pageSelectWeapon->pWeapons, SIGNAL(weaponsDeleted(QString)), |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
348 |
this, SLOT(DeleteWeapons(QString))); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
349 |
connect(ui.pageSelectWeapon->pWeapons, SIGNAL(weaponsAdded(QString, QString)), |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
350 |
this, SLOT(AddWeapons(QString, QString))); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
351 |
connect(ui.pageSelectWeapon->pWeapons, SIGNAL(weaponsEdited(QString, QString, QString)), |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
352 |
this, SLOT(EditWeapons(QString, QString, QString))); |
12811
de3cbbb09915
Fix host not re-sending ammo scheme after editing an existing ammo scheme
Wuzzy <Wuzzy2@mail.ru>
parents:
12799
diff
changeset
|
353 |
connect(ui.pageSelectWeapon->pWeapons, SIGNAL(weaponsEdited(QString, QString, QString)), |
de3cbbb09915
Fix host not re-sending ammo scheme after editing an existing ammo scheme
Wuzzy <Wuzzy2@mail.ru>
parents:
12799
diff
changeset
|
354 |
ui.pageNetGame->pGameCFG, SLOT(resendAmmoData())); |
1887 | 355 |
|
8318 | 356 |
connect(ui.pageMain->BtnNetLocal, SIGNAL(clicked()), this, SLOT(GoToNet())); |
357 |
connect(ui.pageMain->BtnNetOfficial, SIGNAL(clicked()), this, SLOT(NetConnectOfficialServer())); |
|
1950 | 358 |
|
7235
baa69bd025d9
1. Implement new page in frontend with options for video recording.
Stepan777 <stepik-777@mail.ru>
parents:
7180
diff
changeset
|
359 |
connect(ui.pageVideos, SIGNAL(goBack()), config, SLOT(SaveVideosOptions())); |
4509
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
360 |
|
13197
0bc5f618ca7c
Rename the misleadingly-named AmmoSchemeModel to GameSchemeModel
Wuzzy <Wuzzy2@mail.ru>
parents:
13086
diff
changeset
|
361 |
gameSchemeModel = new GameSchemeModel(this, cfgdir->absolutePath() + "/Schemes/Game"); |
0bc5f618ca7c
Rename the misleadingly-named AmmoSchemeModel to GameSchemeModel
Wuzzy <Wuzzy2@mail.ru>
parents:
13086
diff
changeset
|
362 |
ui.pageScheme->setModel(gameSchemeModel); |
0bc5f618ca7c
Rename the misleadingly-named AmmoSchemeModel to GameSchemeModel
Wuzzy <Wuzzy2@mail.ru>
parents:
13086
diff
changeset
|
363 |
ui.pageMultiplayer->gameCFG->GameSchemes->setModel(gameSchemeModel); |
0bc5f618ca7c
Rename the misleadingly-named AmmoSchemeModel to GameSchemeModel
Wuzzy <Wuzzy2@mail.ru>
parents:
13086
diff
changeset
|
364 |
ui.pageOptions->SchemesName->setModel(gameSchemeModel); |
1885 | 365 |
|
6574 | 366 |
wBackground = new BGWidget(this); |
367 |
wBackground->setFixedSize(this->width(), this->height()); |
|
368 |
wBackground->lower(); |
|
369 |
wBackground->init(); |
|
370 |
wBackground->enabled = config->isFrontendEffects(); |
|
371 |
wBackground->startAnimation(); |
|
2012 | 372 |
|
6477 | 373 |
//Install all eventFilters : |
374 |
||
375 |
MouseOverFilter *filter = new MouseOverFilter(); |
|
376 |
filter->setUi(&ui); |
|
377 |
||
378 |
QList<QWidget *> widgets; |
|
379 |
||
380 |
for (int i=0; i < ui.Pages->count(); i++) |
|
381 |
{ |
|
382 |
widgets = ui.Pages->widget(i)->findChildren<QWidget *>(); |
|
383 |
||
384 |
for (int i=0; i < widgets.size(); i++) |
|
385 |
{ |
|
386 |
widgets.at(i)->installEventFilter(filter); |
|
387 |
} |
|
388 |
} |
|
389 |
||
8569 | 390 |
ui.Pages->setCurrentIndex(ID_PAGE_INFO); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
391 |
PagesStack.push(ID_PAGE_MAIN); |
8384 | 392 |
((AbstractPage*)ui.Pages->widget(ID_PAGE_MAIN))->triggerPageEnter(); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
393 |
GoBack(); |
13330 | 394 |
|
395 |
connect(config, SIGNAL(frontendFullscreen(bool)), this, SLOT(onFrontendFullscreen(bool))); |
|
396 |
onFrontendFullscreen(config->isFrontendFullscreen()); |
|
184 | 397 |
} |
398 |
||
1162 | 399 |
void HWForm::onFrontendFullscreen(bool value) |
400 |
{ |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
401 |
if (value) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
402 |
setWindowState(windowState() | Qt::WindowFullScreen); |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
403 |
else |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
404 |
{ |
12725
1a393a59a594
Fix GCC warnings: -Wimplicit-fallthrough and -Wint-in-bool-context
Wuzzy <Wuzzy2@mail.ru>
parents:
12674
diff
changeset
|
405 |
setWindowState(windowState() & ~Qt::WindowFullScreen); |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
406 |
} |
1162 | 407 |
} |
408 |
||
6574 | 409 |
void HWForm::onFrontendEffects(bool value) |
410 |
{ |
|
411 |
wBackground->enabled = value; |
|
412 |
if (value) |
|
413 |
wBackground->startAnimation(); |
|
414 |
else |
|
415 |
wBackground->stopAnimation(); |
|
416 |
} |
|
417 |
||
15090
33eca3f0a9aa
PageEditTeam: Disable sound test button when frontend sounds are disabled
Wuzzy <Wuzzy2@mail.ru>
parents:
14934
diff
changeset
|
418 |
void HWForm::onFrontendSoundsToggled(bool value) |
33eca3f0a9aa
PageEditTeam: Disable sound test button when frontend sounds are disabled
Wuzzy <Wuzzy2@mail.ru>
parents:
14934
diff
changeset
|
419 |
{ |
33eca3f0a9aa
PageEditTeam: Disable sound test button when frontend sounds are disabled
Wuzzy <Wuzzy2@mail.ru>
parents:
14934
diff
changeset
|
420 |
ui.pageEditTeam->frontendSoundsToggled(value); |
33eca3f0a9aa
PageEditTeam: Disable sound test button when frontend sounds are disabled
Wuzzy <Wuzzy2@mail.ru>
parents:
14934
diff
changeset
|
421 |
} |
33eca3f0a9aa
PageEditTeam: Disable sound test button when frontend sounds are disabled
Wuzzy <Wuzzy2@mail.ru>
parents:
14934
diff
changeset
|
422 |
|
4592
b1fe47b11b99
disable fix for issue 24 in order to fix issue 123, as suggested by koda
sheepluva
parents:
4576
diff
changeset
|
423 |
/* |
3937 | 424 |
void HWForm::keyReleaseEvent(QKeyEvent *event) |
425 |
{ |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
426 |
if (event->key() == Qt::Key_Escape) |
3937 | 427 |
this->GoBack(); |
428 |
} |
|
4592
b1fe47b11b99
disable fix for issue 24 in order to fix issue 123, as suggested by koda
sheepluva
parents:
4576
diff
changeset
|
429 |
*/ |
3937 | 430 |
|
1419 | 431 |
void HWForm::CustomizePalettes() |
432 |
{ |
|
12220
a7c08e4748ff
Use the same link color consistently in frontend
Wuzzy <almikes@aol.com>
parents:
12217
diff
changeset
|
433 |
// Scroll bar widget palette |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
434 |
QList<QScrollBar *> allSBars = findChildren<QScrollBar *>(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
435 |
QPalette pal = palette(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
436 |
pal.setColor(QPalette::WindowText, QColor(0xff, 0xcc, 0x00)); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
437 |
pal.setColor(QPalette::Button, QColor(0x00, 0x35, 0x1d)); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
438 |
pal.setColor(QPalette::Base, QColor(0x00, 0x35, 0x1d)); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
439 |
pal.setColor(QPalette::Window, QColor(0x00, 0x00, 0x00)); |
1419 | 440 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
441 |
for (int i = 0; i < allSBars.size(); ++i) |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
442 |
allSBars.at(i)->setPalette(pal); |
12220
a7c08e4748ff
Use the same link color consistently in frontend
Wuzzy <almikes@aol.com>
parents:
12217
diff
changeset
|
443 |
|
a7c08e4748ff
Use the same link color consistently in frontend
Wuzzy <almikes@aol.com>
parents:
12217
diff
changeset
|
444 |
// Set default hyperlink color |
a7c08e4748ff
Use the same link color consistently in frontend
Wuzzy <almikes@aol.com>
parents:
12217
diff
changeset
|
445 |
QPalette appPal = qApp->palette(); |
a7c08e4748ff
Use the same link color consistently in frontend
Wuzzy <almikes@aol.com>
parents:
12217
diff
changeset
|
446 |
appPal.setColor(QPalette::Link, QColor(0xff, 0xff, 0x6e)); |
a7c08e4748ff
Use the same link color consistently in frontend
Wuzzy <almikes@aol.com>
parents:
12217
diff
changeset
|
447 |
qApp->setPalette(appPal); |
1419 | 448 |
} |
449 |
||
695 | 450 |
void HWForm::UpdateWeapons() |
451 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
452 |
QVector<QComboBox*> combos; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
453 |
combos.push_back(ui.pageOptions->WeaponsName); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
454 |
combos.push_back(ui.pageMultiplayer->gameCFG->WeaponsName); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
455 |
combos.push_back(ui.pageNetGame->pGameCFG->WeaponsName); |
4416
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
456 |
combos.push_back(ui.pageSelectWeapon->selectWeaponSet); |
696 | 457 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
458 |
QStringList names = ui.pageSelectWeapon->pWeapons->getWeaponNames(); |
1517 | 459 |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
460 |
for(QVector<QComboBox*>::iterator it = combos.begin(); it != combos.end(); ++it) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
461 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
462 |
(*it)->clear(); |
1517 | 463 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
464 |
for(int i = 0; i < names.size(); ++i) |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
465 |
(*it)->addItem(names[i], ui.pageSelectWeapon->pWeapons->getWeaponsString(names[i])); |
2377 | 466 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
467 |
int pos = (*it)->findText("Default"); |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
468 |
if (pos != -1) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
469 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
470 |
(*it)->setCurrentIndex(pos); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
471 |
} |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
472 |
} |
695 | 473 |
} |
474 |
||
12665
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
475 |
void HWForm::AddWeapons(QString weaponsName, QString ammo) |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
476 |
{ |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
477 |
QVector<QComboBox*> combos; |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
478 |
combos.push_back(ui.pageOptions->WeaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
479 |
combos.push_back(ui.pageMultiplayer->gameCFG->WeaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
480 |
combos.push_back(ui.pageNetGame->pGameCFG->WeaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
481 |
combos.push_back(ui.pageSelectWeapon->selectWeaponSet); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
482 |
|
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
483 |
QStringList names = ui.pageSelectWeapon->pWeapons->getWeaponNames(); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
484 |
|
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
485 |
for(QVector<QComboBox*>::iterator it = combos.begin(); it != combos.end(); ++it) |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
486 |
{ |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
487 |
(*it)->addItem(weaponsName, QVariant(ammo)); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
488 |
} |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
489 |
ui.pageSelectWeapon->selectWeaponSet->setCurrentIndex(ui.pageSelectWeapon->selectWeaponSet->count()-1); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
490 |
} |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
491 |
|
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
492 |
void HWForm::DeleteWeapons(QString weaponsName) |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
493 |
{ |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
494 |
QVector<QComboBox*> combos; |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
495 |
combos.push_back(ui.pageOptions->WeaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
496 |
combos.push_back(ui.pageMultiplayer->gameCFG->WeaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
497 |
combos.push_back(ui.pageNetGame->pGameCFG->WeaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
498 |
combos.push_back(ui.pageSelectWeapon->selectWeaponSet); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
499 |
|
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
500 |
QStringList names = ui.pageSelectWeapon->pWeapons->getWeaponNames(); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
501 |
|
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
502 |
for(QVector<QComboBox*>::iterator it = combos.begin(); it != combos.end(); ++it) |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
503 |
{ |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
504 |
int pos = (*it)->findText(weaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
505 |
if (pos != -1) |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
506 |
{ |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
507 |
(*it)->removeItem(pos); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
508 |
} |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
509 |
} |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
510 |
ui.pageSelectWeapon->pWeapons->deletionDone(); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
511 |
} |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
512 |
|
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
513 |
void HWForm::EditWeapons(QString oldWeaponsName, QString newWeaponsName, QString ammo) |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
514 |
{ |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
515 |
QVector<QComboBox*> combos; |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
516 |
combos.push_back(ui.pageOptions->WeaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
517 |
combos.push_back(ui.pageMultiplayer->gameCFG->WeaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
518 |
combos.push_back(ui.pageNetGame->pGameCFG->WeaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
519 |
combos.push_back(ui.pageSelectWeapon->selectWeaponSet); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
520 |
|
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
521 |
QStringList names = ui.pageSelectWeapon->pWeapons->getWeaponNames(); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
522 |
|
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
523 |
for(QVector<QComboBox*>::iterator it = combos.begin(); it != combos.end(); ++it) |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
524 |
{ |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
525 |
int pos = (*it)->findText(oldWeaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
526 |
(*it)->setItemText(pos, newWeaponsName); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
527 |
(*it)->setItemData(pos, ammo); |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
528 |
} |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
529 |
} |
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
530 |
|
8140 | 531 |
void HWForm::UpdateTeamsLists() |
245 | 532 |
{ |
8140 | 533 |
QStringList teamslist = config->GetTeamsList(); |
245 | 534 |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
535 |
if(teamslist.empty()) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
536 |
{ |
14740
7b2bd37d7503
Fix inconsistencies in guest nick name generation
Wuzzy <Wuzzy2@mail.ru>
parents:
14677
diff
changeset
|
537 |
QString currentNickName = config->value("net/nick", config->getRandomNick()).toString(); |
8136 | 538 |
QString teamName; |
12633
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
539 |
int firstHumanTeam = 1; |
12635 | 540 |
int lastHumanTeam = 2; |
8140 | 541 |
|
12241
0b5aa545e058
Add 4 teams on first start of Hedgewars
Wuzzy <almikes@aol.com>
parents:
12220
diff
changeset
|
542 |
// Default team |
8140 | 543 |
if (currentNickName.isEmpty()) |
8136 | 544 |
{ |
12241
0b5aa545e058
Add 4 teams on first start of Hedgewars
Wuzzy <almikes@aol.com>
parents:
12220
diff
changeset
|
545 |
teamName = tr("Team 1"); |
12633
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
546 |
firstHumanTeam++; |
8136 | 547 |
} |
548 |
else |
|
549 |
{ |
|
550 |
teamName = tr("%1's Team").arg(currentNickName); |
|
12633
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
551 |
lastHumanTeam--; |
8136 | 552 |
} |
8140 | 553 |
|
8136 | 554 |
HWTeam defaultTeam(teamName); |
12296
62975c0a89c6
Only select from default graves and forts for new themes
Wuzzy <almikes@aol.com>
parents:
12244
diff
changeset
|
555 |
// Randomize fort and grave for greater variety by default. |
62975c0a89c6
Only select from default graves and forts for new themes
Wuzzy <almikes@aol.com>
parents:
12244
diff
changeset
|
556 |
// But we exclude DLC graves and forts to not have desyncing teams by default |
62975c0a89c6
Only select from default graves and forts for new themes
Wuzzy <almikes@aol.com>
parents:
12244
diff
changeset
|
557 |
// TODO: Remove DLC filtering when it isn't neccessary anymore |
62975c0a89c6
Only select from default graves and forts for new themes
Wuzzy <almikes@aol.com>
parents:
12244
diff
changeset
|
558 |
HWNamegen::teamRandomGrave(defaultTeam, false); |
62975c0a89c6
Only select from default graves and forts for new themes
Wuzzy <almikes@aol.com>
parents:
12244
diff
changeset
|
559 |
HWNamegen::teamRandomFort(defaultTeam, false); |
14934
0ec0ed2d9045
Frontend: Select appropriate localized Default voicepack for new teams
Wuzzy <Wuzzy2@mail.ru>
parents:
14903
diff
changeset
|
560 |
HWNamegen::teamLocalizedDefaultVoice(defaultTeam); |
6015
daffc14a518a
cleaning up a little bit more, especially team class. we were leaking teams into heap memory on quick game starts btw
sheepluva
parents:
6009
diff
changeset
|
561 |
defaultTeam.saveToFile(); |
8136 | 562 |
teamslist.push_back(teamName); |
12241
0b5aa545e058
Add 4 teams on first start of Hedgewars
Wuzzy <almikes@aol.com>
parents:
12220
diff
changeset
|
563 |
|
12633
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
564 |
// Add additional default teams |
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
565 |
|
12634
91e55ce06ffc
Reduce number of initial teams: 4 human, 2 AI teams
Wuzzy <almikes@aol.com>
parents:
12633
diff
changeset
|
566 |
// More human teams to allow local multiplayer instantly |
12633
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
567 |
for(int i=firstHumanTeam; i<=lastHumanTeam; i++) |
12241
0b5aa545e058
Add 4 teams on first start of Hedgewars
Wuzzy <almikes@aol.com>
parents:
12220
diff
changeset
|
568 |
{ |
12633
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
569 |
//: Default team name |
12241
0b5aa545e058
Add 4 teams on first start of Hedgewars
Wuzzy <almikes@aol.com>
parents:
12220
diff
changeset
|
570 |
teamName = tr("Team %1").arg(i); |
0b5aa545e058
Add 4 teams on first start of Hedgewars
Wuzzy <almikes@aol.com>
parents:
12220
diff
changeset
|
571 |
HWTeam numberTeam(teamName); |
12296
62975c0a89c6
Only select from default graves and forts for new themes
Wuzzy <almikes@aol.com>
parents:
12244
diff
changeset
|
572 |
HWNamegen::teamRandomGrave(numberTeam, false); |
62975c0a89c6
Only select from default graves and forts for new themes
Wuzzy <almikes@aol.com>
parents:
12244
diff
changeset
|
573 |
HWNamegen::teamRandomFort(numberTeam, false); |
14934
0ec0ed2d9045
Frontend: Select appropriate localized Default voicepack for new teams
Wuzzy <Wuzzy2@mail.ru>
parents:
14903
diff
changeset
|
574 |
HWNamegen::teamLocalizedDefaultVoice(numberTeam); |
12241
0b5aa545e058
Add 4 teams on first start of Hedgewars
Wuzzy <almikes@aol.com>
parents:
12220
diff
changeset
|
575 |
numberTeam.saveToFile(); |
0b5aa545e058
Add 4 teams on first start of Hedgewars
Wuzzy <almikes@aol.com>
parents:
12220
diff
changeset
|
576 |
teamslist.push_back(teamName); |
0b5aa545e058
Add 4 teams on first start of Hedgewars
Wuzzy <almikes@aol.com>
parents:
12220
diff
changeset
|
577 |
} |
12634
91e55ce06ffc
Reduce number of initial teams: 4 human, 2 AI teams
Wuzzy <almikes@aol.com>
parents:
12633
diff
changeset
|
578 |
// Add 2 default CPU teams |
12635 | 579 |
for(int i=1; i<=5; i=i+2) |
12633
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
580 |
{ |
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
581 |
//: Default computer team name |
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
582 |
teamName = tr("Computer %1").arg(i); |
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
583 |
HWTeam numberTeam(teamName); |
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
584 |
HWNamegen::teamRandomGrave(numberTeam, false); |
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
585 |
HWNamegen::teamRandomFort(numberTeam, false); |
14934
0ec0ed2d9045
Frontend: Select appropriate localized Default voicepack for new teams
Wuzzy <Wuzzy2@mail.ru>
parents:
14903
diff
changeset
|
586 |
HWNamegen::teamLocalizedDefaultVoice(numberTeam); |
12633
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
587 |
numberTeam.setDifficulty(6-i); |
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
588 |
numberTeam.saveToFile(); |
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
589 |
teamslist.push_back(teamName); |
a791a08062d6
Create 5 human teams + 5 AI teams on first start
Wuzzy <almikes@aol.com>
parents:
12305
diff
changeset
|
590 |
} |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
591 |
} |
245 | 592 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
593 |
ui.pageOptions->CBTeamName->clear(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
594 |
ui.pageOptions->CBTeamName->addItems(teamslist); |
3760 | 595 |
ui.pageCampaign->CBTeam->clear(); |
14462
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
596 |
ui.pageTraining->CBTeam->clear(); |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
597 |
/* Only show human teams in campaign/training page */ |
14646
e3e6b0c6543f
Frontend: Gray out campaign/training start buttons when no human team available
Wuzzy <Wuzzy2@mail.ru>
parents:
14602
diff
changeset
|
598 |
bool playable = false; |
11959
3c15903256a7
Don't show AI-controlled teams in campaigns page
Wuzzy <almikes@aol.com>
parents:
11958
diff
changeset
|
599 |
for(int i=0; i<teamslist.length(); i++) |
3c15903256a7
Don't show AI-controlled teams in campaigns page
Wuzzy <almikes@aol.com>
parents:
11958
diff
changeset
|
600 |
{ |
3c15903256a7
Don't show AI-controlled teams in campaigns page
Wuzzy <almikes@aol.com>
parents:
11958
diff
changeset
|
601 |
HWTeam testTeam = HWTeam(teamslist[i]); |
3c15903256a7
Don't show AI-controlled teams in campaigns page
Wuzzy <almikes@aol.com>
parents:
11958
diff
changeset
|
602 |
testTeam.loadFromFile(); |
3c15903256a7
Don't show AI-controlled teams in campaigns page
Wuzzy <almikes@aol.com>
parents:
11958
diff
changeset
|
603 |
if(testTeam.difficulty() == 0) |
3c15903256a7
Don't show AI-controlled teams in campaigns page
Wuzzy <almikes@aol.com>
parents:
11958
diff
changeset
|
604 |
{ |
3c15903256a7
Don't show AI-controlled teams in campaigns page
Wuzzy <almikes@aol.com>
parents:
11958
diff
changeset
|
605 |
ui.pageCampaign->CBTeam->addItem(teamslist[i]); |
14462
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
606 |
ui.pageTraining->CBTeam->addItem(teamslist[i]); |
14646
e3e6b0c6543f
Frontend: Gray out campaign/training start buttons when no human team available
Wuzzy <Wuzzy2@mail.ru>
parents:
14602
diff
changeset
|
607 |
playable = true; |
11959
3c15903256a7
Don't show AI-controlled teams in campaigns page
Wuzzy <almikes@aol.com>
parents:
11958
diff
changeset
|
608 |
} |
3c15903256a7
Don't show AI-controlled teams in campaigns page
Wuzzy <almikes@aol.com>
parents:
11958
diff
changeset
|
609 |
} |
14646
e3e6b0c6543f
Frontend: Gray out campaign/training start buttons when no human team available
Wuzzy <Wuzzy2@mail.ru>
parents:
14602
diff
changeset
|
610 |
ui.pageCampaign->BtnStartCampaign->setEnabled(playable); |
e3e6b0c6543f
Frontend: Gray out campaign/training start buttons when no human team available
Wuzzy <Wuzzy2@mail.ru>
parents:
14602
diff
changeset
|
611 |
ui.pageCampaign->btnPreview->setEnabled(playable); |
e3e6b0c6543f
Frontend: Gray out campaign/training start buttons when no human team available
Wuzzy <Wuzzy2@mail.ru>
parents:
14602
diff
changeset
|
612 |
ui.pageTraining->btnStart->setEnabled(playable); |
e3e6b0c6543f
Frontend: Gray out campaign/training start buttons when no human team available
Wuzzy <Wuzzy2@mail.ru>
parents:
14602
diff
changeset
|
613 |
ui.pageTraining->btnPreview->setEnabled(playable); |
14462
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
614 |
UpdateTrainingPageTeam(0); |
245 | 615 |
} |
616 |
||
12665
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
617 |
void HWForm::GoToNewWeapons() |
694 | 618 |
{ |
4416
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
619 |
ui.pageSelectWeapon->pWeapons->newWeaponsName(); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
620 |
GoToPage(ID_PAGE_SELECTWEAPON); |
694 | 621 |
} |
622 |
||
12665
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
623 |
void HWForm::GoToEditWeapons() |
600 | 624 |
{ |
4416
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
625 |
ui.pageSelectWeapon->selectWeaponSet->setCurrentIndex(ui.pageOptions->WeaponsName->currentIndex()); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
626 |
GoToPage(ID_PAGE_SELECTWEAPON); |
600 | 627 |
} |
628 |
||
12665
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
629 |
void HWForm::GoToWeapons(int index) |
2009 | 630 |
{ |
4416
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
631 |
ui.pageSelectWeapon->selectWeaponSet->setCurrentIndex(index); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
632 |
GoToPage(ID_PAGE_SELECTWEAPON); |
2009 | 633 |
} |
634 |
||
12665
5664ec82aed7
Rework weapon scheme handling in frontend and fix a couple of bugs
Wuzzy <almikes@aol.com>
parents:
12635
diff
changeset
|
635 |
|
579 | 636 |
void HWForm::GoToSaves() |
637 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
638 |
ui.pagePlayDemo->FillFromDir(PagePlayDemo::RT_Save); |
579 | 639 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
640 |
GoToPage(ID_PAGE_DEMOS); |
579 | 641 |
} |
642 |
||
184 | 643 |
void HWForm::GoToDemos() |
644 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
645 |
ui.pagePlayDemo->FillFromDir(PagePlayDemo::RT_Demo); |
579 | 646 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
647 |
GoToPage(ID_PAGE_DEMOS); |
184 | 648 |
} |
649 |
||
650 |
void HWForm::GoToNet() |
|
651 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
652 |
ui.pageNet->updateServersList(); |
632
5e09ae25729f
Half implement possibility for different backends of servers list
unc0rr
parents:
625
diff
changeset
|
653 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
654 |
GoToPage(ID_PAGE_NET); |
184 | 655 |
} |
656 |
||
4410
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
657 |
void HWForm::GoToScheme(int index) |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
658 |
{ |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
659 |
ui.pageScheme->selectScheme->setCurrentIndex(index); |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
660 |
GoToPage(ID_PAGE_SCHEME); |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
661 |
} |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
662 |
|
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
663 |
void HWForm::GoToNewScheme() |
1885 | 664 |
{ |
4410
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
665 |
ui.pageScheme->newRow(); |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
666 |
GoToPage(ID_PAGE_SCHEME); |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
667 |
} |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
668 |
|
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
669 |
void HWForm::GoToEditScheme() |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
670 |
{ |
f9e38ce1e813
a Henek-koda production: nicer game config screen, fixed scheme-weapon lock, added scheme editing to config page and some minor stuff
Henek
parents:
4392
diff
changeset
|
671 |
ui.pageScheme->selectScheme->setCurrentIndex(ui.pageOptions->SchemesName->currentIndex()); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
672 |
GoToPage(ID_PAGE_SCHEME); |
1885 | 673 |
} |
674 |
||
13818
a8fd5490932f
Add help button in main menu (opens Hedgewars Wiki in browser)
Wuzzy <Wuzzy2@mail.ru>
parents:
13689
diff
changeset
|
675 |
void HWForm::GoToHelp() |
a8fd5490932f
Add help button in main menu (opens Hedgewars Wiki in browser)
Wuzzy <Wuzzy2@mail.ru>
parents:
13689
diff
changeset
|
676 |
{ |
a8fd5490932f
Add help button in main menu (opens Hedgewars Wiki in browser)
Wuzzy <Wuzzy2@mail.ru>
parents:
13689
diff
changeset
|
677 |
// For now just opens the Hedgewars Wiki in external browser. |
a8fd5490932f
Add help button in main menu (opens Hedgewars Wiki in browser)
Wuzzy <Wuzzy2@mail.ru>
parents:
13689
diff
changeset
|
678 |
// TODO: Replace this with an offline help someday (bug 660). |
a8fd5490932f
Add help button in main menu (opens Hedgewars Wiki in browser)
Wuzzy <Wuzzy2@mail.ru>
parents:
13689
diff
changeset
|
679 |
QDesktopServices::openUrl(QUrl("https://hedgewars.org/wiki")); |
a8fd5490932f
Add help button in main menu (opens Hedgewars Wiki in browser)
Wuzzy <Wuzzy2@mail.ru>
parents:
13689
diff
changeset
|
680 |
} |
a8fd5490932f
Add help button in main menu (opens Hedgewars Wiki in browser)
Wuzzy <Wuzzy2@mail.ru>
parents:
13689
diff
changeset
|
681 |
|
7353
0e55228e1303
When there are videos that are being encoded and user tries to quit display dialog with warning.
Stepan777 <stepik-777@mail.ru>
parents:
7347
diff
changeset
|
682 |
void HWForm::GoToVideos() |
0e55228e1303
When there are videos that are being encoded and user tries to quit display dialog with warning.
Stepan777 <stepik-777@mail.ru>
parents:
7347
diff
changeset
|
683 |
{ |
0e55228e1303
When there are videos that are being encoded and user tries to quit display dialog with warning.
Stepan777 <stepik-777@mail.ru>
parents:
7347
diff
changeset
|
684 |
GoToPage(ID_PAGE_VIDEOS); |
0e55228e1303
When there are videos that are being encoded and user tries to quit display dialog with warning.
Stepan777 <stepik-777@mail.ru>
parents:
7347
diff
changeset
|
685 |
} |
0e55228e1303
When there are videos that are being encoded and user tries to quit display dialog with warning.
Stepan777 <stepik-777@mail.ru>
parents:
7347
diff
changeset
|
686 |
|
13086
8d569c7b36a2
Frontend: Lead first-time player to training page on start
Wuzzy <Wuzzy2@mail.ru>
parents:
12924
diff
changeset
|
687 |
void HWForm::GoToTraining() |
8d569c7b36a2
Frontend: Lead first-time player to training page on start
Wuzzy <Wuzzy2@mail.ru>
parents:
12924
diff
changeset
|
688 |
{ |
8d569c7b36a2
Frontend: Lead first-time player to training page on start
Wuzzy <Wuzzy2@mail.ru>
parents:
12924
diff
changeset
|
689 |
GoToPage(ID_PAGE_TRAINING); |
8d569c7b36a2
Frontend: Lead first-time player to training page on start
Wuzzy <Wuzzy2@mail.ru>
parents:
12924
diff
changeset
|
690 |
} |
8d569c7b36a2
Frontend: Lead first-time player to training page on start
Wuzzy <Wuzzy2@mail.ru>
parents:
12924
diff
changeset
|
691 |
|
8353 | 692 |
//TODO: maybe find a better place for this? |
693 |
QString HWForm::stringifyPageId(quint32 id) |
|
694 |
{ |
|
695 |
QString pageName; |
|
696 |
switch (id) |
|
697 |
{ |
|
698 |
case ID_PAGE_SETUP_TEAM : pageName = "PAGE_SETUP_TEAM"; break; |
|
699 |
case ID_PAGE_SETUP : pageName = "PAGE_SETUP"; break; |
|
700 |
case ID_PAGE_MULTIPLAYER : pageName = "PAGE_MULTIPLAYER"; break; |
|
701 |
case ID_PAGE_DEMOS : pageName = "PAGE_DEMOS"; break; |
|
702 |
case ID_PAGE_NET : pageName = "PAGE_NET"; break; |
|
703 |
case ID_PAGE_NETGAME : pageName = "PAGE_NETGAME"; break; |
|
704 |
case ID_PAGE_INFO : pageName = "PAGE_INFO"; break; |
|
705 |
case ID_PAGE_MAIN : pageName = "PAGE_MAIN"; break; |
|
706 |
case ID_PAGE_GAMESTATS : pageName = "PAGE_GAMESTATS"; break; |
|
707 |
case ID_PAGE_SINGLEPLAYER : pageName = "PAGE_SINGLEPLAYER"; break; |
|
708 |
case ID_PAGE_TRAINING : pageName = "PAGE_TRAINING"; break; |
|
709 |
case ID_PAGE_SELECTWEAPON : pageName = "PAGE_SELECTWEAPON"; break; |
|
710 |
case ID_PAGE_NETSERVER : pageName = "PAGE_NETSERVER"; break; |
|
711 |
case ID_PAGE_INGAME : pageName = "PAGE_INGAME"; break; |
|
712 |
case ID_PAGE_ROOMSLIST : pageName = "PAGE_ROOMSLIST"; break; |
|
713 |
case ID_PAGE_CONNECTING : pageName = "PAGE_CONNECTING"; break; |
|
714 |
case ID_PAGE_SCHEME : pageName = "PAGE_SCHEME"; break; |
|
715 |
case ID_PAGE_ADMIN : pageName = "PAGE_ADMIN"; break; |
|
716 |
case ID_PAGE_CAMPAIGN : pageName = "PAGE_CAMPAIGN"; break; |
|
717 |
case ID_PAGE_DRAWMAP : pageName = "PAGE_DRAWMAP"; break; |
|
718 |
case ID_PAGE_DATADOWNLOAD : pageName = "PAGE_DATADOWNLOAD"; break; |
|
719 |
case ID_PAGE_VIDEOS : pageName = "PAGE_VIDEOS"; break; |
|
720 |
case MAX_PAGE : pageName = "MAX_PAGE"; break; |
|
721 |
default : pageName = "UNKNOWN_PAGE"; break; |
|
722 |
} |
|
723 |
return pageName; |
|
724 |
} |
|
725 |
||
496 | 726 |
void HWForm::OnPageShown(quint8 id, quint8 lastid) |
311 | 727 |
{ |
9235 | 728 |
#ifdef QT_DEBUG |
8353 | 729 |
qDebug("Leaving %s, entering %s", qPrintable(stringifyPageId(lastid)), qPrintable(stringifyPageId(id))); |
9235 | 730 |
#endif |
8977 | 731 |
if (lastid == ID_PAGE_MAIN) |
732 |
{ |
|
8982 | 733 |
ui.pageMain->resetNetworkChoice(); |
8977 | 734 |
} |
8353 | 735 |
|
8384 | 736 |
// pageEnter and pageLeave events |
8434 | 737 |
((AbstractPage*)ui.Pages->widget(lastid))->triggerPageLeave(); |
8384 | 738 |
((AbstractPage*)ui.Pages->widget(id))->triggerPageEnter(); |
739 |
||
5999
dad168522e3b
display a message when network is down or server is not reachable, nemo also made the page refresh at display time
koda
parents:
5907
diff
changeset
|
740 |
if (id == ID_PAGE_DATADOWNLOAD) |
dad168522e3b
display a message when network is down or server is not reachable, nemo also made the page refresh at display time
koda
parents:
5907
diff
changeset
|
741 |
{ |
dad168522e3b
display a message when network is down or server is not reachable, nemo also made the page refresh at display time
koda
parents:
5907
diff
changeset
|
742 |
ui.pageDataDownload->fetchList(); |
dad168522e3b
display a message when network is down or server is not reachable, nemo also made the page refresh at display time
koda
parents:
5907
diff
changeset
|
743 |
} |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
744 |
if (id == ID_PAGE_DRAWMAP) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
745 |
{ |
4520
e7882bd1a894
Allow to draw maps in frontend and play them (only locally, some bugs to fix)
unc0rr
parents:
4518
diff
changeset
|
746 |
DrawMapScene * scene; |
4535 | 747 |
if(lastid == ID_PAGE_MULTIPLAYER) |
4520
e7882bd1a894
Allow to draw maps in frontend and play them (only locally, some bugs to fix)
unc0rr
parents:
4518
diff
changeset
|
748 |
scene = ui.pageMultiplayer->gameCFG->pMapContainer->getDrawMapScene(); |
e7882bd1a894
Allow to draw maps in frontend and play them (only locally, some bugs to fix)
unc0rr
parents:
4518
diff
changeset
|
749 |
else |
e7882bd1a894
Allow to draw maps in frontend and play them (only locally, some bugs to fix)
unc0rr
parents:
4518
diff
changeset
|
750 |
scene = ui.pageNetGame->pGameCFG->pMapContainer->getDrawMapScene(); |
e7882bd1a894
Allow to draw maps in frontend and play them (only locally, some bugs to fix)
unc0rr
parents:
4518
diff
changeset
|
751 |
|
e7882bd1a894
Allow to draw maps in frontend and play them (only locally, some bugs to fix)
unc0rr
parents:
4518
diff
changeset
|
752 |
ui.pageDrawMap->drawMapWidget->setScene(scene); |
e7882bd1a894
Allow to draw maps in frontend and play them (only locally, some bugs to fix)
unc0rr
parents:
4518
diff
changeset
|
753 |
} |
5255
947025eeb5dc
under osx don't load a file in case a game is already running (also a little of code formatting)
koda
parents:
5252
diff
changeset
|
754 |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
755 |
if (lastid == ID_PAGE_DRAWMAP) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
756 |
{ |
5255
947025eeb5dc
under osx don't load a file in case a game is already running (also a little of code formatting)
koda
parents:
5252
diff
changeset
|
757 |
if (id == ID_PAGE_MULTIPLAYER) |
4525 | 758 |
ui.pageMultiplayer->gameCFG->pMapContainer->mapDrawingFinished(); |
4520
e7882bd1a894
Allow to draw maps in frontend and play them (only locally, some bugs to fix)
unc0rr
parents:
4518
diff
changeset
|
759 |
else |
4525 | 760 |
ui.pageNetGame->pGameCFG->pMapContainer->mapDrawingFinished(); |
4520
e7882bd1a894
Allow to draw maps in frontend and play them (only locally, some bugs to fix)
unc0rr
parents:
4518
diff
changeset
|
761 |
} |
e7882bd1a894
Allow to draw maps in frontend and play them (only locally, some bugs to fix)
unc0rr
parents:
4518
diff
changeset
|
762 |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
763 |
if (id == ID_PAGE_ROOMSLIST) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
764 |
{ |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
765 |
if (hwnet && game && game->gameState == gsStarted) // abnormal exit - kick or room destruction - send kills. |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
766 |
{ |
6190
1db2486e45f4
potential fix for issue #217 (SigSegV while in game room in KillAllTeams - team list change?)
sheepluva
parents:
6180
diff
changeset
|
767 |
game->netSuspend = true; |
6211
ee9465c0ea82
move (prematurely) finishing game by removing all teams into engine since that's where it should happen
sheepluva
parents:
6205
diff
changeset
|
768 |
ui.pageRoomsList->displayWarning(tr("Game aborted")); |
ee9465c0ea82
move (prematurely) finishing game by removing all teams into engine since that's where it should happen
sheepluva
parents:
6205
diff
changeset
|
769 |
game->abort(); |
6190
1db2486e45f4
potential fix for issue #217 (SigSegV while in game room in KillAllTeams - team list change?)
sheepluva
parents:
6180
diff
changeset
|
770 |
} |
1db2486e45f4
potential fix for issue #217 (SigSegV while in game room in KillAllTeams - team list change?)
sheepluva
parents:
6180
diff
changeset
|
771 |
} |
1db2486e45f4
potential fix for issue #217 (SigSegV while in game room in KillAllTeams - team list change?)
sheepluva
parents:
6180
diff
changeset
|
772 |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
773 |
if (id == ID_PAGE_MULTIPLAYER || id == ID_PAGE_NETGAME) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
774 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
775 |
QStringList tmNames = config->GetTeamsList(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
776 |
TeamSelWidget* curTeamSelWidget; |
6024 | 777 |
ui.pageOptions->setTeamOptionsEnabled(false); |
2377 | 778 |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
779 |
if (id == ID_PAGE_MULTIPLAYER) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
780 |
{ |
5255
947025eeb5dc
under osx don't load a file in case a game is already running (also a little of code formatting)
koda
parents:
5252
diff
changeset
|
781 |
curTeamSelWidget = ui.pageMultiplayer->teamsSelect; |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
782 |
} |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
783 |
else |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
784 |
{ |
5255
947025eeb5dc
under osx don't load a file in case a game is already running (also a little of code formatting)
koda
parents:
5252
diff
changeset
|
785 |
curTeamSelWidget = ui.pageNetGame->pNetTeamsWidget; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
786 |
} |
2377 | 787 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
788 |
QList<HWTeam> teamsList; |
9393 | 789 |
for (QStringList::iterator it = tmNames.begin(); it != tmNames.end(); ++it) |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
790 |
{ |
5255
947025eeb5dc
under osx don't load a file in case a game is already running (also a little of code formatting)
koda
parents:
5252
diff
changeset
|
791 |
HWTeam team(*it); |
6015
daffc14a518a
cleaning up a little bit more, especially team class. we were leaking teams into heap memory on quick game starts btw
sheepluva
parents:
6009
diff
changeset
|
792 |
team.loadFromFile(); |
5255
947025eeb5dc
under osx don't load a file in case a game is already running (also a little of code formatting)
koda
parents:
5252
diff
changeset
|
793 |
teamsList.push_back(team); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
794 |
} |
2377 | 795 |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
796 |
if (lastid == ID_PAGE_SETUP || lastid == ID_PAGE_DRAWMAP) // _TEAM |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
797 |
{ |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
798 |
if (editedTeam) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
799 |
{ |
5255
947025eeb5dc
under osx don't load a file in case a game is already running (also a little of code formatting)
koda
parents:
5252
diff
changeset
|
800 |
curTeamSelWidget->addTeam(*editedTeam); |
947025eeb5dc
under osx don't load a file in case a game is already running (also a little of code formatting)
koda
parents:
5252
diff
changeset
|
801 |
} |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
802 |
} |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
803 |
else if (lastid != ID_PAGE_GAMESTATS |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
804 |
&& lastid != ID_PAGE_INGAME |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
805 |
&& lastid != ID_PAGE_SCHEME |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
806 |
&& lastid != ID_PAGE_SELECTWEAPON) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
807 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
808 |
curTeamSelWidget->resetPlayingTeams(teamsList); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
809 |
} |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
810 |
} |
2845 | 811 |
|
8901
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
812 |
if (id == ID_PAGE_GAMESTATS) |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
813 |
{ |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
814 |
switch(lastGameType) { |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
815 |
case gtLocal: |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
816 |
case gtQLocal: |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
817 |
case gtTraining: |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
818 |
case gtCampaign: |
15276
d111a0d9d499
Enable "replay" button after playing a demo or saved game
Wuzzy <Wuzzy2@mail.ru>
parents:
15193
diff
changeset
|
819 |
case gtDemo: |
d111a0d9d499
Enable "replay" button after playing a demo or saved game
Wuzzy <Wuzzy2@mail.ru>
parents:
15193
diff
changeset
|
820 |
case gtSave: |
8901
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
821 |
ui.pageGameStats->restartBtnVisible(true); |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
822 |
break; |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
823 |
default: |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
824 |
ui.pageGameStats->restartBtnVisible(false); |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
825 |
break; |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
826 |
} |
15278
16f389fcd462
Prevent saving of demo after /lua command was used
Wuzzy <Wuzzy2@mail.ru>
parents:
15276
diff
changeset
|
827 |
ui.pageGameStats->saveDemoBtnEnabled(demoIsPresent); |
8901
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
828 |
} |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
829 |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
830 |
if (id == ID_PAGE_MAIN) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
831 |
{ |
6024 | 832 |
ui.pageOptions->setTeamOptionsEnabled(true); |
3159 | 833 |
} |
311 | 834 |
} |
835 |
||
4509
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
836 |
void HWForm::GoToPage(int id) |
289 | 837 |
{ |
9393 | 838 |
//bool stopAnim = false; |
6428 | 839 |
|
4509
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
840 |
int lastid = ui.Pages->currentIndex(); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
841 |
PagesStack.push(ui.Pages->currentIndex()); |
6428 | 842 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
843 |
OnPageShown(id, lastid); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
844 |
ui.Pages->setCurrentIndex(id); |
6428 | 845 |
|
7004 | 846 |
|
847 |
/* if (id == ID_PAGE_DRAWMAP || id == ID_PAGE_GAMESTATS) |
|
6428 | 848 |
stopAnim = true; |
8098 | 849 |
This were disabled due to broken flake animations. I believe the more general problems w/ opacity that forced its disable makes blocking these |
850 |
unnecessary. |
|
7004 | 851 |
*/ |
6428 | 852 |
|
8384 | 853 |
|
6604
9cc612a24b43
this should lower compatibility with qt4.5 again, but i have no way to test it
koda
parents:
6574
diff
changeset
|
854 |
#if (QT_VERSION >= 0x040600) |
9393 | 855 |
//if (!stopAnim) |
6428 | 856 |
{ |
857 |
/**Start animation :**/ |
|
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
858 |
int coeff = 1; |
6630
f8bbfa9a1a36
Disable opacity across the board. It is screwed up in OSX and apparently also Linux. Bad artifacts and overall performance.
nemo
parents:
6616
diff
changeset
|
859 |
#ifdef false |
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
860 |
coeff = 2; |
6428 | 861 |
QGraphicsOpacityEffect *effectNew = new QGraphicsOpacityEffect(ui.Pages->widget(id)); |
862 |
ui.Pages->widget(id)->setGraphicsEffect(effectNew); |
|
863 |
||
864 |
QGraphicsOpacityEffect *effectLast = new QGraphicsOpacityEffect(ui.Pages->widget(lastid)); |
|
865 |
ui.Pages->widget(lastid)->setGraphicsEffect(effectLast); |
|
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
866 |
#endif |
6574 | 867 |
// no effects, means 0 effect duration :D |
868 |
int duration = config->isFrontendEffects() ? 500 : 0; |
|
6428 | 869 |
|
870 |
//New page animation |
|
871 |
animationNewSlide = new QPropertyAnimation(ui.Pages->widget(id), "pos"); |
|
6574 | 872 |
animationNewSlide->setDuration(duration); |
7004 | 873 |
animationNewSlide->setStartValue(QPoint(width()/coeff, 0)); |
6428 | 874 |
animationNewSlide->setEndValue(QPoint(0, 0)); |
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
875 |
animationNewSlide->setEasingCurve(QEasingCurve::OutExpo); |
6428 | 876 |
|
6630
f8bbfa9a1a36
Disable opacity across the board. It is screwed up in OSX and apparently also Linux. Bad artifacts and overall performance.
nemo
parents:
6616
diff
changeset
|
877 |
#ifdef false |
6428 | 878 |
animationNewOpacity = new QPropertyAnimation(effectNew, "opacity"); |
6574 | 879 |
animationNewOpacity->setDuration(duration); |
6428 | 880 |
animationNewOpacity->setStartValue(0.01); |
881 |
animationNewOpacity->setEndValue(1); |
|
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
882 |
animationNewOpacity->setEasingCurve(QEasingCurve::OutExpo); |
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
883 |
#endif |
6428 | 884 |
|
885 |
//Last page animation |
|
886 |
ui.Pages->widget(lastid)->setHidden(false); |
|
887 |
||
888 |
animationOldSlide = new QPropertyAnimation(ui.Pages->widget(lastid), "pos"); |
|
6574 | 889 |
animationOldSlide->setDuration(duration); |
6428 | 890 |
animationOldSlide->setStartValue(QPoint(0, 0)); |
7004 | 891 |
animationOldSlide->setEndValue(QPoint(-width()/coeff, 0)); |
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
892 |
animationOldSlide->setEasingCurve(QEasingCurve::OutExpo); |
6428 | 893 |
|
6630
f8bbfa9a1a36
Disable opacity across the board. It is screwed up in OSX and apparently also Linux. Bad artifacts and overall performance.
nemo
parents:
6616
diff
changeset
|
894 |
#ifdef false |
6428 | 895 |
animationOldOpacity = new QPropertyAnimation(effectLast, "opacity"); |
6574 | 896 |
animationOldOpacity->setDuration(duration); |
6428 | 897 |
animationOldOpacity->setStartValue(1); |
898 |
animationOldOpacity->setEndValue(0.01); |
|
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
899 |
animationOldOpacity->setEasingCurve(QEasingCurve::OutExpo); |
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
900 |
#endif |
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
901 |
|
7860
a90936219ffa
let animation objects delete themselves after they are not being used anymore
sheepluva
parents:
7842
diff
changeset
|
902 |
// let's hide the old slide after its animation has finished |
a90936219ffa
let animation objects delete themselves after they are not being used anymore
sheepluva
parents:
7842
diff
changeset
|
903 |
connect(animationOldSlide, SIGNAL(finished()), ui.Pages->widget(lastid), SLOT(hide())); |
7826
9f529722d61e
fix for the root cause of issue 434 (previous pages being visible in the background)
sheepluva
parents:
7824
diff
changeset
|
904 |
|
7860
a90936219ffa
let animation objects delete themselves after they are not being used anymore
sheepluva
parents:
7842
diff
changeset
|
905 |
// start animations |
a90936219ffa
let animation objects delete themselves after they are not being used anymore
sheepluva
parents:
7842
diff
changeset
|
906 |
animationOldSlide->start(QAbstractAnimation::DeleteWhenStopped); |
a90936219ffa
let animation objects delete themselves after they are not being used anymore
sheepluva
parents:
7842
diff
changeset
|
907 |
animationNewSlide->start(QAbstractAnimation::DeleteWhenStopped); |
6428 | 908 |
|
8098 | 909 |
/* this is for the situation when the animation below is interrupted by a new animation. For some reason, finished is not being fired */ |
910 |
for(int i=0;i<MAX_PAGE;i++) if (i!=id && i!=lastid) ui.Pages->widget(i)->hide(); |
|
6428 | 911 |
} |
6604
9cc612a24b43
this should lower compatibility with qt4.5 again, but i have no way to test it
koda
parents:
6574
diff
changeset
|
912 |
#endif |
289 | 913 |
} |
914 |
||
915 |
void HWForm::GoBack() |
|
916 |
{ |
|
6428 | 917 |
bool stopAnim = false; |
6042
8b5345758f62
some more cleanups/refactoring/blahblah, some button positions may are a bit off atm. also I added a new picture for one of the buttons
sheepluva
parents:
6036
diff
changeset
|
918 |
int curid = ui.Pages->currentIndex(); |
8b5345758f62
some more cleanups/refactoring/blahblah, some button positions may are a bit off atm. also I added a new picture for one of the buttons
sheepluva
parents:
6036
diff
changeset
|
919 |
if (curid == ID_PAGE_MAIN) |
6428 | 920 |
{ |
8384 | 921 |
((AbstractPage*)ui.Pages->widget(ID_PAGE_MAIN))->triggerPageLeave(); |
7353
0e55228e1303
When there are videos that are being encoded and user tries to quit display dialog with warning.
Stepan777 <stepik-777@mail.ru>
parents:
7347
diff
changeset
|
922 |
if (!ui.pageVideos->tryQuit(this)) |
0e55228e1303
When there are videos that are being encoded and user tries to quit display dialog with warning.
Stepan777 <stepik-777@mail.ru>
parents:
7347
diff
changeset
|
923 |
return; |
6428 | 924 |
stopAnim = true; |
6042
8b5345758f62
some more cleanups/refactoring/blahblah, some button positions may are a bit off atm. also I added a new picture for one of the buttons
sheepluva
parents:
6036
diff
changeset
|
925 |
exit(); |
6428 | 926 |
} |
6042
8b5345758f62
some more cleanups/refactoring/blahblah, some button positions may are a bit off atm. also I added a new picture for one of the buttons
sheepluva
parents:
6036
diff
changeset
|
927 |
|
4509
816a0bff5019
Use QSignalMapper instead of GoToPage*() functions (not all calls converted yet)
unc0rr
parents:
4433
diff
changeset
|
928 |
int id = PagesStack.isEmpty() ? ID_PAGE_MAIN : PagesStack.pop(); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
929 |
ui.Pages->setCurrentIndex(id); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
930 |
OnPageShown(id, curid); |
2377 | 931 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
932 |
if (id == ID_PAGE_CONNECTING) |
6428 | 933 |
{ |
934 |
stopAnim = true; |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
935 |
GoBack(); |
6428 | 936 |
} |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
937 |
if (id == ID_PAGE_NETSERVER) |
6428 | 938 |
{ |
939 |
stopAnim = true; |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
940 |
GoBack(); |
6428 | 941 |
} |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
942 |
if ((!hwnet) && (id == ID_PAGE_ROOMSLIST)) |
6428 | 943 |
{ |
944 |
stopAnim = true; |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
945 |
GoBack(); |
6428 | 946 |
} |
7004 | 947 |
/*if (curid == ID_PAGE_DRAWMAP) |
948 |
stopAnim = true; */ |
|
2377 | 949 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
950 |
if ((!hwnet) || (!hwnet->isInRoom())) |
9393 | 951 |
if (id == ID_PAGE_NETGAME) |
6428 | 952 |
{ |
953 |
stopAnim = true; |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
954 |
GoBack(); |
6428 | 955 |
} |
1672
6a451649558c
Properly handle room deletion in respect of pages switching
unc0rr
parents:
1671
diff
changeset
|
956 |
|
14470
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
957 |
if (curid == ID_PAGE_CAMPAIGN) |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
958 |
config->setValue("frontend/lastSingleplayerTeam", ui.pageCampaign->CBTeam->currentText()); |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
959 |
if (curid == ID_PAGE_TRAINING) |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
960 |
config->setValue("frontend/lastSingleplayerTeam", ui.pageTraining->CBTeam->currentText()); |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
961 |
|
5147 | 962 |
if (curid == ID_PAGE_ROOMSLIST || curid == ID_PAGE_CONNECTING) NetDisconnect(); |
6030
2577028cba07
fix typo that sneaked in by pressing ctrl+z one time too much I guess :D
sheepluva
parents:
6026
diff
changeset
|
963 |
if (curid == ID_PAGE_NETGAME && hwnet && hwnet->isInRoom()) hwnet->partRoom(); |
4432 | 964 |
// need to work on this, can cause invalid state for admin quit trying to prevent bad state message on kick |
965 |
//if (curid == ID_PAGE_NETGAME && (!game || game->gameState != gsStarted)) hwnet->partRoom(); |
|
1902
aeadb10c2d77
Add delete button and scheme selection combobox to scheme edit page
unc0rr
parents:
1899
diff
changeset
|
966 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
967 |
if (curid == ID_PAGE_SCHEME) |
13197
0bc5f618ca7c
Rename the misleadingly-named AmmoSchemeModel to GameSchemeModel
Wuzzy <Wuzzy2@mail.ru>
parents:
13086
diff
changeset
|
968 |
gameSchemeModel->Save(); |
6428 | 969 |
|
6604
9cc612a24b43
this should lower compatibility with qt4.5 again, but i have no way to test it
koda
parents:
6574
diff
changeset
|
970 |
#if (QT_VERSION >= 0x040600) |
6428 | 971 |
/**Start animation :**/ |
6574 | 972 |
if (curid != 0 && !stopAnim) |
6428 | 973 |
{ |
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
974 |
int coeff = 1; |
6630
f8bbfa9a1a36
Disable opacity across the board. It is screwed up in OSX and apparently also Linux. Bad artifacts and overall performance.
nemo
parents:
6616
diff
changeset
|
975 |
#ifdef false |
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
976 |
coeff = 2; |
6428 | 977 |
QGraphicsOpacityEffect *effectNew = new QGraphicsOpacityEffect(ui.Pages->widget(id)); |
978 |
effectNew->setOpacity(1); |
|
979 |
ui.Pages->widget(id)->setGraphicsEffect(effectNew); |
|
980 |
||
981 |
QGraphicsOpacityEffect *effectLast = new QGraphicsOpacityEffect(ui.Pages->widget(curid)); |
|
982 |
ui.Pages->widget(curid)->setGraphicsEffect(effectLast); |
|
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
983 |
#endif |
6574 | 984 |
// no effects, means 0 effect duration :D |
985 |
int duration = config->isFrontendEffects() ? 500 : 0; |
|
6428 | 986 |
|
987 |
//Last page animation |
|
988 |
animationOldSlide = new QPropertyAnimation(ui.Pages->widget(id), "pos"); |
|
6574 | 989 |
animationOldSlide->setDuration(duration); |
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
990 |
animationOldSlide->setStartValue(QPoint(-width()/coeff, 0)); |
6428 | 991 |
animationOldSlide->setEndValue(QPoint(0, 0)); |
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
992 |
animationOldSlide->setEasingCurve(QEasingCurve::OutExpo); |
6428 | 993 |
|
6630
f8bbfa9a1a36
Disable opacity across the board. It is screwed up in OSX and apparently also Linux. Bad artifacts and overall performance.
nemo
parents:
6616
diff
changeset
|
994 |
#ifdef false |
6428 | 995 |
animationOldOpacity = new QPropertyAnimation(effectLast, "opacity"); |
6574 | 996 |
animationOldOpacity->setDuration(duration); |
6428 | 997 |
animationOldOpacity->setStartValue(1); |
998 |
animationOldOpacity->setEndValue(0.01); |
|
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
999 |
animationOldOpacity->setEasingCurve(QEasingCurve::OutExpo); |
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
1000 |
#endif |
6428 | 1001 |
//New page animation |
1002 |
ui.Pages->widget(curid)->setHidden(false); |
|
1003 |
||
1004 |
animationNewSlide = new QPropertyAnimation(ui.Pages->widget(curid), "pos"); |
|
6574 | 1005 |
animationNewSlide->setDuration(duration); |
6428 | 1006 |
animationNewSlide->setStartValue(QPoint(0, 0)); |
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
1007 |
animationNewSlide->setEndValue(QPoint(width()/coeff, 0)); |
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
1008 |
animationNewSlide->setEasingCurve(QEasingCurve::OutExpo); |
6428 | 1009 |
|
6630
f8bbfa9a1a36
Disable opacity across the board. It is screwed up in OSX and apparently also Linux. Bad artifacts and overall performance.
nemo
parents:
6616
diff
changeset
|
1010 |
#ifdef false |
6428 | 1011 |
animationNewOpacity = new QPropertyAnimation(effectNew, "opacity"); |
6574 | 1012 |
animationNewOpacity->setDuration(duration); |
6428 | 1013 |
animationNewOpacity->setStartValue(0.01); |
1014 |
animationNewOpacity->setEndValue(1); |
|
6440
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
1015 |
animationNewOpacity->setEasingCurve(QEasingCurve::OutExpo); |
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
1016 |
#endif |
1fa9dc94c93f
disable opacity effect for non-linux as it is working only there, fix a glitch that would print the page for a frame and then animate it from another position, change the animation curve to something a little more speedy
koda
parents:
6428
diff
changeset
|
1017 |
|
7860
a90936219ffa
let animation objects delete themselves after they are not being used anymore
sheepluva
parents:
7842
diff
changeset
|
1018 |
// let's hide the old slide after its animation has finished |
a90936219ffa
let animation objects delete themselves after they are not being used anymore
sheepluva
parents:
7842
diff
changeset
|
1019 |
connect(animationNewSlide, SIGNAL(finished()), ui.Pages->widget(curid), SLOT(hide())); |
6428 | 1020 |
|
7860
a90936219ffa
let animation objects delete themselves after they are not being used anymore
sheepluva
parents:
7842
diff
changeset
|
1021 |
// start animations |
a90936219ffa
let animation objects delete themselves after they are not being used anymore
sheepluva
parents:
7842
diff
changeset
|
1022 |
animationOldSlide->start(QAbstractAnimation::DeleteWhenStopped); |
a90936219ffa
let animation objects delete themselves after they are not being used anymore
sheepluva
parents:
7842
diff
changeset
|
1023 |
animationNewSlide->start(QAbstractAnimation::DeleteWhenStopped); |
6428 | 1024 |
} |
6604
9cc612a24b43
this should lower compatibility with qt4.5 again, but i have no way to test it
koda
parents:
6574
diff
changeset
|
1025 |
#endif |
7826
9f529722d61e
fix for the root cause of issue 434 (previous pages being visible in the background)
sheepluva
parents:
7824
diff
changeset
|
1026 |
|
9f529722d61e
fix for the root cause of issue 434 (previous pages being visible in the background)
sheepluva
parents:
7824
diff
changeset
|
1027 |
if (stopAnim) |
9f529722d61e
fix for the root cause of issue 434 (previous pages being visible in the background)
sheepluva
parents:
7824
diff
changeset
|
1028 |
ui.Pages->widget(curid)->hide(); |
9f529722d61e
fix for the root cause of issue 434 (previous pages being visible in the background)
sheepluva
parents:
7824
diff
changeset
|
1029 |
|
9f529722d61e
fix for the root cause of issue 434 (previous pages being visible in the background)
sheepluva
parents:
7824
diff
changeset
|
1030 |
// TODO the whole pages shown and effects stuff should be moved |
9f529722d61e
fix for the root cause of issue 434 (previous pages being visible in the background)
sheepluva
parents:
7824
diff
changeset
|
1031 |
// out of hwform.cpp and into a subclass of QStackedLayout |
9f529722d61e
fix for the root cause of issue 434 (previous pages being visible in the background)
sheepluva
parents:
7824
diff
changeset
|
1032 |
|
184 | 1033 |
} |
1034 |
||
5651
a7de68f4f87f
allow accessing the snapshot folder from the about page in the frontend (button could use a nicer icon)
koda
parents:
5567
diff
changeset
|
1035 |
void HWForm::OpenSnapshotFolder() |
a7de68f4f87f
allow accessing the snapshot folder from the about page in the frontend (button could use a nicer icon)
koda
parents:
5567
diff
changeset
|
1036 |
{ |
a7de68f4f87f
allow accessing the snapshot folder from the about page in the frontend (button could use a nicer icon)
koda
parents:
5567
diff
changeset
|
1037 |
QString path = QDir::toNativeSeparators(cfgdir->absolutePath() + "/Screenshots"); |
a7de68f4f87f
allow accessing the snapshot folder from the about page in the frontend (button could use a nicer icon)
koda
parents:
5567
diff
changeset
|
1038 |
QDesktopServices::openUrl(QUrl("file:///" + path)); |
a7de68f4f87f
allow accessing the snapshot folder from the about page in the frontend (button could use a nicer icon)
koda
parents:
5567
diff
changeset
|
1039 |
} |
a7de68f4f87f
allow accessing the snapshot folder from the about page in the frontend (button could use a nicer icon)
koda
parents:
5567
diff
changeset
|
1040 |
|
530 | 1041 |
void HWForm::btnExitPressed() |
1042 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1043 |
eggTimer.start(); |
530 | 1044 |
} |
1045 |
||
6042
8b5345758f62
some more cleanups/refactoring/blahblah, some button positions may are a bit off atm. also I added a new picture for one of the buttons
sheepluva
parents:
6036
diff
changeset
|
1046 |
void HWForm::exit() |
530 | 1047 |
{ |
6042
8b5345758f62
some more cleanups/refactoring/blahblah, some button positions may are a bit off atm. also I added a new picture for one of the buttons
sheepluva
parents:
6036
diff
changeset
|
1048 |
// if (eggTimer.elapsed() < 3000){ |
2400
2422ea85d100
added a utility that warns the user to install hedgewars when it's run from the diskimage
koda
parents:
2399
diff
changeset
|
1049 |
#ifdef __APPLE__ |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1050 |
panel->showInstallController(); |
2400
2422ea85d100
added a utility that warns the user to install hedgewars when it's run from the diskimage
koda
parents:
2399
diff
changeset
|
1051 |
#endif |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1052 |
close(); |
6042
8b5345758f62
some more cleanups/refactoring/blahblah, some button positions may are a bit off atm. also I added a new picture for one of the buttons
sheepluva
parents:
6036
diff
changeset
|
1053 |
// TODO reactivate egg |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1054 |
/* } |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1055 |
else |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1056 |
{ |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1057 |
QPushButton * btn = findChild<QPushButton *>("imageButt"); |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1058 |
if (btn) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1059 |
{ |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1060 |
btn->setIcon(QIcon(":/res/bonus.png")); |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1061 |
} |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1062 |
} */ |
530 | 1063 |
} |
1064 |
||
535
a14eaf35cf4b
"Setup" button instead of "New team", exclude playing teams from setup
displacer
parents:
533
diff
changeset
|
1065 |
void HWForm::IntermediateSetup() |
a14eaf35cf4b
"Setup" button instead of "New team", exclude playing teams from setup
displacer
parents:
533
diff
changeset
|
1066 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1067 |
quint8 id=ui.Pages->currentIndex(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1068 |
TeamSelWidget* curTeamSelWidget; |
2377 | 1069 |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1070 |
if(id == ID_PAGE_MULTIPLAYER) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1071 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1072 |
curTeamSelWidget = ui.pageMultiplayer->teamsSelect; |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1073 |
} |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1074 |
else |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1075 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1076 |
curTeamSelWidget = ui.pageNetGame->pNetTeamsWidget; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1077 |
} |
2377 | 1078 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1079 |
QStringList tmnames; |
5772
c09c50efe8b5
Replace iterators with simple declarative foreach (not tested if it works)
unc0rr
parents:
5763
diff
changeset
|
1080 |
|
5773 | 1081 |
foreach(HWTeam team, curTeamSelWidget->getNotPlayingTeams()) |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1082 |
tmnames += team.name(); |
5140
932307228d05
Change a few iterations over list to what is apparently a modification safe syntax, may fix issue #208 and #217 - needs testing of course.
nemo
parents:
5126
diff
changeset
|
1083 |
|
3757 | 1084 |
//UpdateTeamsLists(&tmnames); // FIXME: still need more work if teamname is updated while configuring |
1085 |
UpdateTeamsLists(); |
|
535
a14eaf35cf4b
"Setup" button instead of "New team", exclude playing teams from setup
displacer
parents:
533
diff
changeset
|
1086 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1087 |
GoToPage(ID_PAGE_SETUP); |
535
a14eaf35cf4b
"Setup" button instead of "New team", exclude playing teams from setup
displacer
parents:
533
diff
changeset
|
1088 |
} |
a14eaf35cf4b
"Setup" button instead of "New team", exclude playing teams from setup
displacer
parents:
533
diff
changeset
|
1089 |
|
184 | 1090 |
void HWForm::NewTeam() |
1091 |
{ |
|
12667
2e0a38566178
Make sure new teams start with an unique name
Wuzzy <almikes@aol.com>
parents:
12665
diff
changeset
|
1092 |
QString teamName = QLineEdit::tr("unnamed"); |
2e0a38566178
Make sure new teams start with an unique name
Wuzzy <almikes@aol.com>
parents:
12665
diff
changeset
|
1093 |
QStringList teamslist = config->GetTeamsList(); |
2e0a38566178
Make sure new teams start with an unique name
Wuzzy <almikes@aol.com>
parents:
12665
diff
changeset
|
1094 |
if(teamslist.contains(teamName)) |
2e0a38566178
Make sure new teams start with an unique name
Wuzzy <almikes@aol.com>
parents:
12665
diff
changeset
|
1095 |
{ |
2e0a38566178
Make sure new teams start with an unique name
Wuzzy <almikes@aol.com>
parents:
12665
diff
changeset
|
1096 |
//name already used -> look for an appropriate name: |
2e0a38566178
Make sure new teams start with an unique name
Wuzzy <almikes@aol.com>
parents:
12665
diff
changeset
|
1097 |
int i=2; |
2e0a38566178
Make sure new teams start with an unique name
Wuzzy <almikes@aol.com>
parents:
12665
diff
changeset
|
1098 |
while(teamslist.contains(teamName = QLineEdit::tr("unnamed (%1)").arg(i++))); |
2e0a38566178
Make sure new teams start with an unique name
Wuzzy <almikes@aol.com>
parents:
12665
diff
changeset
|
1099 |
} |
2e0a38566178
Make sure new teams start with an unique name
Wuzzy <almikes@aol.com>
parents:
12665
diff
changeset
|
1100 |
|
2e0a38566178
Make sure new teams start with an unique name
Wuzzy <almikes@aol.com>
parents:
12665
diff
changeset
|
1101 |
ui.pageEditTeam->createTeam(teamName, playerHash); |
6024 | 1102 |
UpdateTeamsLists(); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1103 |
GoToPage(ID_PAGE_SETUP_TEAM); |
184 | 1104 |
} |
1105 |
||
6024 | 1106 |
void HWForm::EditTeam(const QString & teamName) |
3159 | 1107 |
{ |
6024 | 1108 |
ui.pageEditTeam->editTeam(teamName, playerHash); |
1109 |
GoToPage(ID_PAGE_SETUP_TEAM); |
|
3159 | 1110 |
} |
1111 |
||
6024 | 1112 |
void HWForm::AfterTeamEdit() |
1840 | 1113 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1114 |
UpdateTeamsLists(); |
7551 | 1115 |
//GoBack(); |
184 | 1116 |
} |
1117 |
||
6024 | 1118 |
|
1119 |
void HWForm::DeleteTeam(const QString & teamName) |
|
184 | 1120 |
{ |
8346 | 1121 |
ui.pageEditTeam->deleteTeam(teamName); |
1122 |
UpdateTeamsLists(); |
|
184 | 1123 |
} |
1124 |
||
4416
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1125 |
void HWForm::DeleteScheme() |
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1126 |
{ |
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1127 |
ui.pageScheme->selectScheme->setCurrentIndex(ui.pageOptions->SchemesName->currentIndex()); |
13197
0bc5f618ca7c
Rename the misleadingly-named AmmoSchemeModel to GameSchemeModel
Wuzzy <Wuzzy2@mail.ru>
parents:
13086
diff
changeset
|
1128 |
if (ui.pageOptions->SchemesName->currentIndex() < gameSchemeModel->numberOfDefaultSchemes) |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1129 |
{ |
8383 | 1130 |
MessageDialog::ShowErrorMessage(QMessageBox::tr("Cannot delete default scheme '%1'!").arg(ui.pageOptions->SchemesName->currentText()), this); |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1131 |
} |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1132 |
else |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1133 |
{ |
4416
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1134 |
ui.pageScheme->deleteRow(); |
13197
0bc5f618ca7c
Rename the misleadingly-named AmmoSchemeModel to GameSchemeModel
Wuzzy <Wuzzy2@mail.ru>
parents:
13086
diff
changeset
|
1135 |
gameSchemeModel->Save(); |
4416
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1136 |
} |
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1137 |
} |
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1138 |
|
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1139 |
void HWForm::DeleteWeaponSet() |
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1140 |
{ |
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1141 |
ui.pageSelectWeapon->selectWeaponSet->setCurrentIndex(ui.pageOptions->WeaponsName->currentIndex()); |
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1142 |
ui.pageSelectWeapon->pWeapons->deleteWeaponsName(); |
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1143 |
} |
29d2d1548387
adding a combobox to weapon editor as scheme editor, added a few notices for deleting and some buttons in this area.
Henek
parents:
4410
diff
changeset
|
1144 |
|
184 | 1145 |
void HWForm::SimpleGame() |
1146 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1147 |
CreateGame(0, 0, *cDefaultAmmoStore); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1148 |
game->StartQuick(); |
184 | 1149 |
} |
1150 |
||
1151 |
void HWForm::PlayDemo() |
|
1152 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1153 |
QListWidgetItem * curritem = ui.pagePlayDemo->DemosList->currentItem(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1154 |
if (!curritem) |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1155 |
{ |
8383 | 1156 |
MessageDialog::ShowErrorMessage(QMessageBox::tr("Please select a record from the list"), this); |
5252 | 1157 |
return; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1158 |
} |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1159 |
CreateGame(0, 0, 0); |
5865 | 1160 |
game->PlayDemo(curritem->data(Qt::UserRole).toString(), ui.pagePlayDemo->isSave()); |
184 | 1161 |
} |
1162 |
||
5252 | 1163 |
void HWForm::PlayDemoQuick(const QString & demofilename) |
1164 |
{ |
|
5255
947025eeb5dc
under osx don't load a file in case a game is already running (also a little of code formatting)
koda
parents:
5252
diff
changeset
|
1165 |
GoToPage(ID_PAGE_MAIN); |
8709
191bd86f97a1
fix loading files on osx too, the cause was different than other systems
koda
parents:
8643
diff
changeset
|
1166 |
//GoBack() <- don't or you'll close the socket |
5252 | 1167 |
CreateGame(0, 0, 0); |
5865 | 1168 |
game->PlayDemo(demofilename, false); |
5252 | 1169 |
} |
1170 |
||
8716
e09633d10f16
hit hwplay://server:port and automatically join an unofficial server (on osx right now)
koda
parents:
8709
diff
changeset
|
1171 |
void HWForm::NetConnectQuick(const QString & host, quint16 port) |
e09633d10f16
hit hwplay://server:port and automatically join an unofficial server (on osx right now)
koda
parents:
8709
diff
changeset
|
1172 |
{ |
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1173 |
GoToPage(ID_PAGE_MAIN); |
14865 | 1174 |
NetConnectServer(host, port, false); |
8716
e09633d10f16
hit hwplay://server:port and automatically join an unofficial server (on osx right now)
koda
parents:
8709
diff
changeset
|
1175 |
} |
e09633d10f16
hit hwplay://server:port and automatically join an unofficial server (on osx right now)
koda
parents:
8709
diff
changeset
|
1176 |
|
14865 | 1177 |
void HWForm::NetConnectServer(const QString & host, quint16 port, bool useTls) |
416 | 1178 |
{ |
8716
e09633d10f16
hit hwplay://server:port and automatically join an unofficial server (on osx right now)
koda
parents:
8709
diff
changeset
|
1179 |
qDebug("connecting to %s:%d", qPrintable(host), port); |
14865 | 1180 |
_NetConnect(host, port, useTls, ui.pageOptions->editNetNick->text().trimmed()); |
1395 | 1181 |
} |
1182 |
||
1183 |
void HWForm::NetConnectOfficialServer() |
|
1184 |
{ |
|
14865 | 1185 |
NetConnectServer(NETGAME_DEFAULT_SERVER, NETGAME_DEFAULT_PORT, false); |
416 | 1186 |
} |
1187 |
||
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1188 |
void HWForm::NetPassword(const QString & nick) |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1189 |
{ |
8385
9e8924ff9813
Convert feedback page to dialog (+some fixes from unC0Rr)
dag10
parents:
8384
diff
changeset
|
1190 |
Q_UNUSED(nick); |
8181 | 1191 |
//Get hashes |
8294
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1192 |
QString hash = config->passwordHash(); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1193 |
QString temphash = config->tempHash(); |
8181 | 1194 |
|
1195 |
//Check them |
|
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1196 |
|
8181 | 1197 |
if (temphash.isEmpty() && hash.isEmpty()) { //If the user enters a registered nick with no password, sends a bogus hash |
1198 |
hwnet->SendPasswordHash("THISISNOHASH"); |
|
1199 |
} |
|
1200 |
else if (temphash.isEmpty()) { //Send saved hash as default |
|
1201 |
hwnet->SendPasswordHash(hash); |
|
1202 |
} |
|
1203 |
else { //Send the hash |
|
1204 |
hwnet->SendPasswordHash(temphash); |
|
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1205 |
} |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1206 |
|
8181 | 1207 |
//Remove temporary hash from config |
8295
6ef114ea2298
fixed minor problem with saving hash
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8294
diff
changeset
|
1208 |
config->clearTempHash(); |
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1209 |
} |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1210 |
|
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1211 |
void HWForm::NetNickRegistered(const QString & nick) |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1212 |
{ |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1213 |
//Get hashes |
8294
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1214 |
QString hash = config->passwordHash(); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1215 |
QString temphash = config->tempHash(); |
8295
6ef114ea2298
fixed minor problem with saving hash
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8294
diff
changeset
|
1216 |
|
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1217 |
if (hash.isEmpty()) { |
8294
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1218 |
if (temphash.isEmpty()) { //If the user enters a registered nick with no password |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1219 |
QString suppliedpass; |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1220 |
while (suppliedpass.isEmpty()) { |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1221 |
QInputDialog nickRegedDialog(this); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1222 |
nickRegedDialog.setWindowModality(Qt::WindowModal); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1223 |
nickRegedDialog.setInputMode(QInputDialog::TextInput); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1224 |
nickRegedDialog.setWindowTitle(tr("Hedgewars - Nick registered")); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1225 |
nickRegedDialog.setLabelText(tr("This nick is registered, and you haven't specified a password.\n\nIf this nick isn't yours, please register your own nick at www.hedgewars.org\n\nPassword:")); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1226 |
nickRegedDialog.setTextEchoMode(QLineEdit::Password); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1227 |
nickRegedDialog.exec(); |
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1228 |
|
8294
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1229 |
suppliedpass = nickRegedDialog.textValue(); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1230 |
|
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1231 |
if (nickRegedDialog.result() == QDialog::Rejected) { |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1232 |
config->clearPasswordHash(); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1233 |
config->clearTempHash(); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1234 |
GoBack(); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1235 |
return; |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1236 |
} |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1237 |
temphash = QCryptographicHash::hash(suppliedpass.toUtf8(), QCryptographicHash::Md5).toHex(); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1238 |
config->setTempHash(temphash); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1239 |
} |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1240 |
} |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1241 |
} |
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1242 |
NetPassword(nick); |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1243 |
} |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1244 |
|
8299
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1245 |
void HWForm::NetNickNotRegistered(const QString & nick) |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1246 |
{ |
8385
9e8924ff9813
Convert feedback page to dialog (+some fixes from unC0Rr)
dag10
parents:
8384
diff
changeset
|
1247 |
Q_UNUSED(nick); |
9e8924ff9813
Convert feedback page to dialog (+some fixes from unC0Rr)
dag10
parents:
8384
diff
changeset
|
1248 |
|
8299
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1249 |
QMessageBox noRegMsg(this); |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1250 |
noRegMsg.setIcon(QMessageBox::Information); |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1251 |
noRegMsg.setWindowTitle(QMessageBox::tr("Hedgewars - Nick not registered")); |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1252 |
noRegMsg.setWindowModality(Qt::WindowModal); |
15457
751b992656ab
Mention rejoining in message to unregistered players
Wuzzy <Wuzzy2@mail.ru>
parents:
15300
diff
changeset
|
1253 |
noRegMsg.setText(tr("Your nickname is not registered.\nTo be able to rejoin games in progress and\nprevent someone else from using your nickname,\nplease register it at www.hedgewars.org.")); |
8299
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1254 |
|
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1255 |
if (!config->passwordHash().isEmpty()) |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1256 |
{ |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1257 |
config->clearPasswordHash(); |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1258 |
noRegMsg.setText(noRegMsg.text()+tr("\n\nYour password wasn't saved either.")); |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1259 |
} |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1260 |
if (!config->tempHash().isEmpty()) |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1261 |
{ |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1262 |
config->clearTempHash(); |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1263 |
} |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1264 |
noRegMsg.exec(); |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1265 |
} |
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1266 |
|
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1267 |
void HWForm::NetNickTaken(const QString & nick) |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1268 |
{ |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1269 |
bool ok = false; |
7795
ba32d3f9e567
set window modality also for custom dialogs, small text changes
koda
parents:
7794
diff
changeset
|
1270 |
QString newNick = QInputDialog::getText(this, tr("Nickname"), tr("Someone already uses your nickname %1 on the server.\nPlease pick another nickname:").arg(nick), QLineEdit::Normal, nick, &ok); |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1271 |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1272 |
if (!ok || newNick.isEmpty()) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1273 |
{ |
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1274 |
//ForcedDisconnect(tr("No nickname supplied.")); |
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1275 |
bool retry = RetryDialog(tr("Hedgewars - Empty nickname"), tr("No nickname supplied.")); |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1276 |
GoBack(); |
9549 | 1277 |
if (retry && hwnet) { |
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1278 |
if (hwnet->m_private_game) { |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1279 |
QStringList list = hwnet->getHost().split(":"); |
14865 | 1280 |
NetConnectServer(list.at(0), list.at(1).toShort(), false); |
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1281 |
} else |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1282 |
NetConnectOfficialServer(); |
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1283 |
} |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1284 |
return; |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1285 |
} |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1286 |
|
9549 | 1287 |
if(hwnet) |
1288 |
hwnet->NewNick(newNick); |
|
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1289 |
config->setValue("net/nick", newNick); |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1290 |
config->updNetNick(); |
6227
ce60b734fff1
update name autocompletion after nick change (since own nick isn't suggested)
sheepluva
parents:
6225
diff
changeset
|
1291 |
|
ce60b734fff1
update name autocompletion after nick change (since own nick isn't suggested)
sheepluva
parents:
6225
diff
changeset
|
1292 |
ui.pageRoomsList->setUser(nick); |
ce60b734fff1
update name autocompletion after nick change (since own nick isn't suggested)
sheepluva
parents:
6225
diff
changeset
|
1293 |
ui.pageNetGame->setUser(nick); |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1294 |
} |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1295 |
|
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1296 |
void HWForm::NetAuthFailed() |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1297 |
{ |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1298 |
// Set the password blank if case the user tries to join and enter his password again |
8294
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1299 |
config->clearTempHash(); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1300 |
|
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1301 |
//Try to login again |
8296
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1302 |
bool retry = RetryDialog(tr("Hedgewars - Wrong password"), tr("You entered a wrong password.")); |
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1303 |
GoBack(); |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1304 |
|
8297
b236e3afed0d
Reverted password loading in PAGE_SETUP, changed the value of passwordlength to save, added clearing of hashes after a 'Wrong password' RetryDialog
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8296
diff
changeset
|
1305 |
config->clearPasswordHash(); |
b236e3afed0d
Reverted password loading in PAGE_SETUP, changed the value of passwordlength to save, added clearing of hashes after a 'Wrong password' RetryDialog
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8296
diff
changeset
|
1306 |
config->clearTempHash(); |
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1307 |
if (retry) { |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1308 |
NetConnectOfficialServer(); |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1309 |
} |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1310 |
} |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1311 |
|
9549 | 1312 |
void HWForm::askRoomPassword() |
1313 |
{ |
|
1314 |
QString password = QInputDialog::getText(this, tr("Room password"), tr("The room is protected with password.\nPlease, enter the password:")); |
|
1315 |
if(hwnet && !password.isEmpty()) |
|
1316 |
hwnet->roomPasswordEntered(password); |
|
1317 |
} |
|
1318 |
||
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1319 |
bool HWForm::RetryDialog(const QString & title, const QString & label) |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1320 |
{ |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1321 |
QMessageBox retryMsg(this); |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1322 |
retryMsg.setIcon(QMessageBox::Warning); |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1323 |
retryMsg.setWindowTitle(title); |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1324 |
retryMsg.setText(label); |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1325 |
retryMsg.setWindowModality(Qt::WindowModal); |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1326 |
|
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1327 |
retryMsg.addButton(QMessageBox::Cancel); |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1328 |
|
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1329 |
QPushButton *retryButton = retryMsg.addButton(QMessageBox::Ok); |
8296
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1330 |
retryButton->setText(tr("Try Again")); |
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1331 |
retryButton->setFocus(); |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1332 |
|
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1333 |
retryMsg.exec(); |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1334 |
|
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1335 |
if (retryMsg.clickedButton() == retryButton) { |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1336 |
return true; |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1337 |
} |
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1338 |
return false; |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1339 |
} |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1340 |
|
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1341 |
void HWForm::NetTeamAccepted(const QString & team) |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1342 |
{ |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1343 |
ui.pageNetGame->pNetTeamsWidget->changeTeamStatus(team); |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1344 |
} |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1345 |
|
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1346 |
void HWForm::NetError(const QString & errmsg) |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1347 |
{ |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1348 |
switch (ui.Pages->currentIndex()) |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1349 |
{ |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1350 |
case ID_PAGE_INGAME: |
8383 | 1351 |
MessageDialog::ShowErrorMessage(errmsg, this); |
12725
1a393a59a594
Fix GCC warnings: -Wimplicit-fallthrough and -Wint-in-bool-context
Wuzzy <Wuzzy2@mail.ru>
parents:
12674
diff
changeset
|
1352 |
/* fallthrough */ |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1353 |
case ID_PAGE_NETGAME: |
6180
0992fc5a4ad9
some changes to the css... display:none; works now (e.g. you can use it for user join/leave messages that are not your friends)
sheepluva
parents:
6167
diff
changeset
|
1354 |
ui.pageNetGame->displayError(errmsg); |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1355 |
break; |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1356 |
default: |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1357 |
ui.pageRoomsList->displayError(errmsg); |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1358 |
} |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1359 |
} |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1360 |
|
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1361 |
void HWForm::NetWarning(const QString & wrnmsg) |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1362 |
{ |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1363 |
if (ui.Pages->currentIndex() == ID_PAGE_NETGAME || ui.Pages->currentIndex() == ID_PAGE_INGAME) |
6180
0992fc5a4ad9
some changes to the css... display:none; works now (e.g. you can use it for user join/leave messages that are not your friends)
sheepluva
parents:
6167
diff
changeset
|
1364 |
ui.pageNetGame->displayWarning(wrnmsg); |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1365 |
else |
6180
0992fc5a4ad9
some changes to the css... display:none; works now (e.g. you can use it for user join/leave messages that are not your friends)
sheepluva
parents:
6167
diff
changeset
|
1366 |
ui.pageRoomsList->displayWarning(wrnmsg); |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1367 |
} |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1368 |
|
14865 | 1369 |
void HWForm::_NetConnect(const QString & hostName, quint16 port, bool useTls, QString nick) |
184 | 1370 |
{ |
8385
9e8924ff9813
Convert feedback page to dialog (+some fixes from unC0Rr)
dag10
parents:
8384
diff
changeset
|
1371 |
Q_UNUSED(nick); |
9e8924ff9813
Convert feedback page to dialog (+some fixes from unC0Rr)
dag10
parents:
8384
diff
changeset
|
1372 |
|
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1373 |
if (hwnet) { |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1374 |
// destroy old connection |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1375 |
hwnet->Disconnect(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1376 |
delete hwnet; |
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1377 |
hwnet = NULL; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1378 |
} |
2377 | 1379 |
|
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1380 |
hwnet = new HWNewNet(); |
637
8fa7ed5e13bd
Fix bad behavior when quickly click Connect button more than once
unc0rr
parents:
636
diff
changeset
|
1381 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1382 |
GoToPage(ID_PAGE_CONNECTING); |
1800 | 1383 |
|
8504
9ff55b527d1b
Ehm... probably this will improve situation with desyncs
unc0rr
parents:
8489
diff
changeset
|
1384 |
connect(hwnet, SIGNAL(AskForRunGame()), this, SLOT(CreateNetGame()), Qt::QueuedConnection); |
14903
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1385 |
connect(hwnet, SIGNAL(AskForOfficialServerDemo()), this, SLOT(PlayOfficialServerDemo()), Qt::QueuedConnection); |
14838 | 1386 |
connect(hwnet, SIGNAL(redirected(quint16)), this, SLOT(NetRedirected(quint16)), Qt::QueuedConnection); |
6697
4a04c02bc8c3
Use queued signal-slot connections with HWNet class
unc0rr
parents:
6677
diff
changeset
|
1387 |
connect(hwnet, SIGNAL(connected()), this, SLOT(NetConnected()), Qt::QueuedConnection); |
4a04c02bc8c3
Use queued signal-slot connections with HWNet class
unc0rr
parents:
6677
diff
changeset
|
1388 |
connect(hwnet, SIGNAL(Error(const QString&)), this, SLOT(NetError(const QString&)), Qt::QueuedConnection); |
4a04c02bc8c3
Use queued signal-slot connections with HWNet class
unc0rr
parents:
6677
diff
changeset
|
1389 |
connect(hwnet, SIGNAL(Warning(const QString&)), this, SLOT(NetWarning(const QString&)), Qt::QueuedConnection); |
4a04c02bc8c3
Use queued signal-slot connections with HWNet class
unc0rr
parents:
6677
diff
changeset
|
1390 |
connect(hwnet, SIGNAL(EnteredGame()), this, SLOT(NetGameEnter()), Qt::QueuedConnection); |
4a04c02bc8c3
Use queued signal-slot connections with HWNet class
unc0rr
parents:
6677
diff
changeset
|
1391 |
connect(hwnet, SIGNAL(LeftRoom(const QString&)), this, SLOT(NetLeftRoom(const QString&)), Qt::QueuedConnection); |
4a04c02bc8c3
Use queued signal-slot connections with HWNet class
unc0rr
parents:
6677
diff
changeset
|
1392 |
connect(hwnet, SIGNAL(AddNetTeam(const HWTeam&)), this, SLOT(AddNetTeam(const HWTeam&)), Qt::QueuedConnection); |
4a04c02bc8c3
Use queued signal-slot connections with HWNet class
unc0rr
parents:
6677
diff
changeset
|
1393 |
connect(hwnet, SIGNAL(RemoveNetTeam(const HWTeam&)), this, SLOT(RemoveNetTeam(const HWTeam&)), Qt::QueuedConnection); |
8534
92da587691c9
Workaround queued signals problem in netclient instead. Should fix everything.
unc0rr
parents:
8529
diff
changeset
|
1394 |
connect(hwnet, SIGNAL(TeamAccepted(const QString&)), this, SLOT(NetTeamAccepted(const QString&)), Qt::QueuedConnection); |
8291
e4a0d980d1e2
Patched login dialog bugs, added retry dialogs
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8287
diff
changeset
|
1395 |
connect(hwnet, SIGNAL(NickRegistered(const QString&)), this, SLOT(NetNickRegistered(const QString&)), Qt::QueuedConnection); |
8299
ef2e284255cd
Added handling of not registered nicks (no change-server side tho), clearPasswordHash() also now sets the savepassword setting to false
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8297
diff
changeset
|
1396 |
connect(hwnet, SIGNAL(NickNotRegistered(const QString&)), this, SLOT(NetNickNotRegistered(const QString&)), Qt::QueuedConnection); |
6697
4a04c02bc8c3
Use queued signal-slot connections with HWNet class
unc0rr
parents:
6677
diff
changeset
|
1397 |
connect(hwnet, SIGNAL(NickTaken(const QString&)), this, SLOT(NetNickTaken(const QString&)), Qt::QueuedConnection); |
4a04c02bc8c3
Use queued signal-slot connections with HWNet class
unc0rr
parents:
6677
diff
changeset
|
1398 |
connect(hwnet, SIGNAL(AuthFailed()), this, SLOT(NetAuthFailed()), Qt::QueuedConnection); |
4392
95e27e12d0e9
Fix koda's esc key binding so leaving rooms works correctly with it
nemo
parents:
4232
diff
changeset
|
1399 |
//connect(ui.pageNetGame->BtnBack, SIGNAL(clicked()), hwnet, SLOT(partRoom())); |
9549 | 1400 |
connect(hwnet, SIGNAL(askForRoomPassword()), this, SLOT(askRoomPassword()), Qt::QueuedConnection); |
329
4c3aad46baa5
Send game parameters by net... Currently it leads to infinite loop, flooding traffic with messages about changes
unc0rr
parents:
328
diff
changeset
|
1401 |
|
7723 | 1402 |
ui.pageRoomsList->chatWidget->setUsersModel(hwnet->lobbyPlayersModel()); |
8179
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
1403 |
ui.pageNetGame->chatWidget->setUsersModel(hwnet->roomPlayersModel()); |
7723 | 1404 |
|
1874 | 1405 |
// rooms list page stuff |
6735 | 1406 |
ui.pageRoomsList->setModel(hwnet->roomsListModel()); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1407 |
connect(hwnet, SIGNAL(adminAccess(bool)), |
6720
84261c3408a6
Make all signals from HWNet queued, this should fix issues with teams and chat widgets
unc0rr
parents:
6700
diff
changeset
|
1408 |
ui.pageRoomsList, SLOT(setAdmin(bool)), Qt::QueuedConnection); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1409 |
connect(hwnet, SIGNAL(adminAccess(bool)), |
6720
84261c3408a6
Make all signals from HWNet queued, this should fix issues with teams and chat widgets
unc0rr
parents:
6700
diff
changeset
|
1410 |
ui.pageRoomsList->chatWidget, SLOT(adminAccess(bool)), Qt::QueuedConnection); |
2377 | 1411 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1412 |
connect(hwnet, SIGNAL(serverMessage(const QString&)), |
6720
84261c3408a6
Make all signals from HWNet queued, this should fix issues with teams and chat widgets
unc0rr
parents:
6700
diff
changeset
|
1413 |
ui.pageRoomsList->chatWidget, SLOT(onServerMessage(const QString&)), Qt::QueuedConnection); |
1584
90f6a5abad17
Save much space for chat widget on lobby page by removing server message widget (now this messages goes to chat)
unc0rr
parents:
1577
diff
changeset
|
1414 |
|
9541
312bb4384f33
- Frontend finally learns how to create passworded room
unc0rr
parents:
9393
diff
changeset
|
1415 |
connect(ui.pageRoomsList, SIGNAL(askForCreateRoom(const QString &, const QString &)), |
312bb4384f33
- Frontend finally learns how to create passworded room
unc0rr
parents:
9393
diff
changeset
|
1416 |
hwnet, SLOT(CreateRoom(const QString&, const QString &))); |
9549 | 1417 |
connect(ui.pageRoomsList, SIGNAL(askForJoinRoom(const QString &, const QString &)), |
1418 |
hwnet, SLOT(JoinRoom(const QString&, const QString &))); |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1419 |
// connect(ui.pageRoomsList, SIGNAL(askForCreateRoom(const QString &)), |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1420 |
// this, SLOT(NetGameMaster())); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1421 |
// connect(ui.pageRoomsList, SIGNAL(askForJoinRoom(const QString &)), |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1422 |
// this, SLOT(NetGameSlave())); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1423 |
connect(ui.pageRoomsList, SIGNAL(askForRoomList()), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1424 |
hwnet, SLOT(askRoomsList())); |
1313
f4c54e9e1b8c
- Introduce a bit of state miachine in client code (should be more robust and verbosive now)
unc0rr
parents:
1312
diff
changeset
|
1425 |
|
2345
daf1785f2337
- Frontend: reorganize code controlling widgets state, fix problems getting room admin status
unc0rr
parents:
2261
diff
changeset
|
1426 |
// room status stuff |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1427 |
connect(hwnet, SIGNAL(roomMaster(bool)), |
8893
8f92e94d0b32
Don't set Default scheme/ammo when switching script if not room admin. Prevents game config desync.
unc0rr
parents:
8891
diff
changeset
|
1428 |
this, SLOT(NetGameChangeStatus(bool))); |
2345
daf1785f2337
- Frontend: reorganize code controlling widgets state, fix problems getting room admin status
unc0rr
parents:
2261
diff
changeset
|
1429 |
|
1874 | 1430 |
// net page stuff |
8489
25cb6f4a1d1b
Implements protocol message JOINING on frontend, so client in a room always displays correct room name, even when room name changes. Fixes issue 522.
dag10
parents:
8453
diff
changeset
|
1431 |
connect(hwnet, SIGNAL(roomNameUpdated(const QString &)), |
8534
92da587691c9
Workaround queued signals problem in netclient instead. Should fix everything.
unc0rr
parents:
8529
diff
changeset
|
1432 |
ui.pageNetGame, SLOT(setRoomName(const QString &)), Qt::QueuedConnection); |
8759 | 1433 |
connect(hwnet, SIGNAL(roomChatAction(const QString&, const QString&)), |
1434 |
ui.pageNetGame->chatWidget, SLOT(onChatAction(const QString&, const QString&)), Qt::QueuedConnection); |
|
1435 |
connect(hwnet, SIGNAL(roomChatMessage(const QString&, const QString&)), |
|
1436 |
ui.pageNetGame->chatWidget, SLOT(onChatMessage(const QString&, const QString&)), Qt::QueuedConnection); |
|
7720 | 1437 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1438 |
connect(hwnet, SIGNAL(roomMaster(bool)), |
8179
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
1439 |
ui.pageNetGame->chatWidget, SLOT(adminAccess(bool)), Qt::QueuedConnection); |
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
1440 |
connect(ui.pageNetGame->chatWidget, SIGNAL(chatLine(const QString&)), |
8765
688062f1db59
fix/hack so that (own) messages sent in frontend are also visible in the game chat
sheepluva
parents:
8762
diff
changeset
|
1441 |
hwnet, SLOT(chatLineToNetWithEcho(const QString&))); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1442 |
connect(ui.pageNetGame->BtnGo, SIGNAL(clicked()), hwnet, SLOT(ToggleReady())); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1443 |
connect(hwnet, SIGNAL(setMyReadyStatus(bool)), |
6720
84261c3408a6
Make all signals from HWNet queued, this should fix issues with teams and chat widgets
unc0rr
parents:
6700
diff
changeset
|
1444 |
ui.pageNetGame, SLOT(setReadyStatus(bool)), Qt::QueuedConnection); |
1577 | 1445 |
|
1874 | 1446 |
// chat widget actions |
8179
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
1447 |
connect(ui.pageNetGame->chatWidget, SIGNAL(kick(const QString&)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1448 |
hwnet, SLOT(kickPlayer(const QString&))); |
11865
047be82b6f67
fix for Bug 91 - Make DELEGATE action available in frontend
sheepluva
parents:
11863
diff
changeset
|
1449 |
connect(ui.pageNetGame->chatWidget, SIGNAL(delegate(const QString&)), |
047be82b6f67
fix for Bug 91 - Make DELEGATE action available in frontend
sheepluva
parents:
11863
diff
changeset
|
1450 |
hwnet, SLOT(delegateToPlayer(const QString&))); |
8179
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
1451 |
connect(ui.pageNetGame->chatWidget, SIGNAL(ban(const QString&)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1452 |
hwnet, SLOT(banPlayer(const QString&))); |
8179
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
1453 |
connect(ui.pageNetGame->chatWidget, SIGNAL(info(const QString&)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1454 |
hwnet, SLOT(infoPlayer(const QString&))); |
8179
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
1455 |
connect(ui.pageNetGame->chatWidget, SIGNAL(follow(const QString&)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1456 |
hwnet, SLOT(followPlayer(const QString&))); |
8436
b89aacebb9db
- Also pass unknown cmds to the server when in room
unc0rr
parents:
8434
diff
changeset
|
1457 |
connect(ui.pageNetGame->chatWidget, SIGNAL(consoleCommand(const QString&)), |
b89aacebb9db
- Also pass unknown cmds to the server when in room
unc0rr
parents:
8434
diff
changeset
|
1458 |
hwnet, SLOT(consoleCommand(const QString&))); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1459 |
connect(ui.pageRoomsList->chatWidget, SIGNAL(kick(const QString&)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1460 |
hwnet, SLOT(kickPlayer(const QString&))); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1461 |
connect(ui.pageRoomsList->chatWidget, SIGNAL(ban(const QString&)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1462 |
hwnet, SLOT(banPlayer(const QString&))); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1463 |
connect(ui.pageRoomsList->chatWidget, SIGNAL(info(const QString&)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1464 |
hwnet, SLOT(infoPlayer(const QString&))); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1465 |
connect(ui.pageRoomsList->chatWidget, SIGNAL(follow(const QString&)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1466 |
hwnet, SLOT(followPlayer(const QString&))); |
8396 | 1467 |
connect(ui.pageRoomsList->chatWidget, SIGNAL(consoleCommand(const QString&)), |
1468 |
hwnet, SLOT(consoleCommand(const QString&))); |
|
1566
6b63c75fdc68
Start work on lobby: add/remove nick from the list on join/quit
unc0rr
parents:
1531
diff
changeset
|
1469 |
|
8762 | 1470 |
// player info |
1471 |
connect(hwnet, SIGNAL(playerInfo(const QString&, const QString&, const QString&, const QString&)), |
|
1472 |
ui.pageRoomsList->chatWidget, SLOT(onPlayerInfo(const QString&, const QString&, const QString&, const QString&)), Qt::QueuedConnection); |
|
1473 |
connect(hwnet, SIGNAL(playerInfo(const QString&, const QString&, const QString&, const QString&)), |
|
1474 |
ui.pageNetGame->chatWidget, SLOT(onPlayerInfo(const QString&, const QString&, const QString&, const QString&)), Qt::QueuedConnection); |
|
1475 |
||
1874 | 1476 |
// chatting |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1477 |
connect(ui.pageRoomsList->chatWidget, SIGNAL(chatLine(const QString&)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1478 |
hwnet, SLOT(chatLineToLobby(const QString&))); |
8759 | 1479 |
connect(hwnet, SIGNAL(lobbyChatAction(const QString&,const QString&)), |
1480 |
ui.pageRoomsList->chatWidget, SLOT(onChatAction(const QString&,const QString&)), Qt::QueuedConnection); |
|
1481 |
connect(hwnet, SIGNAL(lobbyChatMessage(const QString&, const QString&)), |
|
1482 |
ui.pageRoomsList->chatWidget, SLOT(onChatMessage(const QString&, const QString&)), Qt::QueuedConnection); |
|
1568 | 1483 |
|
1874 | 1484 |
// nick list stuff |
8891
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1485 |
{ |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1486 |
QSortFilterProxyModel * playersSortFilterModel = qobject_cast<QSortFilterProxyModel *>(hwnet->lobbyPlayersModel()); |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1487 |
if(playersSortFilterModel) |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1488 |
{ |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1489 |
PlayersListModel * players = qobject_cast<PlayersListModel *>(playersSortFilterModel->sourceModel()); |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1490 |
connect(players, SIGNAL(nickAdded(const QString&, bool)), |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1491 |
ui.pageNetGame->chatWidget, SLOT(nickAdded(const QString&, bool))); |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1492 |
connect(players, SIGNAL(nickRemoved(const QString&)), |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1493 |
ui.pageNetGame->chatWidget, SLOT(nickRemoved(const QString&))); |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1494 |
connect(players, SIGNAL(nickAddedLobby(const QString&, bool)), |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1495 |
ui.pageRoomsList->chatWidget, SLOT(nickAdded(const QString&, bool))); |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1496 |
connect(players, SIGNAL(nickRemovedLobby(const QString&)), |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1497 |
ui.pageRoomsList->chatWidget, SLOT(nickRemoved(const QString&))); |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1498 |
connect(players, SIGNAL(nickRemovedLobby(const QString&, const QString&)), |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1499 |
ui.pageRoomsList->chatWidget, SLOT(nickRemoved(const QString&, const QString&))); |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1500 |
} |
bf67b4d7d7b4
- Better fix to friends joins/quits highlighting problem
unc0rr
parents:
8887
diff
changeset
|
1501 |
} |
461 | 1502 |
|
1874 | 1503 |
// teams selecting stuff |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1504 |
connect(ui.pageNetGame->pNetTeamsWidget, SIGNAL(hhogsNumChanged(const HWTeam&)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1505 |
hwnet, SLOT(onHedgehogsNumChanged(const HWTeam&))); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1506 |
connect(ui.pageNetGame->pNetTeamsWidget, SIGNAL(teamColorChanged(const HWTeam&)), |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1507 |
hwnet, SLOT(onTeamColorChanged(const HWTeam&))); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1508 |
connect(ui.pageNetGame->pNetTeamsWidget, SIGNAL(teamWillPlay(HWTeam)), hwnet, SLOT(AddTeam(HWTeam))); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1509 |
connect(ui.pageNetGame->pNetTeamsWidget, SIGNAL(acceptRequested(HWTeam)), hwnet, SLOT(AddTeam(HWTeam))); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1510 |
connect(ui.pageNetGame->pNetTeamsWidget, SIGNAL(teamNotPlaying(const HWTeam&)), hwnet, SLOT(RemoveTeam(const HWTeam&))); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1511 |
connect(hwnet, SIGNAL(hhnumChanged(const HWTeam&)), |
6720
84261c3408a6
Make all signals from HWNet queued, this should fix issues with teams and chat widgets
unc0rr
parents:
6700
diff
changeset
|
1512 |
ui.pageNetGame->pNetTeamsWidget, SLOT(changeHHNum(const HWTeam&)), Qt::QueuedConnection); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1513 |
connect(hwnet, SIGNAL(teamColorChanged(const HWTeam&)), |
6720
84261c3408a6
Make all signals from HWNet queued, this should fix issues with teams and chat widgets
unc0rr
parents:
6700
diff
changeset
|
1514 |
ui.pageNetGame->pNetTeamsWidget, SLOT(changeTeamColor(const HWTeam&)), Qt::QueuedConnection); |
1874 | 1515 |
|
1924 | 1516 |
// admin stuff |
3283 | 1517 |
connect(hwnet, SIGNAL(serverMessageNew(const QString&)), ui.pageAdmin, SLOT(serverMessageNew(const QString &))); |
1518 |
connect(hwnet, SIGNAL(serverMessageOld(const QString&)), ui.pageAdmin, SLOT(serverMessageOld(const QString &))); |
|
1519 |
connect(hwnet, SIGNAL(latestProtocolVar(int)), ui.pageAdmin, SLOT(protocol(int))); |
|
8157 | 1520 |
connect(hwnet, SIGNAL(bansList(const QStringList &)), ui.pageAdmin, SLOT(setBansList(const QStringList &))); |
3283 | 1521 |
connect(ui.pageAdmin, SIGNAL(setServerMessageNew(const QString&)), hwnet, SLOT(setServerMessageNew(const QString &))); |
1522 |
connect(ui.pageAdmin, SIGNAL(setServerMessageOld(const QString&)), hwnet, SLOT(setServerMessageOld(const QString &))); |
|
1523 |
connect(ui.pageAdmin, SIGNAL(setProtocol(int)), hwnet, SLOT(setLatestProtocolVar(int))); |
|
1524 |
connect(ui.pageAdmin, SIGNAL(askServerVars()), hwnet, SLOT(askServerVars())); |
|
6009 | 1525 |
connect(ui.pageAdmin, SIGNAL(clearAccountsCache()), hwnet, SLOT(clearAccountsCache())); |
8157 | 1526 |
connect(ui.pageAdmin, SIGNAL(bansListRequest()), hwnet, SLOT(getBanList())); |
1527 |
connect(ui.pageAdmin, SIGNAL(removeBan(QString)), hwnet, SLOT(removeBan(QString))); |
|
1528 |
connect(ui.pageAdmin, SIGNAL(banIP(QString,QString,int)), hwnet, SLOT(banIP(QString,QString,int))); |
|
1529 |
connect(ui.pageAdmin, SIGNAL(banNick(QString,QString,int)), hwnet, SLOT(banNick(QString,QString,int))); |
|
1924 | 1530 |
|
1898
f0ab0c77946d
Send scheme data over net (but recieving part isn't implemented yet)
unc0rr
parents:
1897
diff
changeset
|
1531 |
// disconnect |
6036 | 1532 |
connect(hwnet, SIGNAL(disconnected(const QString&)), this, SLOT(ForcedDisconnect(const QString&)), Qt::QueuedConnection); |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1533 |
|
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1534 |
// config stuff |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1535 |
connect(hwnet, SIGNAL(paramChanged(const QString &, const QStringList &)), ui.pageNetGame->pGameCFG, SLOT(setParam(const QString &, const QStringList &))); |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1536 |
connect(ui.pageNetGame->pGameCFG, SIGNAL(paramChanged(const QString &, const QStringList &)), hwnet, SLOT(onParamChanged(const QString &, const QStringList &))); |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1537 |
connect(hwnet, SIGNAL(configAsked()), ui.pageNetGame->pGameCFG, SLOT(fullNetConfig())); |
8294
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1538 |
|
9100 | 1539 |
// using proxy slot to prevent loss of game messages when they're sent to not yet connected slot of game object |
1540 |
connect(hwnet, SIGNAL(FromNet(const QByteArray &)), this, SLOT(FromNetProxySlot(const QByteArray &)), Qt::QueuedConnection); |
|
1541 |
||
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1542 |
//nick and pass stuff |
8986 | 1543 |
hwnet->m_private_game = !(hostName == NETGAME_DEFAULT_SERVER && port == NETGAME_DEFAULT_PORT); |
1544 |
if (hwnet->m_private_game == false && AskForNickAndPwd() != 0) |
|
1545 |
return; |
|
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1546 |
|
14740
7b2bd37d7503
Fix inconsistencies in guest nick name generation
Wuzzy <Wuzzy2@mail.ru>
parents:
14677
diff
changeset
|
1547 |
QString nickname = config->value("net/nick", config->getRandomNick()).toString(); |
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1548 |
ui.pageRoomsList->setUser(nickname); |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1549 |
ui.pageNetGame->setUser(nickname); |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1550 |
|
14865 | 1551 |
hwnet->Connect(hostName, port, useTls, nickname); |
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1552 |
} |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1553 |
|
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1554 |
int HWForm::AskForNickAndPwd(void) |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1555 |
{ |
8181 | 1556 |
//remove temppasswordhash just in case |
8294
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1557 |
config->clearTempHash(); |
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1558 |
|
8181 | 1559 |
//initialize |
8986 | 1560 |
QString hash; |
1561 |
QString temphash; |
|
1562 |
QString nickname; |
|
8181 | 1563 |
QString password; |
8294
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1564 |
|
8986 | 1565 |
do { |
14740
7b2bd37d7503
Fix inconsistencies in guest nick name generation
Wuzzy <Wuzzy2@mail.ru>
parents:
14677
diff
changeset
|
1566 |
nickname = config->value("net/nick", config->getRandomNick()).toString(); |
8986 | 1567 |
hash = config->passwordHash(); |
1568 |
temphash = config->tempHash(); |
|
1569 |
||
1570 |
//if something from login is missing, start dialog loop |
|
1571 |
if (nickname.isEmpty() || hash.isEmpty()) { |
|
8407
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1572 |
//open dialog |
8294
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1573 |
HWPasswordDialog * pwDialog = new HWPasswordDialog(this); |
8364
fbc9bcc6c39d
Added "New account" button when connectiong to the official server
vitiv <nikita.utiu@gmail.com>
parents:
8357
diff
changeset
|
1574 |
// make the "new account" button dialog open a browser with the registration page |
fbc9bcc6c39d
Added "New account" button when connectiong to the official server
vitiv <nikita.utiu@gmail.com>
parents:
8357
diff
changeset
|
1575 |
connect(pwDialog->pbNewAccount, SIGNAL(clicked()), this, SLOT(openRegistrationPage())); |
8294
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1576 |
pwDialog->cbSave->setChecked(config->value("net/savepassword", true).toBool()); |
8181 | 1577 |
|
8407
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1578 |
//if nickname is present, put it into the field |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1579 |
if (!nickname.isEmpty()) { |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1580 |
pwDialog->leNickname->setText(nickname); |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1581 |
pwDialog->lePassword->setFocus(); |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1582 |
} |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1583 |
|
12799
e6af1eb9e8ce
Fix broken cancel button on the login window (bug 373)
Wuzzy <Wuzzy2@mail.ru>
parents:
12756
diff
changeset
|
1584 |
//if dialog aborted, return failure |
8407
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1585 |
if (pwDialog->exec() != QDialog::Accepted) { |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1586 |
delete pwDialog; |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1587 |
GoBack(); |
12799
e6af1eb9e8ce
Fix broken cancel button on the login window (bug 373)
Wuzzy <Wuzzy2@mail.ru>
parents:
12756
diff
changeset
|
1588 |
return 1; |
8407
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1589 |
} |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1590 |
|
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1591 |
//set nick and pass from the dialog |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1592 |
nickname = pwDialog->leNickname->text(); |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1593 |
password = pwDialog->lePassword->text(); |
8986 | 1594 |
bool save = pwDialog->cbSave->isChecked(); |
1595 |
//clean up |
|
1596 |
delete pwDialog; |
|
8181 | 1597 |
|
8407
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1598 |
//check the nickname variable |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1599 |
if (nickname.isEmpty()) { |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1600 |
int retry = RetryDialog(tr("Hedgewars - Empty nickname"), tr("No nickname supplied.")); |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1601 |
GoBack(); |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1602 |
if (retry) { |
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1603 |
if (hwnet->m_private_game) { |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1604 |
QStringList list = hwnet->getHost().split(":"); |
14865 | 1605 |
NetConnectServer(list.at(0), list.at(1).toShort(), false); |
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1606 |
} else |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1607 |
NetConnectOfficialServer(); |
8986 | 1608 |
} |
1609 |
break; //loop restart |
|
1610 |
} else { |
|
1611 |
//update nickname if it's fine |
|
1612 |
config->setValue("net/nick", nickname); |
|
1613 |
config->updNetNick(); |
|
8407
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1614 |
} |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1615 |
|
8986 | 1616 |
//check the password variable |
1617 |
if (password.isEmpty()) { |
|
1618 |
config->clearPasswordHash(); |
|
1619 |
break; |
|
1620 |
} else { |
|
8407
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1621 |
//calculate temphash and set it into config |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1622 |
temphash = QCryptographicHash::hash(password.toUtf8(), QCryptographicHash::Md5).toHex(); |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1623 |
config->setTempHash(temphash); |
8181 | 1624 |
|
8407
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1625 |
//if user wants to save password |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1626 |
config->setValue("net/savepassword", save); |
8986 | 1627 |
if (save) { |
1628 |
// user wants to save password |
|
8407
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1629 |
ui.pageOptions->CBSavePassword->setChecked(true); |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1630 |
config->setPasswordHash(temphash); |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1631 |
} |
686f2e716c97
Fixes password not actually saving when "save password" is checked in the HWPasswordDialog called by HWForm.
dag10 <gottlieb.drew@gmail.com>
parents:
8396
diff
changeset
|
1632 |
} |
8986 | 1633 |
} |
1634 |
} while (nickname.isEmpty() || (hash.isEmpty() && temphash.isEmpty())); //while a nickname, or both hashes are missing |
|
8294
0e5782b0dd54
Removed whitespaces, refactored hash setting getting and clearing
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8293
diff
changeset
|
1635 |
|
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1636 |
return 0; |
184 | 1637 |
} |
1638 |
||
314 | 1639 |
void HWForm::NetConnect() |
1640 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1641 |
HWHostPortDialog * hpd = new HWHostPortDialog(this); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1642 |
hpd->leHost->setText(*netHost); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1643 |
hpd->sbPort->setValue(netPort); |
653
4f44fc06ca45
Class to ask host/port to connect to ('Specify' button on PageNet)
unc0rr
parents:
647
diff
changeset
|
1644 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1645 |
if (hpd->exec() == QDialog::Accepted) |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1646 |
{ |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1647 |
config->SaveOptions(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1648 |
delete netHost; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1649 |
netHost = new QString(hpd->leHost->text()); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1650 |
netPort = hpd->sbPort->value(); |
14865 | 1651 |
NetConnectServer(*netHost, netPort, false); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1652 |
} |
6907 | 1653 |
delete hpd; |
314 | 1654 |
} |
1655 |
||
1656 |
void HWForm::NetStartServer() |
|
1657 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1658 |
config->SaveOptions(); |
636 | 1659 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1660 |
pnetserver = new HWNetServer; |
7794
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
1661 |
if (!pnetserver->StartServer(ui.pageNetServer->sbPort->value())) |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1662 |
{ |
8383 | 1663 |
MessageDialog::ShowErrorMessage(QMessageBox::tr("Unable to start server"), this); |
7794
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
1664 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1665 |
delete pnetserver; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1666 |
pnetserver = 0; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1667 |
return; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1668 |
} |
672
08ed55ea1e2a
- Fix a bug when server fails to start, and then connecting to another server on the same host (strange, the fix won't work on my machine)
unc0rr
parents:
668
diff
changeset
|
1669 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1670 |
QTimer::singleShot(250, this, SLOT(AsyncNetServerStart())); |
672
08ed55ea1e2a
- Fix a bug when server fails to start, and then connecting to another server on the same host (strange, the fix won't work on my machine)
unc0rr
parents:
668
diff
changeset
|
1671 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1672 |
pRegisterServer = new HWNetUdpServer(0, |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1673 |
ui.pageNetServer->leServerDescr->text(), |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1674 |
ui.pageNetServer->sbPort->value()); |
1418 | 1675 |
} |
1676 |
||
1677 |
void HWForm::AsyncNetServerStart() |
|
1678 |
{ |
|
14865 | 1679 |
NetConnectServer("localhost", pnetserver->getRunningPort(), false); |
314 | 1680 |
} |
1681 |
||
184 | 1682 |
void HWForm::NetDisconnect() |
1683 |
{ |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1684 |
if(pnetserver) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1685 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1686 |
if (pRegisterServer) |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1687 |
{ |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1688 |
pRegisterServer->unregister(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1689 |
pRegisterServer = 0; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1690 |
} |
659 | 1691 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1692 |
pnetserver->StopServer(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1693 |
delete pnetserver; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1694 |
pnetserver = 0; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1695 |
} |
6225
505643d4c23d
disconnect when going back from lobby page (regression fix)
sheepluva
parents:
6223
diff
changeset
|
1696 |
|
505643d4c23d
disconnect when going back from lobby page (regression fix)
sheepluva
parents:
6223
diff
changeset
|
1697 |
if(hwnet) |
505643d4c23d
disconnect when going back from lobby page (regression fix)
sheepluva
parents:
6223
diff
changeset
|
1698 |
hwnet->Disconnect(); |
184 | 1699 |
} |
1700 |
||
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1701 |
void HWForm::ForcedDisconnect(const QString & reason) |
383 | 1702 |
{ |
8296
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1703 |
if (reason == "Reconnected too fast") { //TODO: this is a hack, which should be remade |
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1704 |
bool retry = RetryDialog(tr("Hedgewars - Connection error"), tr("You reconnected too fast.\nPlease wait a few seconds and try again.")); |
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1705 |
if (retry) { |
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1706 |
if (hwnet->m_private_game) { |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1707 |
QStringList list = hwnet->getHost().split(":"); |
14865 | 1708 |
NetConnectServer(list.at(0), list.at(1).toUInt(), false); |
8720
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1709 |
} else |
5603527f9803
this should prevent the password prompt from appearing on local games (issue 548)
koda
parents:
8716
diff
changeset
|
1710 |
NetConnectOfficialServer(); |
8296
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1711 |
} |
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1712 |
else { |
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1713 |
while (ui.Pages->currentIndex() != ID_PAGE_NET |
8434 | 1714 |
&& ui.Pages->currentIndex() != ID_PAGE_MAIN) |
8296
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1715 |
{ |
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1716 |
GoBack(); |
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1717 |
} |
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1718 |
} |
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1719 |
return; |
455da122c0ad
Added a hack that activates a RetryDialog in case the user is banned for 'Reconnect too fast'. Set all string used in RetryDialog to be translated
Ondrej Skopek <skopekondrej@gmail.com>
parents:
8295
diff
changeset
|
1720 |
} |
7794
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
1721 |
if (pnetserver) |
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
1722 |
return; // we have server - let it care of all things |
13846 | 1723 |
if (hwnet && (reason != "bye")) |
13673
1aa5e884326a
Fix some string/translation inconsistencies in strings related to leaving
Wuzzy <Wuzzy2@mail.ru>
parents:
13657
diff
changeset
|
1724 |
{ |
13657
2d38dc2d3414
Tweak some connection failure messages
Wuzzy <Wuzzy2@mail.ru>
parents:
13628
diff
changeset
|
1725 |
QString errorStr = QMessageBox::tr("The connection to the server is lost.") + (reason.isEmpty()?"":("\n\n" + HWNewNet::tr("Reason:") + "\n" + reason)); |
8383 | 1726 |
MessageDialog::ShowErrorMessage(errorStr, this); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1727 |
} |
7842
d1c0e4341165
- Better fix than the one from rc7f5c3bd7f8c. Now just scrolling back till net/nettype/main page. Not tested aswell.
unc0rr
parents:
7826
diff
changeset
|
1728 |
|
d1c0e4341165
- Better fix than the one from rc7f5c3bd7f8c. Now just scrolling back till net/nettype/main page. Not tested aswell.
unc0rr
parents:
7826
diff
changeset
|
1729 |
while (ui.Pages->currentIndex() != ID_PAGE_NET |
d1c0e4341165
- Better fix than the one from rc7f5c3bd7f8c. Now just scrolling back till net/nettype/main page. Not tested aswell.
unc0rr
parents:
7826
diff
changeset
|
1730 |
&& ui.Pages->currentIndex() != ID_PAGE_MAIN) |
7803 | 1731 |
{ |
7842
d1c0e4341165
- Better fix than the one from rc7f5c3bd7f8c. Now just scrolling back till net/nettype/main page. Not tested aswell.
unc0rr
parents:
7826
diff
changeset
|
1732 |
GoBack(); |
7803 | 1733 |
} |
383 | 1734 |
} |
1735 |
||
14838 | 1736 |
void HWForm::NetRedirected(quint16 port) |
1737 |
{ |
|
1738 |
QMessageBox questionMsg(this); |
|
1739 |
questionMsg.setIcon(QMessageBox::Question); |
|
1740 |
questionMsg.setWindowTitle(QMessageBox::tr("Server redirection")); |
|
1741 |
questionMsg.setText(QMessageBox::tr("This server supports secure connections on port %1.\nWould you like to reconnect securely?").arg(port)); |
|
1742 |
questionMsg.setTextFormat(Qt::PlainText); |
|
1743 |
questionMsg.setWindowModality(Qt::WindowModal); |
|
1744 |
questionMsg.addButton(QMessageBox::Yes); |
|
1745 |
questionMsg.addButton(QMessageBox::No); |
|
1746 |
||
1747 |
if (questionMsg.exec() == QMessageBox::Yes) |
|
14865 | 1748 |
{ |
1749 |
QString host = hwnet->getHost().split(":").at(0); |
|
1750 |
NetConnectServer(host, port, true); |
|
1751 |
} |
|
1752 |
else if (hwnet) |
|
14838 | 1753 |
{ |
14865 | 1754 |
hwnet->ContinueConnection(); |
14838 | 1755 |
} |
1756 |
} |
|
1757 |
||
1311 | 1758 |
void HWForm::NetConnected() |
1759 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1760 |
GoToPage(ID_PAGE_ROOMSLIST); |
1311 | 1761 |
} |
1762 |
||
184 | 1763 |
void HWForm::NetGameEnter() |
1764 |
{ |
|
8179
a1ffcb559f99
Refactor: get rid of excessive QSettings instances on the same poor hedgewars.ini file
unc0rr
parents:
8157
diff
changeset
|
1765 |
ui.pageNetGame->chatWidget->clear(); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1766 |
GoToPage(ID_PAGE_NETGAME); |
184 | 1767 |
} |
1768 |
||
339
7535ab6c3820
Run game message added, team and config info provided for net game
displacer
parents:
338
diff
changeset
|
1769 |
void HWForm::AddNetTeam(const HWTeam& team) |
184 | 1770 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1771 |
ui.pageNetGame->pNetTeamsWidget->addTeam(team); |
184 | 1772 |
} |
1773 |
||
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1774 |
void HWForm::RemoveNetTeam(const HWTeam& team) |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1775 |
{ |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1776 |
ui.pageNetGame->pNetTeamsWidget->removeNetTeam(team); |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1777 |
} |
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
1778 |
|
184 | 1779 |
void HWForm::StartMPGame() |
1780 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1781 |
QString ammo; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1782 |
ammo = ui.pageMultiplayer->gameCFG->WeaponsName->itemData( |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1783 |
ui.pageMultiplayer->gameCFG->WeaponsName->currentIndex() |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1784 |
).toString(); |
696 | 1785 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1786 |
CreateGame(ui.pageMultiplayer->gameCFG, ui.pageMultiplayer->teamsSelect, ammo); |
306 | 1787 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1788 |
game->StartLocal(); |
184 | 1789 |
} |
306 | 1790 |
|
1791 |
void HWForm::GameStateChanged(GameState gameState) |
|
1792 |
{ |
|
4430
cacda05a053e
Try suppressing those annoying "incorrect state" messages without actually breaking net play. Alter prior checks on GoBack. NEEDS TESTING.
nemo
parents:
4429
diff
changeset
|
1793 |
quint8 id = ui.Pages->currentIndex(); |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1794 |
switch(gameState) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1795 |
{ |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1796 |
case gsStarted: |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1797 |
{ |
15278
16f389fcd462
Prevent saving of demo after /lua command was used
Wuzzy <Wuzzy2@mail.ru>
parents:
15276
diff
changeset
|
1798 |
demoIsPresent = true; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1799 |
Music(false); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1800 |
if (wBackground) wBackground->stopAnimation(); |
4428
2bc3d3475edf
Try to kill off all teams if the player returns to the lobby in mid-game. Also leave game room open for admins to kick/restrict joins etc. NEEDS TESTING PROBABLY BROKE SOMETHING OR OTHER
nemo
parents:
4416
diff
changeset
|
1801 |
if (!hwnet || (!hwnet->isRoomChief() || !hwnet->isInRoom())) GoToPage(ID_PAGE_INGAME); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1802 |
ui.pageGameStats->clear(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1803 |
if (pRegisterServer) |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1804 |
{ |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1805 |
pRegisterServer->unregister(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1806 |
pRegisterServer = 0; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1807 |
} |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1808 |
//setVisible(false); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1809 |
setFocusPolicy(Qt::NoFocus); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1810 |
break; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1811 |
} |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1812 |
case gsFinished: |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1813 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1814 |
//setVisible(true); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1815 |
setFocusPolicy(Qt::StrongFocus); |
4430
cacda05a053e
Try suppressing those annoying "incorrect state" messages without actually breaking net play. Alter prior checks on GoBack. NEEDS TESTING.
nemo
parents:
4429
diff
changeset
|
1816 |
if (id == ID_PAGE_INGAME) GoBack(); |
8226
67f07ff5b593
Removed redundant "enable"s on checkboxes and variable names.
Mitchell Kember <mk12360@gmail.com>
parents:
8205
diff
changeset
|
1817 |
Music(ui.pageOptions->CBFrontendMusic->isChecked()); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1818 |
if (wBackground) wBackground->startAnimation(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1819 |
GoToPage(ID_PAGE_GAMESTATS); |
13689
27e5e311c7a3
Fix critical failure to cleanup teams list after rejoining game after a force-quit. Fixes bug 597
Wuzzy <Wuzzy2@mail.ru>
parents:
13673
diff
changeset
|
1820 |
if (hwnet) |
27e5e311c7a3
Fix critical failure to cleanup teams list after rejoining game after a force-quit. Fixes bug 597
Wuzzy <Wuzzy2@mail.ru>
parents:
13673
diff
changeset
|
1821 |
{ |
27e5e311c7a3
Fix critical failure to cleanup teams list after rejoining game after a force-quit. Fixes bug 597
Wuzzy <Wuzzy2@mail.ru>
parents:
13673
diff
changeset
|
1822 |
if (!game || !game->netSuspend) |
27e5e311c7a3
Fix critical failure to cleanup teams list after rejoining game after a force-quit. Fixes bug 597
Wuzzy <Wuzzy2@mail.ru>
parents:
13673
diff
changeset
|
1823 |
hwnet->gameFinished(true); |
27e5e311c7a3
Fix critical failure to cleanup teams list after rejoining game after a force-quit. Fixes bug 597
Wuzzy <Wuzzy2@mail.ru>
parents:
13673
diff
changeset
|
1824 |
// After a game, the local player might have pseudo-teams left |
27e5e311c7a3
Fix critical failure to cleanup teams list after rejoining game after a force-quit. Fixes bug 597
Wuzzy <Wuzzy2@mail.ru>
parents:
13673
diff
changeset
|
1825 |
// when rejoining a previously left game. This makes sure the |
27e5e311c7a3
Fix critical failure to cleanup teams list after rejoining game after a force-quit. Fixes bug 597
Wuzzy <Wuzzy2@mail.ru>
parents:
13673
diff
changeset
|
1826 |
// teams list is in a consistent state. |
27e5e311c7a3
Fix critical failure to cleanup teams list after rejoining game after a force-quit. Fixes bug 597
Wuzzy <Wuzzy2@mail.ru>
parents:
13673
diff
changeset
|
1827 |
ui.pageNetGame->cleanupFakeNetTeams(); |
27e5e311c7a3
Fix critical failure to cleanup teams list after rejoining game after a force-quit. Fixes bug 597
Wuzzy <Wuzzy2@mail.ru>
parents:
13673
diff
changeset
|
1828 |
} |
4430
cacda05a053e
Try suppressing those annoying "incorrect state" messages without actually breaking net play. Alter prior checks on GoBack. NEEDS TESTING.
nemo
parents:
4429
diff
changeset
|
1829 |
if (game) game->netSuspend = false; |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1830 |
break; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1831 |
} |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1832 |
default: |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1833 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1834 |
//setVisible(true); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1835 |
setFocusPolicy(Qt::StrongFocus); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1836 |
quint8 id = ui.Pages->currentIndex(); |
4428
2bc3d3475edf
Try to kill off all teams if the player returns to the lobby in mid-game. Also leave game room open for admins to kick/restrict joins etc. NEEDS TESTING PROBABLY BROKE SOMETHING OR OTHER
nemo
parents:
4416
diff
changeset
|
1837 |
if (id == ID_PAGE_INGAME || |
2bc3d3475edf
Try to kill off all teams if the player returns to the lobby in mid-game. Also leave game room open for admins to kick/restrict joins etc. NEEDS TESTING PROBABLY BROKE SOMETHING OR OTHER
nemo
parents:
4416
diff
changeset
|
1838 |
// was room chief and the game was aborted |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1839 |
(hwnet && hwnet->isRoomChief() && hwnet->isInRoom() && |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1840 |
(gameState == gsInterrupted || gameState == gsStopped || gameState == gsDestroyed || gameState == gsHalted))) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1841 |
{ |
4430
cacda05a053e
Try suppressing those annoying "incorrect state" messages without actually breaking net play. Alter prior checks on GoBack. NEEDS TESTING.
nemo
parents:
4429
diff
changeset
|
1842 |
if (id == ID_PAGE_INGAME) GoBack(); |
8226
67f07ff5b593
Removed redundant "enable"s on checkboxes and variable names.
Mitchell Kember <mk12360@gmail.com>
parents:
8205
diff
changeset
|
1843 |
Music(ui.pageOptions->CBFrontendMusic->isChecked()); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1844 |
if (wBackground) wBackground->startAnimation(); |
4908
99d6797b7ff4
Frontend sends ROUNDFINISHED with information about whether the round was played till end (will be needed for stats)
unc0rr
parents:
4902
diff
changeset
|
1845 |
if (hwnet) hwnet->gameFinished(false); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1846 |
} |
4845 | 1847 |
if (gameState == gsHalted) close(); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1848 |
}; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1849 |
} |
307 | 1850 |
} |
1851 |
||
15278
16f389fcd462
Prevent saving of demo after /lua command was used
Wuzzy <Wuzzy2@mail.ru>
parents:
15276
diff
changeset
|
1852 |
void HWForm::DemoPresenceChanged(bool hasDemo) |
16f389fcd462
Prevent saving of demo after /lua command was used
Wuzzy <Wuzzy2@mail.ru>
parents:
15276
diff
changeset
|
1853 |
{ |
16f389fcd462
Prevent saving of demo after /lua command was used
Wuzzy <Wuzzy2@mail.ru>
parents:
15276
diff
changeset
|
1854 |
demoIsPresent = hasDemo; |
16f389fcd462
Prevent saving of demo after /lua command was used
Wuzzy <Wuzzy2@mail.ru>
parents:
15276
diff
changeset
|
1855 |
} |
16f389fcd462
Prevent saving of demo after /lua command was used
Wuzzy <Wuzzy2@mail.ru>
parents:
15276
diff
changeset
|
1856 |
|
696 | 1857 |
void HWForm::CreateGame(GameCFGWidget * gamecfg, TeamSelWidget* pTeamSelWidget, QString ammo) |
306 | 1858 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1859 |
game = new HWGame(config, gamecfg, ammo, pTeamSelWidget); |
7245
53f73f4ae203
Modified frontend so that updating campaogn progress no longer changes current index of the mission combo box
belphegorr <szabibibi@gmail.com>
parents:
7207
diff
changeset
|
1860 |
connect(game, SIGNAL(CampStateChanged(int)), this, SLOT(UpdateCampaignPageProgress(int))); |
14467
4edcb655dc5a
Update training page after completing a training
Wuzzy <Wuzzy2@mail.ru>
parents:
14462
diff
changeset
|
1861 |
connect(game, SIGNAL(TrainingStateChanged(int)), this, SLOT(UpdateTrainingPageTeam(int))); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1862 |
connect(game, SIGNAL(GameStateChanged(GameState)), this, SLOT(GameStateChanged(GameState))); |
15278
16f389fcd462
Prevent saving of demo after /lua command was used
Wuzzy <Wuzzy2@mail.ru>
parents:
15276
diff
changeset
|
1863 |
connect(game, SIGNAL(DemoPresenceChanged(bool)), this, SLOT(DemoPresenceChanged(bool))); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1864 |
connect(game, SIGNAL(GameStats(char, const QString &)), ui.pageGameStats, SLOT(GameStats(char, const QString &))); |
10307
e13d3147f15b
do not get stuck on "in game..." page just because of game crash. output a message instead. could still need some tweaking, but a man gotta sleep. and sheep too...
sheepluva
parents:
10108
diff
changeset
|
1865 |
connect(game, SIGNAL(ErrorMessage(const QString &)), this, SLOT(ShowFatalErrorMessage(const QString &)), Qt::QueuedConnection); |
7180 | 1866 |
connect(game, SIGNAL(HaveRecord(RecordType, const QByteArray &)), this, SLOT(GetRecord(RecordType, const QByteArray &))); |
5734 | 1867 |
m_lastDemo = QByteArray(); |
306 | 1868 |
} |
425 | 1869 |
|
7180 | 1870 |
void HWForm::GetRecord(RecordType type, const QByteArray & record) |
533 | 1871 |
{ |
7180 | 1872 |
if (type != rtNeither) |
1873 |
{ |
|
1874 |
QString filename; |
|
1875 |
QByteArray demo = record; |
|
1876 |
QString recordFileName = |
|
1877 |
config->appendDateTimeToRecordName() ? |
|
1878 |
QDateTime::currentDateTime().toString("yyyy-MM-dd_hh-mm") : |
|
1879 |
"LastRound"; |
|
1487
b4cc59a6d50a
Add an option to name records with current date and time
unc0rr
parents:
1427
diff
changeset
|
1880 |
|
8613
82c649dfc7c3
split cVersionString into its three separate components (version, revision, hash) and apply the new values sensibly on the frontend (esp. title, info and feedback)
koda
parents:
8609
diff
changeset
|
1881 |
recordFileName += "_" + *cRevisionString + "-" + *cHashString; |
4902
45ec26ca9491
if on dev version append hg revision id to demos/saves' filenames
sheepluva
parents:
4897
diff
changeset
|
1882 |
|
7180 | 1883 |
if (type == rtDemo) |
1884 |
{ |
|
1885 |
demo.replace(QByteArray("\x02TL"), QByteArray("\x02TD")); |
|
1886 |
demo.replace(QByteArray("\x02TN"), QByteArray("\x02TD")); |
|
1887 |
demo.replace(QByteArray("\x02TS"), QByteArray("\x02TD")); |
|
1888 |
filename = cfgdir->absolutePath() + "/Demos/" + recordFileName + "." + *cProtoVer + ".hwd"; |
|
1889 |
m_lastDemo = demo; |
|
1890 |
} |
|
1891 |
else |
|
1892 |
{ |
|
1893 |
demo.replace(QByteArray("\x02TL"), QByteArray("\x02TS")); |
|
1894 |
demo.replace(QByteArray("\x02TN"), QByteArray("\x02TS")); |
|
1895 |
filename = cfgdir->absolutePath() + "/Saves/" + recordFileName + "." + *cProtoVer + ".hws"; |
|
1896 |
} |
|
1897 |
||
1898 |
QFile demofile(filename); |
|
1899 |
if (!demofile.open(QIODevice::WriteOnly)) |
|
8383 | 1900 |
MessageDialog::ShowErrorMessage(tr("Cannot save record to file %1").arg(filename), this); |
7180 | 1901 |
else |
1902 |
{ |
|
1903 |
demofile.write(demo); |
|
1904 |
demofile.close(); |
|
1905 |
} |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1906 |
} |
533 | 1907 |
|
7392
bc3306c59a08
Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents:
7376
diff
changeset
|
1908 |
ui.pageVideos->startEncoding(record); |
533 | 1909 |
} |
587 | 1910 |
|
11968
1de4d6b35748
Mission recategorization into trainings, challenges and scenarios.
Wuzzy <almikes@aol.com>
parents:
11959
diff
changeset
|
1911 |
void HWForm::startTraining(const QString & scriptName, const QString & subFolder) |
587 | 1912 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1913 |
CreateGame(0, 0, 0); |
587 | 1914 |
|
14462
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
1915 |
QString trainTeam = ui.pageTraining->CBTeam->currentText(); |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
1916 |
game->StartTraining(scriptName, subFolder, trainTeam); |
3760 | 1917 |
} |
1918 |
||
1919 |
void HWForm::StartCampaign() |
|
1920 |
{ |
|
1921 |
CreateGame(0, 0, 0); |
|
11957 | 1922 |
QString camp = ui.pageCampaign->CBCampaign->itemData(ui.pageCampaign->CBCampaign->currentIndex()).toString(); |
9290
478aa681e702
this seems to work ok, but I have to clean up the code
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9288
diff
changeset
|
1923 |
QString miss = campaignMissionInfo[ui.pageCampaign->CBMission->currentIndex()].script; |
7201
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
1924 |
QString campTeam = ui.pageCampaign->CBTeam->currentText(); |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
1925 |
game->StartCampaign(camp, miss, campTeam); |
587 | 1926 |
} |
660 | 1927 |
|
1928 |
void HWForm::CreateNetGame() |
|
1929 |
{ |
|
9100 | 1930 |
// go back in pages to prevent user from being stuck on certain pages |
1931 |
if(ui.Pages->currentIndex() == ID_PAGE_GAMESTATS || |
|
1932 |
ui.Pages->currentIndex() == ID_PAGE_INGAME) |
|
1933 |
GoBack(); |
|
1934 |
||
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1935 |
QString ammo; |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1936 |
ammo = ui.pageNetGame->pGameCFG->WeaponsName->itemData( |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1937 |
ui.pageNetGame->pGameCFG->WeaponsName->currentIndex() |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
1938 |
).toString(); |
1517 | 1939 |
|
6225
505643d4c23d
disconnect when going back from lobby page (regression fix)
sheepluva
parents:
6223
diff
changeset
|
1940 |
CreateGame(ui.pageNetGame->pGameCFG, ui.pageNetGame->pNetTeamsWidget, ammo); |
660 | 1941 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1942 |
connect(game, SIGNAL(SendNet(const QByteArray &)), hwnet, SLOT(SendNet(const QByteArray &))); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1943 |
connect(game, SIGNAL(SendChat(const QString &)), hwnet, SLOT(chatLineToNet(const QString &))); |
10392 | 1944 |
connect(game, SIGNAL(SendConsoleCommand(const QString&)), hwnet, SLOT(consoleCommand(const QString&))); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1945 |
connect(game, SIGNAL(SendTeamMessage(const QString &)), hwnet, SLOT(SendTeamMessage(const QString &))); |
7916 | 1946 |
connect(hwnet, SIGNAL(chatStringFromNet(const QString &)), game, SLOT(FromNetChat(const QString &)), Qt::QueuedConnection); |
13823
d012948b1eda
Make frontend forward server error and warning messages to engine
Wuzzy <Wuzzy2@mail.ru>
parents:
13818
diff
changeset
|
1947 |
connect(hwnet, SIGNAL(Warning(const QString&)), game, SLOT(FromNetWarning(const QString&)), Qt::QueuedConnection); |
d012948b1eda
Make frontend forward server error and warning messages to engine
Wuzzy <Wuzzy2@mail.ru>
parents:
13818
diff
changeset
|
1948 |
connect(hwnet, SIGNAL(Error(const QString&)), game, SLOT(FromNetError(const QString&)), Qt::QueuedConnection); |
660 | 1949 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1950 |
game->StartNet(); |
660 | 1951 |
} |
674 | 1952 |
|
14903
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1953 |
void HWForm::PlayOfficialServerDemo() |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1954 |
{ |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1955 |
// go back in pages to prevent user from being stuck on certain pages |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1956 |
if(ui.Pages->currentIndex() == ID_PAGE_GAMESTATS || |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1957 |
ui.Pages->currentIndex() == ID_PAGE_INGAME) |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1958 |
GoBack(); |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1959 |
|
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1960 |
QString ammo; |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1961 |
ammo = ui.pageNetGame->pGameCFG->WeaponsName->itemData( |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1962 |
ui.pageNetGame->pGameCFG->WeaponsName->currentIndex() |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1963 |
).toString(); |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1964 |
|
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1965 |
CreateGame(ui.pageNetGame->pGameCFG, ui.pageNetGame->pNetTeamsWidget, ammo); |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1966 |
|
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1967 |
game->PlayOfficialServerDemo(); |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1968 |
} |
5119203470f3
Teach frontend how to deal with official server replays (/watch)
Wuzzy <Wuzzy2@mail.ru>
parents:
14865
diff
changeset
|
1969 |
|
674 | 1970 |
void HWForm::closeEvent(QCloseEvent *event) |
1971 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1972 |
config->SaveOptions(); |
11852 | 1973 |
#ifdef VIDEOREC |
7235
baa69bd025d9
1. Implement new page in frontend with options for video recording.
Stepan777 <stepik-777@mail.ru>
parents:
7180
diff
changeset
|
1974 |
config->SaveVideosOptions(); |
8266
927da572bcdc
will fix this http://code.google.com/p/hedgewars/source/detail?r=9f0e79ab51f00f3b1e133ae70cdd63f6963439c0 and will allow hedgewars to build without video recording enabled, for the time being although i want to talk to koda or someone to understand what should be #ifdef'd and if i've done too much or too little.. but at least that will let it build
mk12
parents:
8226
diff
changeset
|
1975 |
#endif |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1976 |
event->accept(); |
674 | 1977 |
} |
1235 | 1978 |
|
1979 |
void HWForm::Music(bool checked) |
|
1980 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1981 |
if (checked) |
6165
6fe3e922246e
moving and renaming SDLs.*, making it a singleton; cleaning up class responsibilties wrt SDLInteraction; some comments
sheepluva
parents:
6160
diff
changeset
|
1982 |
SDLInteraction::instance().startMusic(); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1983 |
else |
6165
6fe3e922246e
moving and renaming SDLs.*, making it a singleton; cleaning up class responsibilties wrt SDLInteraction; some comments
sheepluva
parents:
6160
diff
changeset
|
1984 |
SDLInteraction::instance().stopMusic(); |
1235 | 1985 |
} |
1409
d1cbe4a57ebf
Add button for controlling room options (no usefull yet)
unc0rr
parents:
1405
diff
changeset
|
1986 |
|
2345
daf1785f2337
- Frontend: reorganize code controlling widgets state, fix problems getting room admin status
unc0rr
parents:
2261
diff
changeset
|
1987 |
void HWForm::NetGameChangeStatus(bool isMaster) |
daf1785f2337
- Frontend: reorganize code controlling widgets state, fix problems getting room admin status
unc0rr
parents:
2261
diff
changeset
|
1988 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1989 |
if (isMaster) |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1990 |
NetGameMaster(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1991 |
else |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1992 |
NetGameSlave(); |
2345
daf1785f2337
- Frontend: reorganize code controlling widgets state, fix problems getting room admin status
unc0rr
parents:
2261
diff
changeset
|
1993 |
} |
daf1785f2337
- Frontend: reorganize code controlling widgets state, fix problems getting room admin status
unc0rr
parents:
2261
diff
changeset
|
1994 |
|
1409
d1cbe4a57ebf
Add button for controlling room options (no usefull yet)
unc0rr
parents:
1405
diff
changeset
|
1995 |
void HWForm::NetGameMaster() |
d1cbe4a57ebf
Add button for controlling room options (no usefull yet)
unc0rr
parents:
1405
diff
changeset
|
1996 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1997 |
ui.pageNetGame->setMasterMode(true); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1998 |
ui.pageNetGame->restrictJoins->setChecked(false); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
1999 |
ui.pageNetGame->restrictTeamAdds->setChecked(false); |
8559 | 2000 |
ui.pageNetGame->restrictUnregistered->setChecked(false); |
13197
0bc5f618ca7c
Rename the misleadingly-named AmmoSchemeModel to GameSchemeModel
Wuzzy <Wuzzy2@mail.ru>
parents:
13086
diff
changeset
|
2001 |
ui.pageNetGame->pGameCFG->GameSchemes->setModel(gameSchemeModel); |
8377 | 2002 |
ui.pageNetGame->pGameCFG->setMaster(true); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2003 |
ui.pageNetGame->pNetTeamsWidget->setInteractivity(true); |
14810
583d8b96fb30
Select appropriate schemes when taking room control (bug 461)
Wuzzy <Wuzzy2@mail.ru>
parents:
14804
diff
changeset
|
2004 |
ui.pageNetGame->pGameCFG->resetSchemeStates(); |
2377 | 2005 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2006 |
if (hwnet) |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2007 |
{ |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2008 |
// disconnect connections first to ensure their inexistance and not to connect twice |
8416
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2009 |
ui.pageNetGame->BtnStart->disconnect(this); |
5126 | 2010 |
ui.pageNetGame->BtnUpdate->disconnect(hwnet); |
8415
02acf6b92f52
Moved room name edit box from footer to top of page. Also shows room name when in slave mode.
dag10
parents:
8407
diff
changeset
|
2011 |
ui.pageNetGame->leRoomName->disconnect(hwnet); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2012 |
ui.pageNetGame->restrictJoins->disconnect(hwnet); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2013 |
ui.pageNetGame->restrictTeamAdds->disconnect(hwnet); |
8559 | 2014 |
ui.pageNetGame->restrictUnregistered->disconnect(hwnet); |
7122
fa2d09868ac6
Fix reported in bug #327, comment #3 - untested but seems reasonable/safe.
nemo
parents:
7015
diff
changeset
|
2015 |
ui.pageNetGame->disconnect(hwnet, SLOT(updateRoomName(const QString&))); |
7710
fd5bcbd698a5
- Keep track of room name so correct name is displayed when you become room admin
unc0rr
parents:
7679
diff
changeset
|
2016 |
|
fd5bcbd698a5
- Keep track of room name so correct name is displayed when you become room admin
unc0rr
parents:
7679
diff
changeset
|
2017 |
ui.pageNetGame->setRoomName(hwnet->getRoom()); |
fd5bcbd698a5
- Keep track of room name so correct name is displayed when you become room admin
unc0rr
parents:
7679
diff
changeset
|
2018 |
|
8416
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2019 |
connect(ui.pageNetGame->BtnStart, SIGNAL(clicked()), this, SLOT(startGame())); |
7122
fa2d09868ac6
Fix reported in bug #327, comment #3 - untested but seems reasonable/safe.
nemo
parents:
7015
diff
changeset
|
2020 |
connect(ui.pageNetGame, SIGNAL(askForUpdateRoomName(const QString &)), hwnet, SLOT(updateRoomName(const QString &))); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2021 |
connect(ui.pageNetGame->restrictJoins, SIGNAL(triggered()), hwnet, SLOT(toggleRestrictJoins())); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2022 |
connect(ui.pageNetGame->restrictTeamAdds, SIGNAL(triggered()), hwnet, SLOT(toggleRestrictTeamAdds())); |
8559 | 2023 |
connect(ui.pageNetGame->restrictUnregistered, SIGNAL(triggered()), hwnet, SLOT(toggleRegisteredOnly())); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2024 |
connect(ui.pageNetGame->pGameCFG->GameSchemes->model(), |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2025 |
SIGNAL(dataChanged(const QModelIndex &, const QModelIndex &)), |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2026 |
ui.pageNetGame->pGameCFG, |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2027 |
SLOT(resendSchemeData()) |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
2028 |
); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2029 |
} |
1409
d1cbe4a57ebf
Add button for controlling room options (no usefull yet)
unc0rr
parents:
1405
diff
changeset
|
2030 |
} |
d1cbe4a57ebf
Add button for controlling room options (no usefull yet)
unc0rr
parents:
1405
diff
changeset
|
2031 |
|
d1cbe4a57ebf
Add button for controlling room options (no usefull yet)
unc0rr
parents:
1405
diff
changeset
|
2032 |
void HWForm::NetGameSlave() |
d1cbe4a57ebf
Add button for controlling room options (no usefull yet)
unc0rr
parents:
1405
diff
changeset
|
2033 |
{ |
8377 | 2034 |
ui.pageNetGame->pGameCFG->setMaster(false); |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2035 |
ui.pageNetGame->pNetTeamsWidget->setInteractivity(false); |
2377 | 2036 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2037 |
if (hwnet) |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2038 |
{ |
13197
0bc5f618ca7c
Rename the misleadingly-named AmmoSchemeModel to GameSchemeModel
Wuzzy <Wuzzy2@mail.ru>
parents:
13086
diff
changeset
|
2039 |
NetGameSchemeModel * netAmmo = new NetGameSchemeModel(hwnet); |
10721
9b789de8e5df
Workaround bug (each time losing room master status, even when joining mutliple rooms, new instance of NetAmmoSchemeModel created, receiving schemeConfig and modifying its 43rd member, thus the last model which accepts this signal has the string cut down several times, workaround creates copy of qstringlist to avoid modifying shared message instance. Proper fix would delete unneeded instances of NetAmmoSchemeModel, but who cares)
unc0rr
parents:
10392
diff
changeset
|
2040 |
connect(hwnet, SIGNAL(netSchemeConfig(QStringList)), netAmmo, SLOT(setNetSchemeConfig(QStringList))); |
8893
8f92e94d0b32
Don't set Default scheme/ammo when switching script if not room admin. Prevents game config desync.
unc0rr
parents:
8891
diff
changeset
|
2041 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2042 |
ui.pageNetGame->pGameCFG->GameSchemes->setModel(netAmmo); |
1899
5763f46d7486
Sync schemes config over net should work now (untested)
unc0rr
parents:
1898
diff
changeset
|
2043 |
|
8415
02acf6b92f52
Moved room name edit box from footer to top of page. Also shows room name when in slave mode.
dag10
parents:
8407
diff
changeset
|
2044 |
ui.pageNetGame->setRoomName(hwnet->getRoom()); |
02acf6b92f52
Moved room name edit box from footer to top of page. Also shows room name when in slave mode.
dag10
parents:
8407
diff
changeset
|
2045 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2046 |
ui.pageNetGame->pGameCFG->GameSchemes->view()->disconnect(hwnet); |
10801 | 2047 |
connect(hwnet, SIGNAL(netSchemeConfig(QStringList)), |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2048 |
this, SLOT(selectFirstNetScheme())); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2049 |
} |
1899
5763f46d7486
Sync schemes config over net should work now (untested)
unc0rr
parents:
1898
diff
changeset
|
2050 |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2051 |
ui.pageNetGame->setMasterMode(false); |
1409
d1cbe4a57ebf
Add button for controlling room options (no usefull yet)
unc0rr
parents:
1405
diff
changeset
|
2052 |
} |
1600 | 2053 |
|
9100 | 2054 |
void HWForm::FromNetProxySlot(const QByteArray & msg) |
2055 |
{ |
|
2056 |
if(game) |
|
2057 |
game->FromNet(msg); |
|
2058 |
||
2059 |
} |
|
2060 |
||
1899
5763f46d7486
Sync schemes config over net should work now (untested)
unc0rr
parents:
1898
diff
changeset
|
2061 |
void HWForm::selectFirstNetScheme() |
5763f46d7486
Sync schemes config over net should work now (untested)
unc0rr
parents:
1898
diff
changeset
|
2062 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2063 |
ui.pageNetGame->pGameCFG->GameSchemes->setCurrentIndex(0); |
1899
5763f46d7486
Sync schemes config over net should work now (untested)
unc0rr
parents:
1898
diff
changeset
|
2064 |
} |
5763f46d7486
Sync schemes config over net should work now (untested)
unc0rr
parents:
1898
diff
changeset
|
2065 |
|
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
2066 |
void HWForm::NetLeftRoom(const QString & reason) |
1600 | 2067 |
{ |
4433 | 2068 |
if (ui.Pages->currentIndex() == ID_PAGE_NETGAME || ui.Pages->currentIndex() == ID_PAGE_INGAME) |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
2069 |
{ |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2070 |
GoBack(); |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
2071 |
if (!reason.isEmpty()) |
6180
0992fc5a4ad9
some changes to the css... display:none; works now (e.g. you can use it for user join/leave messages that are not your friends)
sheepluva
parents:
6167
diff
changeset
|
2072 |
ui.pageRoomsList->displayNotice(reason); |
5998
e8f44e9433f0
many many netclient/frondent changes (just the beginning though):
sheepluva
parents:
5907
diff
changeset
|
2073 |
} |
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2074 |
else |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2075 |
qWarning("Left room while not in room"); |
1600 | 2076 |
} |
2012 | 2077 |
|
2078 |
void HWForm::resizeEvent(QResizeEvent * event) |
|
2079 |
{ |
|
2948
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2080 |
int w = event->size().width(); |
3f21a9dc93d0
Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents:
2874
diff
changeset
|
2081 |
int h = event->size().height(); |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
2082 |
if (wBackground) |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
2083 |
{ |
2098
c977d7f2aa09
Toggle for stars ("frontend effects") - also turns off optimisations for stars that were causing problems onone machine
nemo
parents:
2080
diff
changeset
|
2084 |
wBackground->setFixedSize(w, h); |
c977d7f2aa09
Toggle for stars ("frontend effects") - also turns off optimisations for stars that were causing problems onone machine
nemo
parents:
2080
diff
changeset
|
2085 |
wBackground->move(0, 0); |
c977d7f2aa09
Toggle for stars ("frontend effects") - also turns off optimisations for stars that were causing problems onone machine
nemo
parents:
2080
diff
changeset
|
2086 |
} |
2012 | 2087 |
} |
3760 | 2088 |
|
14462
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2089 |
void HWForm::UpdateTrainingPageTeam(int index) |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2090 |
{ |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2091 |
Q_UNUSED(index); |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2092 |
HWTeam team(ui.pageTraining->CBTeam->currentText()); |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2093 |
QString tName = team.name(); |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2094 |
|
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2095 |
QListWidget* listWidget; |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2096 |
for(int w = 0; w < 3; w++) |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2097 |
{ |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2098 |
switch(w) { |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2099 |
case 0: listWidget = ui.pageTraining->lstTrainings; break; |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2100 |
case 1: listWidget = ui.pageTraining->lstChallenges; break; |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2101 |
case 2: listWidget = ui.pageTraining->lstScenarios; break; |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2102 |
default: listWidget = ui.pageTraining->lstTrainings; break; |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2103 |
} |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2104 |
unsigned int n = listWidget->count(); |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2105 |
|
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2106 |
for(unsigned int i = 0; i < n; i++) |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2107 |
{ |
14468
41f1b611cdd2
Training page: Don't change selection after changing team or playing
Wuzzy <Wuzzy2@mail.ru>
parents:
14467
diff
changeset
|
2108 |
QListWidgetItem* item = listWidget->item(i); |
14462
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2109 |
QString missionName = QString(item->data(Qt::UserRole).toString()).replace(QString(" "),QString("_")); |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2110 |
if(isMissionWon(missionName, tName)) |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2111 |
item->setIcon(finishedIcon); |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2112 |
else |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2113 |
item->setIcon(notFinishedIcon); |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2114 |
} |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2115 |
} |
14525
029f40c609b4
Display team records in training menu
Wuzzy <Wuzzy2@mail.ru>
parents:
14509
diff
changeset
|
2116 |
ui.pageTraining->updateInfo(); |
14462
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2117 |
} |
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2118 |
|
7201
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2119 |
void HWForm::InitCampaignPage() |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2120 |
{ |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2121 |
ui.pageCampaign->CBCampaign->clear(); |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2122 |
HWTeam team(ui.pageCampaign->CBTeam->currentText()); |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2123 |
|
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2124 |
QStringList entries = DataManager::instance().entryList( |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2125 |
"Missions/Campaign", |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2126 |
QDir::Dirs, |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2127 |
QStringList("[^\\.]*") |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2128 |
); |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2129 |
|
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2130 |
unsigned int n = entries.count(); |
11948
6da9bb4b3449
Show check marks for campaigns with Won=true
Wuzzy <almikes@aol.com>
parents:
11865
diff
changeset
|
2131 |
|
7201
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2132 |
for(unsigned int i = 0; i < n; i++) |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2133 |
{ |
12305 | 2134 |
const QString & campaignName = entries[i]; |
11948
6da9bb4b3449
Show check marks for campaigns with Won=true
Wuzzy <almikes@aol.com>
parents:
11865
diff
changeset
|
2135 |
QString tName = team.name(); |
11957 | 2136 |
ui.pageCampaign->CBCampaign->addItem(getRealCampName(campaignName), campaignName); |
7201
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2137 |
} |
14470
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2138 |
|
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2139 |
} |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2140 |
|
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2141 |
void HWForm::RestoreSingleplayerTeamSelection() |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2142 |
{ |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2143 |
QString lastTeam = config->value("frontend/lastSingleplayerTeam", QString()).toString(); |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2144 |
if (!lastTeam.isNull() && !lastTeam.isEmpty()) |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2145 |
{ |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2146 |
int index = ui.pageCampaign->CBTeam->findData(lastTeam, Qt::DisplayRole); |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2147 |
if(index != -1) |
14509
64d73515abba
Initialize mission completion status on frontend load
Wuzzy <Wuzzy2@mail.ru>
parents:
14470
diff
changeset
|
2148 |
{ |
14470
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2149 |
ui.pageCampaign->CBTeam->setCurrentIndex(index); |
14509
64d73515abba
Initialize mission completion status on frontend load
Wuzzy <Wuzzy2@mail.ru>
parents:
14470
diff
changeset
|
2150 |
UpdateCampaignPageTeam(index); |
64d73515abba
Initialize mission completion status on frontend load
Wuzzy <Wuzzy2@mail.ru>
parents:
14470
diff
changeset
|
2151 |
} |
14470
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2152 |
index = ui.pageTraining->CBTeam->findData(lastTeam, Qt::DisplayRole); |
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2153 |
if(index != -1) |
14509
64d73515abba
Initialize mission completion status on frontend load
Wuzzy <Wuzzy2@mail.ru>
parents:
14470
diff
changeset
|
2154 |
{ |
14470
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2155 |
ui.pageTraining->CBTeam->setCurrentIndex(index); |
14509
64d73515abba
Initialize mission completion status on frontend load
Wuzzy <Wuzzy2@mail.ru>
parents:
14470
diff
changeset
|
2156 |
UpdateTrainingPageTeam(index); |
64d73515abba
Initialize mission completion status on frontend load
Wuzzy <Wuzzy2@mail.ru>
parents:
14470
diff
changeset
|
2157 |
} |
14470
6ab8335fe0a6
Save and restore last campaign/training team selection in settings.ini
Wuzzy <Wuzzy2@mail.ru>
parents:
14469
diff
changeset
|
2158 |
} |
7201
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2159 |
} |
dc17ffdf0702
The first campaign commit with a lot of changes...
belphegorr <szabibibi@gmail.com>
parents:
7122
diff
changeset
|
2160 |
|
3760 | 2161 |
void HWForm::UpdateCampaignPage(int index) |
2162 |
{ |
|
4560
5d6c7f88db73
- Some work on drawMap widget and scene to allow undo, clear, save and load operations
unc0rr
parents:
4536
diff
changeset
|
2163 |
Q_UNUSED(index); |
3760 | 2164 |
HWTeam team(ui.pageCampaign->CBTeam->currentText()); |
14602
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2165 |
QString campaignName = ui.pageCampaign->CBCampaign->currentData().toString(); |
10017 | 2166 |
QString tName = team.name(); |
2167 |
||
2168 |
campaignMissionInfo = getCampMissionList(campaignName,tName); |
|
2169 |
ui.pageCampaign->CBMission->clear(); |
|
2170 |
||
14602
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2171 |
// Populate mission list |
9292
187ce630dddc
y! code clean up :)
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9290
diff
changeset
|
2172 |
for(int i=0;i<campaignMissionInfo.size();i++) |
9182
f92e205bc167
issue 562, image and description for the campaign page
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9163
diff
changeset
|
2173 |
{ |
11958
de66192866d3
Make campaign mission names translatable
Wuzzy <almikes@aol.com>
parents:
11957
diff
changeset
|
2174 |
ui.pageCampaign->CBMission->addItem(QString(campaignMissionInfo[i].realName), QString(campaignMissionInfo[i].name)); |
14462
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2175 |
if(isCampMissionWon(campaignName, i, tName)) |
11951
b05db9ca6e1c
Add support for storing and displaying success of campaign missions
Wuzzy <almikes@aol.com>
parents:
11950
diff
changeset
|
2176 |
ui.pageCampaign->CBMission->setItemIcon(i, finishedIcon); |
b05db9ca6e1c
Add support for storing and displaying success of campaign missions
Wuzzy <almikes@aol.com>
parents:
11950
diff
changeset
|
2177 |
else |
11978
4a2da00bbedc
Align drop-down text of unfinished campaign missions with finished icons
Wuzzy <almikes@aol.com>
parents:
11968
diff
changeset
|
2178 |
ui.pageCampaign->CBMission->setItemIcon(i, notFinishedIcon); |
10017 | 2179 |
} |
14602
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2180 |
|
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2181 |
// Select first open mission |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2182 |
int missionIndex = ui.pageCampaign->CBMission->currentIndex(); |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2183 |
if(isCampMissionWon(campaignName, missionIndex, tName)) |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2184 |
{ |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2185 |
for(int m = 0; m < ui.pageCampaign->CBMission->count(); m++) |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2186 |
{ |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2187 |
if(!isCampMissionWon(campaignName, m, tName)) |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2188 |
{ |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2189 |
ui.pageCampaign->CBMission->setCurrentIndex(m); |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2190 |
break; |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2191 |
} |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2192 |
} |
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2193 |
} |
9182
f92e205bc167
issue 562, image and description for the campaign page
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9163
diff
changeset
|
2194 |
} |
f92e205bc167
issue 562, image and description for the campaign page
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9163
diff
changeset
|
2195 |
|
11950
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2196 |
void HWForm::UpdateCampaignPageTeam(int index) |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2197 |
{ |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2198 |
Q_UNUSED(index); |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2199 |
HWTeam team(ui.pageCampaign->CBTeam->currentText()); |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2200 |
QString tName = team.name(); |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2201 |
|
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2202 |
QStringList entries = DataManager::instance().entryList( |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2203 |
"Missions/Campaign", |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2204 |
QDir::Dirs, |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2205 |
QStringList("[^\\.]*") |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2206 |
); |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2207 |
|
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2208 |
unsigned int n = entries.count(); |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2209 |
|
14602
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2210 |
// Update campaign status |
11950
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2211 |
for(unsigned int i = 0; i < n; i++) |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2212 |
{ |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2213 |
QString campaignName = QString(entries[i]).replace(QString(" "),QString("_")); |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2214 |
if(isCampWon(campaignName, tName)) |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2215 |
ui.pageCampaign->CBCampaign->setItemIcon(i, finishedIcon); |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2216 |
else |
11978
4a2da00bbedc
Align drop-down text of unfinished campaign missions with finished icons
Wuzzy <almikes@aol.com>
parents:
11968
diff
changeset
|
2217 |
ui.pageCampaign->CBCampaign->setItemIcon(i, notFinishedIcon); |
11950
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2218 |
} |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2219 |
} |
3792a9f9fa9c
Update campaign victory status when changing selection
Wuzzy <almikes@aol.com>
parents:
11948
diff
changeset
|
2220 |
|
9219 | 2221 |
void HWForm::UpdateCampaignPageMission(int index) |
2222 |
{ |
|
9292
187ce630dddc
y! code clean up :)
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9290
diff
changeset
|
2223 |
// update thumbnail and description |
14602
14b295892fb7
Campaign: Try to auto-select an open mission after selecting team or campaign
Wuzzy <Wuzzy2@mail.ru>
parents:
14601
diff
changeset
|
2224 |
QString campaignName = ui.pageCampaign->CBCampaign->currentData().toString(); |
9182
f92e205bc167
issue 562, image and description for the campaign page
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9163
diff
changeset
|
2225 |
// when campaign changes the UpdateCampaignPageMission is triggered with wrong values |
f92e205bc167
issue 562, image and description for the campaign page
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9163
diff
changeset
|
2226 |
// this will cause segfault. This check prevents illegal memory reads |
9292
187ce630dddc
y! code clean up :)
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9290
diff
changeset
|
2227 |
if(index > -1 && index < campaignMissionInfo.count()) { |
9219 | 2228 |
ui.pageCampaign->lbltitle->setText("<h2>"+ui.pageCampaign->CBMission->currentText()+"</h2>"); |
9290
478aa681e702
this seems to work ok, but I have to clean up the code
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9288
diff
changeset
|
2229 |
ui.pageCampaign->lbldescription->setText(campaignMissionInfo[index].description); |
10017 | 2230 |
ui.pageCampaign->btnPreview->setIcon(QIcon(campaignMissionInfo[index].image)); |
9219 | 2231 |
} |
3760 | 2232 |
} |
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
2233 |
|
7490
c422845b8d1f
Fixed a typo, frontend is now working properly
belphegorr <szabibibi@gmail.com>
parents:
7411
diff
changeset
|
2234 |
void HWForm::UpdateCampaignPageProgress(int index) |
7245
53f73f4ae203
Modified frontend so that updating campaogn progress no longer changes current index of the mission combo box
belphegorr <szabibibi@gmail.com>
parents:
7207
diff
changeset
|
2235 |
{ |
14600
13b22e2f2010
Frontend: Don't reset campaign mission selection to top of list after each play
Wuzzy <Wuzzy2@mail.ru>
parents:
14525
diff
changeset
|
2236 |
QString missionTitle = ui.pageCampaign->CBMission->currentData().toString(); |
7679 | 2237 |
UpdateCampaignPage(0); |
14601
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2238 |
int missionIndex = 0; |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2239 |
// Restore selected mission (because UpdateCampaignPage repopulated the list) |
9641
b08c8bde57e3
fixes bug that doesn't display mission name in drop down list
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9482
diff
changeset
|
2240 |
for(int i=0;i<ui.pageCampaign->CBMission->count();i++) |
b08c8bde57e3
fixes bug that doesn't display mission name in drop down list
Periklis Ntanasis <pntanasis@gmail.com>
parents:
9482
diff
changeset
|
2241 |
{ |
14600
13b22e2f2010
Frontend: Don't reset campaign mission selection to top of list after each play
Wuzzy <Wuzzy2@mail.ru>
parents:
14525
diff
changeset
|
2242 |
if (ui.pageCampaign->CBMission->itemData(i).toString() == missionTitle) |
10017 | 2243 |
{ |
14601
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2244 |
missionIndex = i; |
10017 | 2245 |
break; |
2246 |
} |
|
2247 |
} |
|
14601
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2248 |
|
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2249 |
// Get metadata |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2250 |
int c = ui.pageCampaign->CBCampaign->currentIndex(); |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2251 |
QString campaignName = ui.pageCampaign->CBCampaign->itemData(c).toString(); |
11955
d72a177dbaea
Update campaign drop-down list after campaign victory
Wuzzy <almikes@aol.com>
parents:
11951
diff
changeset
|
2252 |
HWTeam team(ui.pageCampaign->CBTeam->currentText()); |
d72a177dbaea
Update campaign drop-down list after campaign victory
Wuzzy <almikes@aol.com>
parents:
11951
diff
changeset
|
2253 |
QString tName = team.name(); |
14601
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2254 |
|
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2255 |
if(index == gsFinished) |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2256 |
{ |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2257 |
// Select new mission when current mission went from |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2258 |
// unfinished to finished. |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2259 |
if(ui.pageCampaign->currentMissionWon == false && |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2260 |
isCampMissionWon(campaignName, missionIndex, tName)) |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2261 |
{ |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2262 |
// Traverse all missions and pick first mission that |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2263 |
// has not been won. |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2264 |
bool selected = false; |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2265 |
// start from mission that comes after the selected one |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2266 |
for(int m = missionIndex-1; m >= 0;m--) |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2267 |
{ |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2268 |
if(!isCampMissionWon(campaignName, m, tName)) |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2269 |
{ |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2270 |
missionIndex = m; |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2271 |
selected = true; |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2272 |
break; |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2273 |
} |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2274 |
} |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2275 |
// No mission selected? Let's try again from the end of the list |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2276 |
if(!selected) |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2277 |
{ |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2278 |
for(int m = ui.pageCampaign->CBMission->count()-1; m > missionIndex-1; m--) |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2279 |
{ |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2280 |
if(!isCampMissionWon(campaignName, m, tName)) |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2281 |
{ |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2282 |
missionIndex = m; |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2283 |
break; |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2284 |
} |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2285 |
} |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2286 |
} |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2287 |
// If no mission was selected, the old selection remains unchanged. |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2288 |
} |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2289 |
} |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2290 |
else if(index == gsStarted) |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2291 |
{ |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2292 |
// Remember the "won" state of current mission before we start it. |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2293 |
// We'll need it when the game has finished. |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2294 |
ui.pageCampaign->currentMissionWon = isCampMissionWon(campaignName, missionIndex, tName); |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2295 |
} |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2296 |
|
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2297 |
ui.pageCampaign->CBMission->setCurrentIndex(missionIndex); |
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2298 |
|
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2299 |
// Update campaign victory status |
11955
d72a177dbaea
Update campaign drop-down list after campaign victory
Wuzzy <almikes@aol.com>
parents:
11951
diff
changeset
|
2300 |
if(isCampWon(campaignName, tName)) |
14601
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2301 |
ui.pageCampaign->CBCampaign->setItemIcon(c, finishedIcon); |
11955
d72a177dbaea
Update campaign drop-down list after campaign victory
Wuzzy <almikes@aol.com>
parents:
11951
diff
changeset
|
2302 |
else |
14601
1d3f8cf48831
Campaign: Select next unfinished mission after completing one
Wuzzy <Wuzzy2@mail.ru>
parents:
14600
diff
changeset
|
2303 |
ui.pageCampaign->CBCampaign->setItemIcon(c, notFinishedIcon); |
3760 | 2304 |
} |
3932 | 2305 |
|
5213
a86768368309
make the associate button use the user's settings for loading demos/saves
nemo
parents:
5205
diff
changeset
|
2306 |
QString HWForm::getDemoArguments() |
a86768368309
make the associate button use the user's settings for loading demos/saves
nemo
parents:
5205
diff
changeset
|
2307 |
{ |
8307 | 2308 |
|
8643 | 2309 |
QString prefix = "\"" + datadir->absolutePath() + "\""; |
2310 |
QString userPrefix = "\"" + cfgdir->absolutePath() + "\""; |
|
9163
67334acaaac7
port all Q_WS_* to Q_OS_* so that we are forward compatible with Qt5
koda
parents:
9100
diff
changeset
|
2311 |
#ifdef Q_OS_WIN |
8307 | 2312 |
prefix = prefix.replace("/","\\"); |
2313 |
userPrefix = userPrefix.replace("/","\\"); |
|
8302
a7934cd12469
improve engine cmd line parsing and its documentation
RowanD
parents:
8299
diff
changeset
|
2314 |
#endif |
a7934cd12469
improve engine cmd line parsing and its documentation
RowanD
parents:
8299
diff
changeset
|
2315 |
|
8354
c25bee85d6f8
Separated fullscreen and windowed hwengine resolution parameters.
vitiv <nikita.utiu@gmail.com>
parents:
8346
diff
changeset
|
2316 |
std::pair<QRect, QRect> resolutions = config->vid_ResolutionPair(); |
8307 | 2317 |
return QString("--prefix " + prefix |
2318 |
+ " --user-prefix " + userPrefix |
|
8354
c25bee85d6f8
Separated fullscreen and windowed hwengine resolution parameters.
vitiv <nikita.utiu@gmail.com>
parents:
8346
diff
changeset
|
2319 |
+ " --fullscreen-width " + QString::number(resolutions.first.width()) |
c25bee85d6f8
Separated fullscreen and windowed hwengine resolution parameters.
vitiv <nikita.utiu@gmail.com>
parents:
8346
diff
changeset
|
2320 |
+ " --fullscreen-height " + QString::number(resolutions.first.height()) |
c25bee85d6f8
Separated fullscreen and windowed hwengine resolution parameters.
vitiv <nikita.utiu@gmail.com>
parents:
8346
diff
changeset
|
2321 |
+ " --width " + QString::number(resolutions.second.width()) |
c25bee85d6f8
Separated fullscreen and windowed hwengine resolution parameters.
vitiv <nikita.utiu@gmail.com>
parents:
8346
diff
changeset
|
2322 |
+ " --height " + QString::number(resolutions.second.height()) |
15299
3bf780084c86
Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents:
15278
diff
changeset
|
2323 |
+ (config->vid_Maximized() ? " --maximized" : "") |
14677
93429d8f6b3f
Add setting to set default/initial zoom
Wuzzy <Wuzzy2@mail.ru>
parents:
14670
diff
changeset
|
2324 |
+ (config->zoom() == 100 ? "" : " --zoom " + QString::number(config->zoom())) |
8302
a7934cd12469
improve engine cmd line parsing and its documentation
RowanD
parents:
8299
diff
changeset
|
2325 |
+ " --volume " + QString::number(config->volume()) |
a7934cd12469
improve engine cmd line parsing and its documentation
RowanD
parents:
8299
diff
changeset
|
2326 |
+ (config->isMusicEnabled() ? "" : " --nomusic") |
a7934cd12469
improve engine cmd line parsing and its documentation
RowanD
parents:
8299
diff
changeset
|
2327 |
+ (config->isSoundEnabled() ? "" : " --nosound") |
13628
d5e029b84e16
Add setting to disable audio dampening if losing window focus
Wuzzy <Wuzzy2@mail.ru>
parents:
13505
diff
changeset
|
2328 |
+ (config->isAudioDampenEnabled() ? "" : " --nodampen") |
8302
a7934cd12469
improve engine cmd line parsing and its documentation
RowanD
parents:
8299
diff
changeset
|
2329 |
+ " --locale " + config->language() + ".txt" |
a7934cd12469
improve engine cmd line parsing and its documentation
RowanD
parents:
8299
diff
changeset
|
2330 |
+ (config->vid_Fullscreen() ? " --fullscreen" : "") |
a7934cd12469
improve engine cmd line parsing and its documentation
RowanD
parents:
8299
diff
changeset
|
2331 |
+ (config->isShowFPSEnabled() ? " --showfps" : "") |
a7934cd12469
improve engine cmd line parsing and its documentation
RowanD
parents:
8299
diff
changeset
|
2332 |
+ (config->isAltDamageEnabled() ? " --altdmg" : "") |
a7934cd12469
improve engine cmd line parsing and its documentation
RowanD
parents:
8299
diff
changeset
|
2333 |
+ " --frame-interval " + QString::number(config->timerInterval()) |
9249 | 2334 |
+ " --raw-quality " + QString::number(config->translateQuality())) |
2335 |
+ (!config->Form->ui.pageOptions->CBTeamTag->isChecked() ? " --no-teamtag" : "") |
|
2336 |
+ (!config->Form->ui.pageOptions->CBHogTag->isChecked() ? " --no-hogtag" : "") |
|
2337 |
+ (!config->Form->ui.pageOptions->CBHealthTag->isChecked() ? " --no-healthtag" : "") |
|
14670
56831f466d1d
Add settings.ini setting and hwengine param to disable holiday silliness (hat changes, etc.)
Wuzzy <Wuzzy2@mail.ru>
parents:
14646
diff
changeset
|
2338 |
+ (config->Form->ui.pageOptions->CBTagOpacity->isChecked() ? " --translucent-tags" : "") |
56831f466d1d
Add settings.ini setting and hwengine param to disable holiday silliness (hat changes, etc.)
Wuzzy <Wuzzy2@mail.ru>
parents:
14646
diff
changeset
|
2339 |
+ (!config->isHolidaySillinessEnabled() ? " --no-holiday-silliness" : ""); |
5213
a86768368309
make the associate button use the user's settings for loading demos/saves
nemo
parents:
5205
diff
changeset
|
2340 |
} |
a86768368309
make the associate button use the user's settings for loading demos/saves
nemo
parents:
5205
diff
changeset
|
2341 |
|
3932 | 2342 |
void HWForm::AssociateFiles() |
2343 |
{ |
|
4084
0d0bf0533eee
Add opendesktop association of files for non-windows. NEEDS TESTING.
nemo
parents:
3940
diff
changeset
|
2344 |
bool success = true; |
5222 | 2345 |
QString arguments = getDemoArguments(); |
4084
0d0bf0533eee
Add opendesktop association of files for non-windows. NEEDS TESTING.
nemo
parents:
3940
diff
changeset
|
2346 |
#ifdef _WIN32 |
3932 | 2347 |
QSettings registry_hkcr("HKEY_CLASSES_ROOT", QSettings::NativeFormat); |
8722
2dead6b84bca
this should supposedly add hwplay:// schemes to windows, after user presses file association
koda
parents:
8720
diff
changeset
|
2348 |
|
2dead6b84bca
this should supposedly add hwplay:// schemes to windows, after user presses file association
koda
parents:
8720
diff
changeset
|
2349 |
// file extension(s) |
3932 | 2350 |
registry_hkcr.setValue(".hwd/Default", "Hedgewars.Demo"); |
2351 |
registry_hkcr.setValue(".hws/Default", "Hedgewars.Save"); |
|
2352 |
registry_hkcr.setValue("Hedgewars.Demo/Default", tr("Hedgewars Demo File", "File Types")); |
|
2353 |
registry_hkcr.setValue("Hedgewars.Save/Default", tr("Hedgewars Save File", "File Types")); |
|
2354 |
registry_hkcr.setValue("Hedgewars.Demo/DefaultIcon/Default", "\"" + bindir->absolutePath().replace("/", "\\") + "\\hwdfile.ico\",0"); |
|
2355 |
registry_hkcr.setValue("Hedgewars.Save/DefaultIcon/Default", "\"" + bindir->absolutePath().replace("/", "\\") + "\\hwsfile.ico\",0"); |
|
8643 | 2356 |
registry_hkcr.setValue("Hedgewars.Demo/Shell/Open/Command/Default", "\"" + bindir->absolutePath().replace("/", "\\") + "\\hwengine.exe\" " + arguments + " %1"); |
2357 |
registry_hkcr.setValue("Hedgewars.Save/Shell/Open/Command/Default", "\"" + bindir->absolutePath().replace("/", "\\") + "\\hwengine.exe\" " + arguments + " %1"); |
|
8722
2dead6b84bca
this should supposedly add hwplay:// schemes to windows, after user presses file association
koda
parents:
8720
diff
changeset
|
2358 |
|
2dead6b84bca
this should supposedly add hwplay:// schemes to windows, after user presses file association
koda
parents:
8720
diff
changeset
|
2359 |
// custom url scheme(s) |
8766
ce153d705fff
scheme association for linux (although it stops during connection)
koda
parents:
8722
diff
changeset
|
2360 |
registry_hkcr.setValue("hwplay/Default", "\"URL:Hedgewars ServerAccess Scheme\""); |
8722
2dead6b84bca
this should supposedly add hwplay:// schemes to windows, after user presses file association
koda
parents:
8720
diff
changeset
|
2361 |
registry_hkcr.setValue("hwplay/URL Protocol", ""); |
2dead6b84bca
this should supposedly add hwplay:// schemes to windows, after user presses file association
koda
parents:
8720
diff
changeset
|
2362 |
registry_hkcr.setValue("hwplay/DefaultIcon/Default", "\"" + bindir->absolutePath().replace("/", "\\") + "\\hedgewars.exe\",0"); |
2dead6b84bca
this should supposedly add hwplay:// schemes to windows, after user presses file association
koda
parents:
8720
diff
changeset
|
2363 |
registry_hkcr.setValue("hwplay/Shell/Open/Command/Default", "\"" + bindir->absolutePath().replace("/", "\\") + "\\hedgewars.exe\" %1"); |
4090 | 2364 |
#elif defined __APPLE__ |
5252 | 2365 |
// only useful when other apps have taken precedence over our file extensions and you want to reset it |
2366 |
system("defaults write com.apple.LaunchServices LSHandlers -array-add '<dict><key>LSHandlerContentTag</key><string>hwd</string><key>LSHandlerContentTagClass</key><string>public.filename-extension</string><key>LSHandlerRoleAll</key><string>org.hedgewars.desktop</string></dict>'"); |
|
2367 |
system("defaults write com.apple.LaunchServices LSHandlers -array-add '<dict><key>LSHandlerContentTag</key><string>hws</string><key>LSHandlerContentTagClass</key><string>public.filename-extension</string><key>LSHandlerRoleAll</key><string>org.hedgewars.desktop</string></dict>'"); |
|
2368 |
system("/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/LaunchServices.framework/Versions/A/Support/lsregister -kill -domain local -domain system -domain user"); |
|
4084
0d0bf0533eee
Add opendesktop association of files for non-windows. NEEDS TESTING.
nemo
parents:
3940
diff
changeset
|
2369 |
#else |
4091
f89b8d0afbe1
set as default type, add icon. going to assume the icon was installed already. should happen in most packaging out there.
nemo
parents:
4090
diff
changeset
|
2370 |
// this is a little silly due to all the system commands below anyway - just use mkdir -p ? Does have the advantage of the alert I guess |
4085 | 2371 |
if (success) success = checkForDir(QDir::home().absolutePath() + "/.local"); |
2372 |
if (success) success = checkForDir(QDir::home().absolutePath() + "/.local/share"); |
|
2373 |
if (success) success = checkForDir(QDir::home().absolutePath() + "/.local/share/mime"); |
|
4084
0d0bf0533eee
Add opendesktop association of files for non-windows. NEEDS TESTING.
nemo
parents:
3940
diff
changeset
|
2374 |
if (success) success = checkForDir(QDir::home().absolutePath() + "/.local/share/mime/packages"); |
4085 | 2375 |
if (success) success = checkForDir(QDir::home().absolutePath() + "/.local"); |
2376 |
if (success) success = checkForDir(QDir::home().absolutePath() + "/.local/share"); |
|
4084
0d0bf0533eee
Add opendesktop association of files for non-windows. NEEDS TESTING.
nemo
parents:
3940
diff
changeset
|
2377 |
if (success) success = checkForDir(QDir::home().absolutePath() + "/.local/share/applications"); |
0d0bf0533eee
Add opendesktop association of files for non-windows. NEEDS TESTING.
nemo
parents:
3940
diff
changeset
|
2378 |
if (success) success = system(("cp "+datadir->absolutePath()+"/misc/hedgewars-mimeinfo.xml "+QDir::home().absolutePath()+"/.local/share/mime/packages").toLocal8Bit().constData())==0; |
8766
ce153d705fff
scheme association for linux (although it stops during connection)
koda
parents:
8722
diff
changeset
|
2379 |
if (success) success = system(("cp "+datadir->absolutePath()+"/misc/hedgewars.desktop "+QDir::home().absolutePath()+"/.local/share/applications").toLocal8Bit().constData())==0; |
4084
0d0bf0533eee
Add opendesktop association of files for non-windows. NEEDS TESTING.
nemo
parents:
3940
diff
changeset
|
2380 |
if (success) success = system(("cp "+datadir->absolutePath()+"/misc/hwengine.desktop "+QDir::home().absolutePath()+"/.local/share/applications").toLocal8Bit().constData())==0; |
0d0bf0533eee
Add opendesktop association of files for non-windows. NEEDS TESTING.
nemo
parents:
3940
diff
changeset
|
2381 |
if (success) success = system(("update-mime-database "+QDir::home().absolutePath()+"/.local/share/mime").toLocal8Bit().constData())==0; |
8766
ce153d705fff
scheme association for linux (although it stops during connection)
koda
parents:
8722
diff
changeset
|
2382 |
if (success) success = system("xdg-mime default hedgewars.desktop x-scheme-handler/hwplay")==0; |
4091
f89b8d0afbe1
set as default type, add icon. going to assume the icon was installed already. should happen in most packaging out there.
nemo
parents:
4090
diff
changeset
|
2383 |
if (success) success = system("xdg-mime default hwengine.desktop application/x-hedgewars-demo")==0; |
f89b8d0afbe1
set as default type, add icon. going to assume the icon was installed already. should happen in most packaging out there.
nemo
parents:
4090
diff
changeset
|
2384 |
if (success) success = system("xdg-mime default hwengine.desktop application/x-hedgewars-save")==0; |
5238
46ddaf14509d
Enable ~/.hedgewars/Data (or platform equivalent) to override/extend pretty much everything in system Data dir. Obviously desyncing can occur, so this is at user's own risk. Should simplify map etc install. Needs testing.
nemo
parents:
5222
diff
changeset
|
2385 |
// hack to add user's settings to hwengine. might be better at this point to read in the file, append it, and write it out to its new home. This assumes no spaces in the data dir path |
8639 | 2386 |
if (success) success = system(("sed -i 's|^\\(Exec=.*\\) \\(%f\\)|\\1 \\2 "+arguments+"|' "+QDir::home().absolutePath()+"/.local/share/applications/hwengine.desktop").toLocal8Bit().constData())==0; |
4084
0d0bf0533eee
Add opendesktop association of files for non-windows. NEEDS TESTING.
nemo
parents:
3940
diff
changeset
|
2387 |
#endif |
7794
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
2388 |
if (success) |
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
2389 |
{ |
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
2390 |
QMessageBox infoMsg(this); |
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
2391 |
infoMsg.setIcon(QMessageBox::Information); |
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
2392 |
infoMsg.setWindowTitle(QMessageBox::tr("Hedgewars - Success")); |
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
2393 |
infoMsg.setText(QMessageBox::tr("All file associations have been set")); |
14836
b9437746bffb
Frontend: Force plain text mode for many message windows
Wuzzy <Wuzzy2@mail.ru>
parents:
14810
diff
changeset
|
2394 |
infoMsg.setTextFormat(Qt::PlainText); |
7794
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
2395 |
infoMsg.setWindowModality(Qt::WindowModal); |
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
2396 |
infoMsg.exec(); |
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
2397 |
} |
ab7b94c03bc9
QMessageBox overhaul: unify buttons, style and appearance of info dialogs, fixing a few typos and return values along the way
koda
parents:
7792
diff
changeset
|
2398 |
else |
8383 | 2399 |
MessageDialog::ShowErrorMessage(QMessageBox::tr("File association failed."), this); |
3932 | 2400 |
} |
3937 | 2401 |
|
8434 | 2402 |
void HWForm::openRegistrationPage() |
8364
fbc9bcc6c39d
Added "New account" button when connectiong to the official server
vitiv <nikita.utiu@gmail.com>
parents:
8357
diff
changeset
|
2403 |
{ |
11830 | 2404 |
QDesktopServices::openUrl(QUrl("https://www.hedgewars.org/user/register")); |
8434 | 2405 |
} |
8364
fbc9bcc6c39d
Added "New account" button when connectiong to the official server
vitiv <nikita.utiu@gmail.com>
parents:
8357
diff
changeset
|
2406 |
|
5734 | 2407 |
void HWForm::saveDemoWithCustomName() |
2408 |
{ |
|
2409 |
if(!m_lastDemo.isEmpty()) |
|
2410 |
{ |
|
2411 |
QString fileName; |
|
2412 |
bool ok = false; |
|
2413 |
do |
|
2414 |
{ |
|
2415 |
fileName = QInputDialog::getText(this, tr("Demo name"), tr("Demo name:")); |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
2416 |
|
5734 | 2417 |
if(!fileName.isEmpty()) |
2418 |
{ |
|
2419 |
QString filePath = cfgdir->absolutePath() + "/Demos/" + fileName + "." + *cProtoVer + ".hwd"; |
|
2420 |
QFile demofile(filePath); |
|
2421 |
ok = demofile.open(QIODevice::WriteOnly); |
|
2422 |
if (!ok) |
|
8383 | 2423 |
MessageDialog::ShowErrorMessage(tr("Cannot save record to file %1").arg(filePath), this); |
5734 | 2424 |
else |
2425 |
{ |
|
2426 |
ok = -1 != demofile.write(m_lastDemo); |
|
2427 |
demofile.close(); |
|
2428 |
} |
|
2429 |
} |
|
6616
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
2430 |
} |
f77bb02b669f
astyle -C -S -L -N --style=allman --recursive "QTfrontend/*.cpp" "QTfrontend/*.h"
nemo
parents:
6604
diff
changeset
|
2431 |
while(!fileName.isEmpty() && !ok); |
5734 | 2432 |
} |
5746
fbc52bb92cad
Use QTextBrowser instead of WebKit for downloadable contents page (currently only shows the page itself)
unc0rr
parents:
5734
diff
changeset
|
2433 |
} |
fbc52bb92cad
Use QTextBrowser instead of WebKit for downloadable contents page (currently only shows the page itself)
unc0rr
parents:
5734
diff
changeset
|
2434 |
|
8901
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2435 |
void HWForm::restartGame() |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2436 |
{ |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2437 |
// get rid off old game stats page |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2438 |
if(ui.Pages->currentIndex() == ID_PAGE_GAMESTATS) |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2439 |
GoBack(); |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2440 |
|
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2441 |
CreateGame(lastGameCfg, lastGameTeamSel, lastGameAmmo); |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2442 |
|
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2443 |
switch(lastGameType) { |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2444 |
case gtTraining: |
14462
4c743ef80b1b
Add team selection in training page and basic check mark support
Wuzzy <Wuzzy2@mail.ru>
parents:
13846
diff
changeset
|
2445 |
game->StartTraining(lastGameStartArgs.at(0).toString(), lastGameStartArgs.at(1).toString(), lastGameStartArgs.at(2).toString()); |
8901
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2446 |
break; |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2447 |
case gtQLocal: |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2448 |
game->StartQuick(); |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2449 |
break; |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2450 |
case gtCampaign: |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2451 |
game->StartCampaign(lastGameStartArgs.at(0).toString(), lastGameStartArgs.at(1).toString(), lastGameStartArgs.at(2).toString()); |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2452 |
break; |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2453 |
case gtLocal: |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2454 |
game->StartLocal(); |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2455 |
break; |
15276
d111a0d9d499
Enable "replay" button after playing a demo or saved game
Wuzzy <Wuzzy2@mail.ru>
parents:
15193
diff
changeset
|
2456 |
case gtDemo: |
d111a0d9d499
Enable "replay" button after playing a demo or saved game
Wuzzy <Wuzzy2@mail.ru>
parents:
15193
diff
changeset
|
2457 |
case gtSave: |
d111a0d9d499
Enable "replay" button after playing a demo or saved game
Wuzzy <Wuzzy2@mail.ru>
parents:
15193
diff
changeset
|
2458 |
PlayDemo(); |
d111a0d9d499
Enable "replay" button after playing a demo or saved game
Wuzzy <Wuzzy2@mail.ru>
parents:
15193
diff
changeset
|
2459 |
break; |
8901
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2460 |
default: |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2461 |
break; |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2462 |
} |
505307b9735d
implementation of a restart-game button. location and appearance is not final :P
thunderstruck
parents:
8893
diff
changeset
|
2463 |
} |
6561 | 2464 |
|
10307
e13d3147f15b
do not get stuck on "in game..." page just because of game crash. output a message instead. could still need some tweaking, but a man gotta sleep. and sheep too...
sheepluva
parents:
10108
diff
changeset
|
2465 |
void HWForm::ShowFatalErrorMessage(const QString & msg) |
8383 | 2466 |
{ |
10307
e13d3147f15b
do not get stuck on "in game..." page just because of game crash. output a message instead. could still need some tweaking, but a man gotta sleep. and sheep too...
sheepluva
parents:
10108
diff
changeset
|
2467 |
MessageDialog::ShowFatalMessage(msg, this); |
8383 | 2468 |
} |
8385
9e8924ff9813
Convert feedback page to dialog (+some fixes from unC0Rr)
dag10
parents:
8384
diff
changeset
|
2469 |
|
9e8924ff9813
Convert feedback page to dialog (+some fixes from unC0Rr)
dag10
parents:
8384
diff
changeset
|
2470 |
void HWForm::showFeedbackDialog() |
9e8924ff9813
Convert feedback page to dialog (+some fixes from unC0Rr)
dag10
parents:
8384
diff
changeset
|
2471 |
{ |
11830 | 2472 |
QNetworkRequest newRequest(QUrl("https://www.hedgewars.org")); |
8878 | 2473 |
|
2474 |
QNetworkAccessManager *manager = new QNetworkAccessManager(this); |
|
2475 |
QNetworkReply *reply = manager->get(newRequest); |
|
2476 |
connect(reply, SIGNAL(finished()), this, SLOT(showFeedbackDialogNetChecked())); |
|
2477 |
} |
|
2478 |
||
2479 |
void HWForm::showFeedbackDialogNetChecked() |
|
2480 |
{ |
|
2481 |
QNetworkReply *reply = qobject_cast<QNetworkReply *>(sender()); |
|
2482 |
||
12674
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2483 |
if (reply) { |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2484 |
switch (reply->error()) { |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2485 |
case QNetworkReply::NoError: |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2486 |
{ |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2487 |
FeedbackDialog dialog(this); |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2488 |
dialog.exec(); |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2489 |
} |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2490 |
break; |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2491 |
case QNetworkReply::UnknownNetworkError: |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2492 |
MessageDialog::ShowFatalMessage( |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2493 |
tr("Unknown network error (possibly missing SSL library)."), this); |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2494 |
break; |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2495 |
default: |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2496 |
MessageDialog::ShowFatalMessage( |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2497 |
QString(tr("This feature requires an Internet connection, but you don't appear to be online (error code: %1).")).arg(reply->error()), this); |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2498 |
break; |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2499 |
} |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2500 |
} |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2501 |
else { |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2502 |
MessageDialog::ShowFatalMessage(tr("Internal error: Reply object is invalid."), this); |
8d266b2d0f9c
Improve error messages when feedback or DLC fail to reach Internet
alfadur
parents:
12667
diff
changeset
|
2503 |
} |
8385
9e8924ff9813
Convert feedback page to dialog (+some fixes from unC0Rr)
dag10
parents:
8384
diff
changeset
|
2504 |
} |
8416
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2505 |
|
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2506 |
void HWForm::startGame() |
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2507 |
{ |
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2508 |
QMessageBox questionMsg(this); |
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2509 |
questionMsg.setIcon(QMessageBox::Question); |
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2510 |
questionMsg.setWindowTitle(QMessageBox::tr("Not all players are ready")); |
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2511 |
questionMsg.setText(QMessageBox::tr("Are you sure you want to start this game?\nNot all players are ready.")); |
14836
b9437746bffb
Frontend: Force plain text mode for many message windows
Wuzzy <Wuzzy2@mail.ru>
parents:
14810
diff
changeset
|
2512 |
questionMsg.setTextFormat(Qt::PlainText); |
8416
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2513 |
questionMsg.setWindowModality(Qt::WindowModal); |
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2514 |
questionMsg.addButton(QMessageBox::Yes); |
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2515 |
questionMsg.addButton(QMessageBox::Cancel); |
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2516 |
|
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2517 |
if (hwnet->allPlayersReady() || questionMsg.exec() == QMessageBox::Yes) |
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2518 |
hwnet->startGame(); |
e691acd778f5
It is now possible to start a game even if not all players are "ready"; a confirmation prompt is shown. This commit updates the server.
dag10
parents:
8415
diff
changeset
|
2519 |
} |