aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--Game/Code/Classes/UIni.pas11
-rw-r--r--Game/Code/Classes/UPartyM2.pas20
-rw-r--r--Game/Code/Screens/UScreenPartyOptionsM2.pas4
3 files changed, 35 insertions, 0 deletions
diff --git a/Game/Code/Classes/UIni.pas b/Game/Code/Classes/UIni.pas
index 5228d870..0cfea5ce 100644
--- a/Game/Code/Classes/UIni.pas
+++ b/Game/Code/Classes/UIni.pas
@@ -82,6 +82,7 @@ type
LineBonus: integer;
PartyPopup: integer;
SumPlayers: integer;
+ DuelRatio: integer;
// Controller
Joypad: integer;
@@ -181,6 +182,7 @@ const
ILineBonus: array[0..2] of string = ('Off', 'At Score', 'At Notes');
IPartyPopup: array[0..1] of string = ('Off', 'On');
ISumPlayers: array[0..2] of string = ('Never', 'Dynamic', 'Always');
+ IDuelRatio: array[0..9] of string = ('normal', '10%', '20%', '30%', '40%', '50%', '60%', '70%', '80%', '90%');
IJoypad: array[0..1] of string = ('Off', 'On');
ILPT: array[0..2] of string = ('Off', 'LCD', 'Lights');
@@ -610,6 +612,11 @@ begin
for Pet := 0 to High(ISumPlayers) do
if Tekst = ISumPlayers[Pet] then Ini.SumPlayers := Pet;
+ // DuelRatio
+ Tekst := IniFile.ReadString('Advanced', 'DuelRatio', IDuelRatio[0]);
+ for Pet := 0 to High(IDuelRatio) do
+ if Tekst = IDuelRatio[Pet] then Ini.DuelRatio := Pet;
+
// Joypad
Tekst := IniFile.ReadString('Controller', 'Joypad', IJoypad[0]);
for Pet := 0 to High(IJoypad) do
@@ -844,6 +851,10 @@ begin
Tekst := ISumPlayers[Ini.SumPlayers];
IniFile.WriteString('Advanced', 'SumPlayers', Tekst);
+ //DuelRatio
+ Tekst := IDuelRatio[Ini.DuelRatio];
+ IniFile.WriteString('Advanced', 'DuelRatio', Tekst);
+
// Joypad
Tekst := IJoypad[Ini.Joypad];
IniFile.WriteString('Controller', 'Joypad', Tekst);
diff --git a/Game/Code/Classes/UPartyM2.pas b/Game/Code/Classes/UPartyM2.pas
index ccf3bf7f..8c572610 100644
--- a/Game/Code/Classes/UPartyM2.pas
+++ b/Game/Code/Classes/UPartyM2.pas
@@ -62,6 +62,7 @@ type
Teams: TTeamInfo;
Order: PlayerOrderArray;
Option_Plugins: boolean;
+ ID_DUELL: Byte;
constructor Create;
procedure GenScores;
@@ -86,6 +87,7 @@ uses
UGraphic,
ULanguage,
UMain,
+ UIni,
Math,
ULog;
@@ -261,6 +263,7 @@ var
max_played: integer;
max_flag: boolean;
must_sing: integer;
+ DuelRatioFactor: integer;
//debug
rn: array of TRN;
@@ -445,6 +448,23 @@ begin
//Set rounds
if (Length(Plugins) >= 1) then
begin
+ //set DuelRatioFactor
+ DuelRatioFactor := Round((Ini.DuelRatio*Length(Plugins)-10)/(10-Ini.DuelRatio));
+
+ for I := 0 to Length(Plugins) - 1 do
+ begin
+ if (Plugins[I].ID = ID_DUELL) and
+ not Plugins[I].Medley and not Plugins[I].MedleySurprise then
+ begin
+ for K := 1 to DuelRatioFactor do
+ begin
+ len := Length(Plugins);
+ SetLength(Plugins, len+1);
+ Plugins[len] := Plugins[I];
+ end;
+ end;
+ end;
+
for I := 0 to NumRounds - 1 do
begin
SetLength (Rounds, I+1);
diff --git a/Game/Code/Screens/UScreenPartyOptionsM2.pas b/Game/Code/Screens/UScreenPartyOptionsM2.pas
index 7a8f5f2b..17c6560e 100644
--- a/Game/Code/Screens/UScreenPartyOptionsM2.pas
+++ b/Game/Code/Screens/UScreenPartyOptionsM2.pas
@@ -196,6 +196,8 @@ begin
else
PlaylistMan.CurPlayList := Playlist2;
+ PartySessionM2.ID_DUELL := ID_DUELL;
+
//Start Party
PartySessionM2.StartNewParty(NumPlayer+2, Rounds+1);
@@ -386,6 +388,8 @@ begin
else
PlaylistMan.CurPlayList := Playlist2;
+ PartySessionM2.ID_DUELL := ID_DUELL;
+
//Start Party
PartySessionM2.StartNewParty(NumPlayer+2, Rounds+1);