// 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 // Grass Revetment (zet- en stortsteen) // Started from MenuObservationReport. // ------------------------------------------------------------ // Created by Maarten van Zomeren // Template by Maarten Wesselius // © 2006, GeoDelft //============================================================================= class MenuGrass 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(); } 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("Q1A3", 10); HashTable.add("Q1A4", 11); HashTable.add("Q1A5", 12); HashTable.add("Q1A6", 13); HashTable.add("Q2", 14); HashTable.add("Q2A1", 15); HashTable.add("Q2A2", 16); HashTable.add("Q2A3", 17); HashTable.add("Q2A4", 18); HashTable.add("Q2A5", 19); HashTable.add("Q2A6", 20); /*HashTable.add("Q3", 20); HashTable.add("Q3A1", 21); HashTable.add("Q3A2", 22); HashTable.add("Q3A3", 23); HashTable.add("Q3A4", 24); HashTable.add("Q3A5", 25); HashTable.add("Q3A6", 26);*/ } function InitializeStringData() { local Signal.GeoSignalTypes TypeThis; TypeThis = SIG_GrassRevetment; 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 SignalGrass theSignal; local SignalReportGrass theSignalReport; local moCheckBox Q1A1, Q1A2, Q1A3, Q1A4, Q1A5, Q1A6, Q2A1, Q2A2, Q2A3, Q2A4, Q2A5, Q2A6/*, Q3A1, Q3A2, Q3A3, Q3A4, Q3A5, Q3A6*/; Q1A1 = moCheckBox(Controls[HashTable.getValue("Q1A1")]); Q1A2 = moCheckBox(Controls[HashTable.getValue("Q1A2")]); Q1A3 = moCheckBox(Controls[HashTable.getValue("Q1A3")]); Q1A4 = moCheckBox(Controls[HashTable.getValue("Q1A4")]); Q1A5 = moCheckBox(Controls[HashTable.getValue("Q1A5")]); Q1A6 = moCheckBox(Controls[HashTable.getValue("Q1A6")]); 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 = SignalGrass(GeoPC.NewSignal); if(theSignal.SignalReports.length > 0) { // get signal properties that are dependent of the state of the failure theSignalReport = SignalReportGrass(theSignal.SignalReports[theSignal.SignalReports.length-1]); // QUESTION 1 if(theSignalReport.LengthOfDamage == SIZE_VerySmall) Q1A1.Checked(true); else if(theSignalReport.LengthOfDamage == SIZE_Small) Q1A2.Checked(true); else if(theSignalReport.LengthOfDamage == SIZE_Medium) Q1A3.Checked(true); else if(theSignalReport.LengthOfDamage == SIZE_MediumLarge) Q1A4.Checked(true); else if(theSignalReport.LengthOfDamage == SIZE_Large) Q1A5.Checked(true); else if(theSignalReport.LengthOfDamage == SIZE_VeryLarge) Q1A6.Checked(true); // QUESTION 2 if(theSignalReport.WidthOfDamage == SIZE_VerySmall) Q2A1.Checked(true); else if(theSignalReport.WidthOfDamage == SIZE_Small) Q2A2.Checked(true); else if(theSignalReport.WidthOfDamage == SIZE_Medium) Q2A3.Checked(true); else if(theSignalReport.WidthOfDamage == SIZE_MediumLarge) Q2A4.Checked(true); else if(theSignalReport.WidthOfDamage == SIZE_Large) Q2A5.Checked(true); else if(theSignalReport.WidthOfDamage == SIZE_VeryLarge) Q2A6.Checked(true); /* QUESTION 3 if(theSignalReport.DepthOfDamage == SIZE_VerySmall) Q3A1.Checked(true); else if(theSignalReport.DepthOfDamage == SIZE_Small) Q3A2.Checked(true); else if(theSignalReport.DepthOfDamage == SIZE_Medium) Q3A3.Checked(true); else if(theSignalReport.DepthOfDamage == SIZE_MediumLarge) Q3A4.Checked(true); else if(theSignalReport.DepthOfDamage == SIZE_Large) Q3A5.Checked(true); else if(theSignalReport.DepthOfDamage == SIZE_VeryLarge) Q3A6.Checked(true); */ } } function storeAnswerValues() { // FUNCTIONALITY: look at current values in answers and save it in GeoPC.NewSignal local SignalGrass theSignal; // set to GeoPC.NewSignal, working variable for the Signal answers local SignalGrass OriginalSignal; // the original report made, to check for changes in observations local SignalReportGrass tempSignalReport; // temporary working SignalReport for the SignalReport answers local moCheckBox Q1A1, Q1A2, Q1A3, Q1A4, Q1A5, Q1A6, Q2A1, Q2A2, Q2A3, Q2A4, Q2A5, Q2A6; 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")]); Q1A3 = moCheckBox(Controls[HashTable.getValue("Q1A3")]); Q1A4 = moCheckBox(Controls[HashTable.getValue("Q1A4")]); Q1A5 = moCheckBox(Controls[HashTable.getValue("Q1A5")]); Q1A6 = moCheckBox(Controls[HashTable.getValue("Q1A6")]); 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")]); theSignal = SignalGrass(GeoPC.NewSignal.Duplicate()); // create a SignalReport for this Signal tempSignalReport = new class'SignalReportGrass'; // set SignalReport properties (that are dependent of the failure state) // QUESTION 1 if(Q1A1.isChecked()) tempSignalReport.LengthOfDamage = SIZE_VerySmall; else if(Q1A2.isChecked()) tempSignalReport.LengthOfDamage = SIZE_Small; else if(Q1A3.isChecked()) tempSignalReport.LengthOfDamage = SIZE_Medium; else if(Q1A4.isChecked()) tempSignalReport.LengthOfDamage = SIZE_MediumLarge; else if(Q1A5.isChecked()) tempSignalReport.LengthOfDamage = SIZE_Large; else if(Q1A6.isChecked()) tempSignalReport.LengthOfDamage = SIZE_VeryLarge; // QUESTION 2 if(Q2A1.isChecked()) tempSignalReport.WidthOfDamage = SIZE_VerySmall; else if(Q2A2.isChecked()) tempSignalReport.WidthOfDamage = SIZE_Small; else if(Q2A3.isChecked()) tempSignalReport.WidthOfDamage = SIZE_Medium; else if(Q2A4.isChecked()) tempSignalReport.WidthOfDamage = SIZE_MediumLarge; else if(Q2A5.isChecked()) tempSignalReport.WidthOfDamage = SIZE_Large; else if(Q2A6.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 = SignalGrass(GeoPC.NearbyMarker.SignalOriginals[GeoPC.EditIndex]); // 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' Controls(10)=moCheckBox'AnswerButton' Controls(11)=moCheckBox'AnswerButton' Controls(12)=moCheckBox'AnswerButton' Controls(13)=moCheckBox'AnswerButton' // QUESTION 2 Controls(14)=GUILabel'QuestionLabel' Controls(15)=moCheckBox'AnswerButton' Controls(16)=moCheckBox'AnswerButton' Controls(17)=moCheckBox'AnswerButton' Controls(18)=moCheckBox'AnswerButton' Controls(19)=moCheckBox'AnswerButton' Controls(20)=moCheckBox'AnswerButton' // QUESTION 3 //Controls(20)=GUILabel'QuestionLabel' //Controls(21)=moCheckBox'AnswerButton' //Controls(22)=moCheckBox'AnswerButton' //Controls(23)=moCheckBox'AnswerButton' //Controls(24)=moCheckBox'AnswerButton' //Controls(25)=moCheckBox'AnswerButton' //Controls(26)=moCheckBox'AnswerButton' MenuWidth=0.85 MenuHeight=0.55 // override standard values of superclass here! EN_Title = "Observation report for grass revetment" NL_Title = "Observatie rapport voor grasbekleding" HelpMenuOption=2 }