// September 2015 // Levee Patroller / Dijk Patrouille // This source file is (c) by Deltares. This source file is open source but only available to select users. Do not redistribute without written permission of Stichting Deltares, Delft, The Netherlands. // This header has been automatically generated. //============================================================================= // In game menu for filling in the questions associated with // Horizontal movement (horizontale verplaatsing) // Started from MenuObservationReport. // ------------------------------------------------------------ // Created by Maarten van Zomeren // Template by Maarten Wesselius // © 2006, GeoDelft //============================================================================= class MenuHorizontalMovement extends MenuSignalQuestions dependsOn(GeoPlayerController); function InitComponent(GUIController MyController, GUIComponent MyOwner) { GeoPC=GeoPlayerController(MyController.ViewportOwner.Actor); if(GeoPC!=None) UpdateLanguage(); else log("ERROR WITH TYPE OF GAME"); InitializeHashTable(); InitializeStringData(); Super.InitComponent(MyController, MyOwner); InitializeCheckedness(); if(GeoPC.ReportingMode == MODE_CreatingNewObservation || GeoPC.ReportingMode == MODE_EditingFirstReport) { // nothing special to be done } else { InitLaterReport(); } } function InitLaterReport() { local moCheckBox Q1A1, Q1A2; Q1A1 = moCheckBox(Controls[HashTable.getValue("Q1A1")]); Q1A2 = moCheckBox(Controls[HashTable.getValue("Q1A2")]); // put the right caption in the answers, telling the user that this is what they filled in before if(GeoPC.Dutch) { Q1A1.MyLabel.Caption = NL_ChosenBefore $ Q1A1.MyLabel.Caption; Q1A2.MyLabel.Caption = NL_ChosenBefore $ Q1A2.MyLabel.Caption; } else { Q1A1.MyLabel.Caption = EN_ChosenBefore $ Q1A1.MyLabel.Caption; Q1A2.MyLabel.Caption = EN_ChosenBefore $ Q1A2.MyLabel.Caption; } Q1A1.WinWidth = getAnswerWidthValue(Q1A1.myLabel.Caption); Q1A2.WinWidth = getAnswerWidthValue(Q1A2.myLabel.Caption); //Check which answer of question 1 is true if(Q1A1.IsChecked()) { //the first answer of question 1 is true; show only this answer, without checkbox Q1A1.MyCheckBox.SetVisibility(false); Q1A2.SetVisibility(false); } else { //the second answer of question 1 is true; show only this answer, without checkbox Q1A2.MyCheckBox.SetVisibility(false); Q1A1.SetVisibility(false); Q1A2.WinLeft = Q1A1.WinLeft; } } function InitializeHashTable() { // FUNCTIONALITY: initialize the hashtable with the keys (which should be "Q1", "Q1A1", // "Q2", "Q2A3", etc.) and its corresponding values (the index in the controls-array). HashTable = New class'QAHashTable'; HashTable.add("Q1", 7); HashTable.add("Q1A1", 8); HashTable.add("Q1A2", 9); HashTable.add("Q2", 10); HashTable.add("Q2A1", 11); HashTable.add("Q2A2", 12); HashTable.add("Q2A3", 13); HashTable.add("Q2A4", 14); HashTable.add("Q2A5", 15); HashTable.add("Q2A6", 16); HashTable.add("Q3", 17); HashTable.add("Q3A1", 18); HashTable.add("Q3A2", 19); HashTable.add("Q3A3", 20); HashTable.add("Q3A4", 21); HashTable.add("Q3A5", 22); HashTable.add("Q3A6", 23); } function InitializeStringData() { local Signal.GeoSignalTypes TypeThis; TypeThis = SIG_HorizontalMovement; if (!GeoPC.IsDroogte()) { DataObject = new class'SignalStringData'; }else { DataObject = new class'SignalStringDataDroogte'; } NrQuestions = DataObject.GetNrQuestions(TypeThis); EN_QuestionStrings = DataObject.GetQuestionStrings(TypeThis, false); NL_QuestionStrings = DataObject.GetQuestionStrings(TypeThis, true); EN_AnswerStrings = DataObject.GetAnswerStrings(TypeThis, false); NL_AnswerStrings = DataObject.GetAnswerStrings(TypeThis, true); } function InitializeCheckedness() { // FUNCTIONALITY: load values from GeoPC.NewSignal and set answerButtons checkedness accordingly local SignalHorizontalMovement theSignal; local SignalReportHorizontalMovement theSignalReport; local moCheckBox Q1A1, Q1A2, Q2A1, Q2A2, Q2A3, Q2A4, Q2A5, Q2A6, Q3A1, Q3A2, Q3A3, Q3A4, Q3A5, Q3A6; Q1A1 = moCheckBox(Controls[HashTable.getValue("Q1A1")]); Q1A2 = moCheckBox(Controls[HashTable.getValue("Q1A2")]); Q2A1 = moCheckBox(Controls[HashTable.getValue("Q2A1")]); Q2A2 = moCheckBox(Controls[HashTable.getValue("Q2A2")]); Q2A3 = moCheckBox(Controls[HashTable.getValue("Q2A3")]); Q2A4 = moCheckBox(Controls[HashTable.getValue("Q2A4")]); Q2A5 = moCheckBox(Controls[HashTable.getValue("Q2A5")]); Q2A6 = moCheckBox(Controls[HashTable.getValue("Q2A6")]); Q3A1 = moCheckBox(Controls[HashTable.getValue("Q3A1")]); Q3A2 = moCheckBox(Controls[HashTable.getValue("Q3A2")]); Q3A3 = moCheckBox(Controls[HashTable.getValue("Q3A3")]); Q3A4 = moCheckBox(Controls[HashTable.getValue("Q3A4")]); Q3A5 = moCheckBox(Controls[HashTable.getValue("Q3A5")]); Q3A6 = moCheckBox(Controls[HashTable.getValue("Q3A6")]); theSignal = SignalHorizontalMovement(GeoPC.NewSignal); // get signal properties that are independent of the state of the failure // QUESTION 1 if(theSignal.RevetmentType == REV_Grass) Q1A1.Checked(true); else if(theSignal.RevetmentType == REV_Asphalt) Q1A2.Checked(true); if(theSignal.SignalReports.length > 0) { // get signal properties that are dependent of the state of the failure theSignalReport = SignalReportHorizontalMovement(theSignal.SignalReports[theSignal.SignalReports.length-1]); // QUESTION 2 if(theSignalReport.LengthOfDamage == SIZE_VerySmall) Q2A1.Checked(true); else if(theSignalReport.LengthOfDamage == SIZE_Small) Q2A2.Checked(true); else if(theSignalReport.LengthOfDamage == SIZE_Medium) Q2A3.Checked(true); else if(theSignalReport.LengthOfDamage == SIZE_MediumLarge) Q2A4.Checked(true); else if(theSignalReport.LengthOfDamage == SIZE_Large) Q2A5.Checked(true); else if(theSignalReport.LengthOfDamage == SIZE_VeryLarge) Q2A6.Checked(true); // QUESTION 3 if(theSignalReport.WidthOfDamage == SIZE_VerySmall) Q3A1.Checked(true); else if(theSignalReport.WidthOfDamage == SIZE_Small) Q3A2.Checked(true); else if(theSignalReport.WidthOfDamage == SIZE_Medium) Q3A3.Checked(true); else if(theSignalReport.WidthOfDamage == SIZE_MediumLarge) Q3A4.Checked(true); else if(theSignalReport.WidthOfDamage == SIZE_Large) Q3A5.Checked(true); else if(theSignalReport.WidthOfDamage == SIZE_VeryLarge) Q3A6.Checked(true); } } function storeAnswerValues() { // FUNCTIONALITY: look at current values in answers and save it in GeoPC.NewSignal local SignalHorizontalMovement theSignal; // set to GeoPC.NewSignal, working variable for the Signal answers local SignalHorizontalMovement OriginalSignal; // the original report made, to check for changes in observations local SignalReportHorizontalMovement tempSignalReport; // temporary working SignalReport for the SignalReport answers local moCheckBox Q1A1, Q1A2, Q2A1, Q2A2, Q2A3, Q2A4, Q2A5, Q2A6, Q3A1, Q3A2, Q3A3, Q3A4, Q3A5, Q3A6; local bool bObservationsChanged; // if answers are different from original answers for this report // (only used when in editing mode) local int tmp; // this one is not really used, but it has to be there as // parameter to SignalReport's isEqual bObservationsChanged = false; Q1A1 = moCheckBox(Controls[HashTable.getValue("Q1A1")]); Q1A2 = moCheckBox(Controls[HashTable.getValue("Q1A2")]); Q2A1 = moCheckBox(Controls[HashTable.getValue("Q2A1")]); Q2A2 = moCheckBox(Controls[HashTable.getValue("Q2A2")]); Q2A3 = moCheckBox(Controls[HashTable.getValue("Q2A3")]); Q2A4 = moCheckBox(Controls[HashTable.getValue("Q2A4")]); Q2A5 = moCheckBox(Controls[HashTable.getValue("Q2A5")]); Q2A6 = moCheckBox(Controls[HashTable.getValue("Q2A6")]); Q3A1 = moCheckBox(Controls[HashTable.getValue("Q3A1")]); Q3A2 = moCheckBox(Controls[HashTable.getValue("Q3A2")]); Q3A3 = moCheckBox(Controls[HashTable.getValue("Q3A3")]); Q3A4 = moCheckBox(Controls[HashTable.getValue("Q3A4")]); Q3A5 = moCheckBox(Controls[HashTable.getValue("Q3A5")]); Q3A6 = moCheckBox(Controls[HashTable.getValue("Q3A6")]); theSignal = SignalHorizontalMovement(GeoPC.NewSignal.Duplicate()); // create a SignalReport for this Signal and set the failure state at this time tempSignalReport = new class'SignalReportHorizontalMovement'; // set Signal properties (that are independent of the state of the failure) // QUESTION 1 if(Q1A1.isChecked()) theSignal.RevetmentType = REV_Grass; else if(Q1A2.isChecked()) theSignal.RevetmentType = REV_Asphalt; // set SignalReport properties (that are dependent of the failure state) // QUESTION 2 if(Q2A1.isChecked()) tempSignalReport.LengthOfDamage = SIZE_VerySmall; else if(Q2A2.isChecked()) tempSignalReport.LengthOfDamage = SIZE_Small; else if(Q2A3.isChecked()) tempSignalReport.LengthOfDamage = SIZE_Medium; else if(Q2A4.isChecked()) tempSignalReport.LengthOfDamage = SIZE_MediumLarge; else if(Q2A5.isChecked()) tempSignalReport.LengthOfDamage = SIZE_Large; else if(Q2A6.isChecked()) tempSignalReport.LengthOfDamage = SIZE_VeryLarge; // QUESTION 3 if(Q3A1.isChecked()) tempSignalReport.WidthOfDamage = SIZE_VerySmall; else if(Q3A2.isChecked()) tempSignalReport.WidthOfDamage = SIZE_Small; else if(Q3A3.isChecked()) tempSignalReport.WidthOfDamage = SIZE_Medium; else if(Q3A4.isChecked()) tempSignalReport.WidthOfDamage = SIZE_MediumLarge; else if(Q3A5.isChecked()) tempSignalReport.WidthOfDamage = SIZE_Large; else if(Q3A6.isChecked()) tempSignalReport.WidthOfDamage = SIZE_VeryLarge; // now check if observations have changed (only applicable in editing mode) if(GeoPC.ReportingMode == MODE_EditingFirstReport || GeoPC.ReportingMode == MODE_EditingLaterReport) { // if there is already an original, use it to get the answers // from last time, in order to see if any changes were made regarding the original. OriginalSignal = SignalHorizontalMovement(GeoPC.NearbyMarker.SignalOriginals[GeoPC.EditIndex]); if(OriginalSignal.RevetmentType != theSignal.RevetmentType) bObservationsChanged = true; // for the SignalReport-answers, IsEqual() is used to check for changes if(!tempSignalReport.IsEqual(OriginalSignal.SignalReports[OriginalSignal.SignalReports.length - 1], 0.95,tmp,tmp)) bObservationsChanged = true; // bChanged reflects if any changes were made regarding the original report tempSignalReport.bChanged = bObservationsChanged; } SaveAnswers(theSignal, tempSignalReport); } defaultproperties { // Controls 6 to 31 are the labels for the questions, and the buttons for the possible answers // common properties of all answer buttons // QUESTION 1 Controls(7)=GUILabel'QuestionLabel' Controls(8)=moCheckBox'AnswerButton' Controls(9)=moCheckBox'AnswerButton' // QUESTION 2 Controls(10)=GUILabel'QuestionLabel' Controls(11)=moCheckBox'AnswerButton' Controls(12)=moCheckBox'AnswerButton' Controls(13)=moCheckBox'AnswerButton' Controls(14)=moCheckBox'AnswerButton' Controls(15)=moCheckBox'AnswerButton' Controls(16)=moCheckBox'AnswerButton' // QUESTION 3 Controls(17)=GUILabel'QuestionLabel' Controls(18)=moCheckBox'AnswerButton' Controls(19)=moCheckBox'AnswerButton' Controls(20)=moCheckBox'AnswerButton' Controls(21)=moCheckBox'AnswerButton' Controls(22)=moCheckBox'AnswerButton' Controls(23)=moCheckBox'AnswerButton' MenuWidth=0.9 MenuHeight=0.55 // override standard values of superclass here! EN_Title = "Observation report for horizontal movement" NL_Title = "Observatie rapport voor horizontale verplaatsing" HelpMenuOption=4 }