2 Copyright 2007 Chris Tallon
4 This file is part of VOMP.
6 VOMP is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 VOMP is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with VOMP; if not, write to the Free Software
18 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
29 #include "woptionpane.h"
30 #include "wremoteconfig.h"
36 #ifdef VOMP_PLATTFORM_MVP
37 #include "mediaoptions.h"
40 //#include "command.h"
45 setTitleBarColour(DrawStyle::TITLEBARBACKGROUND);
46 setTitleText(tr("Options"));
51 if (Video::getInstance()->getFormat() == Video::PAL)
52 setPosition(100, 110);
56 tabbar.setPosition(6, 32);
57 tabbar.setSize(getWidth() - 12, getHeight() - 34);
63 // --- edit options start here
65 static const char* options1[] = {"Old", "New"};
67 static const char* options5[] = {"Chop sides", "Letterbox"};
68 static const char* options6[] = {"On", "Off", "Last state"};
69 static const char* options7[] = {"All", "FTA only"};
70 static const char* options15[] = {"Alphabetical", "Chronological"};
72 static const char* options13[] = {"Auto","1024", "2048", "4096", "8192", "16384", "32768", "65536"};
73 static const char* options14[] = {"No", "Yes"};
74 // Get list of languages from VDR and construct options table
75 LangCode = VDR::getInstance()->getLanguageList();
76 options2 = new const char*[LangCode.size()];
77 options2keys = new const char*[LangCode.size()];
78 I18n::lang_code_list::const_iterator iter;
80 for (iter = LangCode.begin(); iter != LangCode.end(); ++iter,++LangNumber)
82 options2[LangNumber] = iter->second.c_str();
83 options2keys[LangNumber] = iter->first.c_str();
87 panes = new Boxx*[numPanes];
89 wop = new WOptionPane();
90 tabbar.addTab(tr("General"), wop);
92 #ifdef MVP_REMOTE_TYPES
93 option = new Option(1, "Remote control type", "General", "Remote type", Option::TYPE_TEXT, 2, 0, 0, options1);
94 options.push_back(option);
95 wop->addOptionLine(option);
97 option = new Option(2, "Language", "General", "LangCode", Option::TYPE_KEYED_TEXT, LangCode.size(), 0, 0, options2, options2keys);
98 options.push_back(option);
99 wop->addOptionLine(option);
102 UINT suppconn = Video::getInstance()->getSupportedFormats();
105 if (suppconn & Video::COMPOSITERGB) {
107 options3.push_back("RGB+composite");
108 options3keys.push_back("RGB+composite");
110 if (Video::SVIDEO & suppconn) {
111 options3.push_back("S-Video");
112 options3keys.push_back("S-Video");
114 if (Video::HDMI & suppconn) {
115 defaultch = options3.size();
116 options3.push_back("HDMI");
117 options3keys.push_back("HDMI");
119 if (Video::HDMI3D & suppconn) {
120 options3.push_back("HDMI3D");
121 options3keys.push_back("HDMI3D");
123 option = new Option(3, "TV connection type", "TV", "Connection",
124 Option::TYPE_KEYED_TEXT, options3.size(), defaultch, 0,
125 &(options3[0]), &(options3keys[0]));
127 options.push_back(option);
128 wop->addOptionLine(option);
131 UINT suppformats = Video::getInstance()->supportedTVFormats();
134 options16.push_back("NTSC");
135 options16keys.push_back("NTSC");
136 if (suppformats & Video::PAL) {
138 options16.push_back("PAL");
139 options16keys.push_back("PAL");
141 if (Video::NTSC_J & suppformats) {
142 options16.push_back("NTSC-J");
143 options16keys.push_back("NTSC-J");
145 if (Video::PAL_M & suppformats) {
146 options16.push_back("PAL-M");
147 options16keys.push_back("PAL-M");
150 option = new Option(16, "TV standard (needs restart)", "General", "Override Video Format",
151 Option::TYPE_KEYED_TEXT, options16.size(), defaultch, 0,
152 &(options16[0]), &(options16keys[0]));
154 options.push_back(option);
155 wop->addOptionLine(option);
158 UINT supptvsize=Video::getInstance()->supportedTVsize();
161 options4.push_back("4:3");
162 options4keys.push_back("4:3");
163 if (Video::ASPECT16X9 & supptvsize) {
164 options4.push_back("16:9");
165 options4keys.push_back("16:9");
168 if (Video::ASPECT14X9 & supptvsize) {
169 options4.push_back("14:9");
170 options4keys.push_back("14:9");
172 option = new Option(4, "TV aspect ratio", "TV", "Aspect",
173 Option::TYPE_KEYED_TEXT, options4.size(), defaultch, 0,
174 &(options4[0]), &(options4keys[0]));
175 options.push_back(option);
176 wop->addOptionLine(option);
179 option = new Option(5, "16:9 on 4:3 display mode", "TV", "Widemode", Option::TYPE_TEXT, 2, 0, 0, options5);
180 options.push_back(option);
181 wop->addOptionLine(option);
182 option = new Option(6, "Power state after bootup", "General", "Power After Boot", Option::TYPE_TEXT, 3, 0, 0, options6);
183 options.push_back(option);
184 wop->addOptionLine(option);
185 option = new Option(7, "Display channels", "General", "Channels", Option::TYPE_TEXT, 2, 0, 0, options7);
186 options.push_back(option);
187 wop->addOptionLine(option);
188 option = new Option(15, "Recordings sort order", "General", "Recordings Sort Order", Option::TYPE_TEXT, 2, 0, 0, options15);
189 options.push_back(option);
190 wop->addOptionLine(option);
192 Remote::getInstance()->addOptionsToPanes(0,&options,wop);
193 Video::getInstance()->addOptionsToPanes(0,&options,wop);
194 Audio::getInstance()->addOptionsToPanes(0,&options,wop);
197 /* WRemoteConfig* wrc = new WRemoteConfig();
198 tabbar.addTab(tr("Remote Control"), wrc);*/
199 Remote::getInstance()->addOptionPagesToWTB(&tabbar);
202 Video::getInstance()->addOptionPagesToWTB(&tabbar);
203 Audio::getInstance()->addOptionPagesToWTB(&tabbar);
204 #ifdef VOMP_PLATTFORM_MVP
205 MediaOptions::getInstance()->addOptionPagesToWTB(&tabbar);
209 wop = new WOptionPane();
210 tabbar.addTab(tr("Timers"), wop);
213 option = new Option(9, "Default start margin (minutes)", "Timers", "Start margin", Option::TYPE_INT, 20, 5, 0, NULL);
214 options.push_back(option);
215 wop->addOptionLine(option);
216 option = new Option(10, "Default end margin (minutes)", "Timers", "End margin", Option::TYPE_INT, 20, 5, 0, NULL);
217 options.push_back(option);
218 wop->addOptionLine(option);
219 option = new Option(11, "Default priority", "Timers", "Priority", Option::TYPE_INT, 100, 99, 0, NULL);
220 options.push_back(option);
221 wop->addOptionLine(option);
222 option = new Option(12, "Default lifetime", "Timers", "Lifetime", Option::TYPE_INT, 100, 99, 0, NULL);
223 options.push_back(option);
224 wop->addOptionLine(option);
226 Remote::getInstance()->addOptionsToPanes(1,&options,wop);
227 Video::getInstance()->addOptionsToPanes(1,&options,wop);
228 Audio::getInstance()->addOptionsToPanes(1,&options,wop);
231 wop = new WOptionPane();
232 tabbar.addTab(tr("Advanced"), wop);
235 option = new Option(8, "VDR-Pri 0=OK !See forums!", "General", "Live priority", Option::TYPE_INT, 199, -1, -99, NULL);
236 options.push_back(option);
237 wop->addOptionLine(option);
238 option = new Option(13, "TCP receive window size", "Advanced", "TCP receive window", Option::TYPE_TEXT, 8, /*1*/DEFAULT_TCP_WINDOWSIZENR, 0, options13);
239 options.push_back(option);
240 wop->addOptionLine(option);
242 option = new Option(14, "Use WSS (PAL only)", "General", "WSS", Option::TYPE_TEXT, 2, 0, 0, options14);
243 options.push_back(option);
244 wop->addOptionLine(option);
246 const char * * fontnames;
247 const char * * fontnames_keys;
248 int numfonts=Osd::getInstance()->getFontNames(&fontnames,&fontnames_keys);
250 option = new Option(17, "Font Name", "Advanced", "Font Name", Option::TYPE_KEYED_TEXT, numfonts, 1, 0, fontnames,fontnames_keys);
251 options.push_back(option);
252 wop->addOptionLine(option);
255 Remote::getInstance()->addOptionsToPanes(2,&options,wop);
256 Video::getInstance()->addOptionsToPanes(2,&options,wop);
257 Audio::getInstance()->addOptionsToPanes(2,&options,wop);
262 // for (int i = 0; i < numPanes; i++) delete panes[i]; //Move to TabBar, Marten
265 for(vector<Option*>::iterator j = options.begin(); j != options.end(); j++) delete *j;
267 delete[] options2keys;
270 int VOpts::handleCommand(int command)
272 // either is active, handle back
273 if (command == Remote::BACK)
280 int retval = tabbar.handleCommand(command);
283 BoxStack::getInstance()->update(this);
286 else if (retval == 2)
288 // command was taken and actively ignored
300 VDR* vdr = VDR::getInstance();
302 Remote::getInstance()->saveOptionstoServer(); //Remote
303 Video::getInstance()->saveOptionstoServer(); //Video
304 Audio::getInstance()->saveOptionstoServer(); //Remote
305 #ifdef VOMP_PLATTFORM_MVP
306 MediaOptions::getInstance()->saveOptionstoServer(); //Media
309 // Damn, and the dynamic idea was going *so* well...
310 //Whats about a check with typeid operator?
312 wop = (WOptionPane*)panes[0];
314 wop = (WOptionPane*)panes[1];
316 wop = (WOptionPane*)panes[2];
320 for (UINT i = 0; i < options.size(); i++)
322 if (options[i]->configChoice == options[i]->userSetChoice) continue; // no change
324 Log::getInstance()->log("Options", Log::DEBUG, "Option %i has changed", i);
328 if (options[i]->optionType == Option::TYPE_TEXT)
330 vdr->configSave(options[i]->configSection, options[i]->configKey, options[i]->options[options[i]->userSetChoice]);
332 else if (options[i]->optionType == Option::TYPE_KEYED_TEXT)
334 vdr->configSave(options[i]->configSection, options[i]->configKey, options[i]->optionkeys[options[i]->userSetChoice]);
339 sprintf(buffer, "%i", options[i]->userSetChoice);
340 vdr->configSave(options[i]->configSection, options[i]->configKey, buffer);
344 if (options[i]->opthandler == NULL) //Ok, noone else is handling this, we are doing it
346 switch(options[i]->id)
350 #ifdef MVP_REMOTE_TYPES
351 if (options[i]->userSetChoice == 1)
353 Log::getInstance()->log("Options", Log::DEBUG, "Setting New Remote");
354 Remote::getInstance()->setRemoteType(Remote::NEWREMOTE);
358 Log::getInstance()->log("Options", Log::DEBUG, "Setting Old Remote");
359 Remote::getInstance()->setRemoteType(Remote::OLDREMOTE);
366 Message* m = new Message();
367 m->message = Message::CHANGE_LANGUAGE;
368 m->to = Command::getInstance();
369 Command::getInstance()->postMessageNoLock(m);
374 if (STRCASECMP(options[i]->optionkeys[options[i]->userSetChoice], "RGB+composite")==0)
376 Log::getInstance()->log("Options", Log::DEBUG, "Setting RGB/Composite");
377 Video::getInstance()->setConnection(Video::COMPOSITERGB);
379 else if (STRCASECMP(options[i]->optionkeys[options[i]->userSetChoice], "S-Video")==0)
381 Log::getInstance()->log("Options", Log::DEBUG, "Setting S-Video");
382 Video::getInstance()->setConnection(Video::SVIDEO);
384 else if (STRCASECMP(options[i]->optionkeys[options[i]->userSetChoice], "HDMI")==0)
386 Log::getInstance()->log("Options", Log::DEBUG, "Setting HDMI");
387 Video::getInstance()->setConnection(Video::HDMI);
389 else if (STRCASECMP(options[i]->optionkeys[options[i]->userSetChoice], "HDMI3D")==0)
391 Log::getInstance()->log("Options", Log::DEBUG, "Setting HDMI");
392 Video::getInstance()->setConnection(Video::HDMI3D);
398 if (STRCASECMP(options[i]->optionkeys[options[i]->userSetChoice], "16:9")==0)
400 Log::getInstance()->log("Options", Log::DEBUG, "Setting 16:9 TV");
401 Video::getInstance()->setTVsize(Video::ASPECT16X9);
403 else if (STRCASECMP(options[i]->optionkeys[options[i]->userSetChoice], "4:3")==0)
405 Log::getInstance()->log("Options", Log::DEBUG, "Setting 4:3 TV");
406 Video::getInstance()->setTVsize(Video::ASPECT4X3);
408 else if (STRCASECMP(options[i]->optionkeys[options[i]->userSetChoice], "14:9")==0)
410 Log::getInstance()->log("Options", Log::DEBUG, "Setting 14:9 TV");
411 Video::getInstance()->setTVsize(Video::ASPECT14X9);
417 if (options[i]->userSetChoice == 1)
419 Log::getInstance()->log("Options", Log::DEBUG, "Setting letterbox");
420 Video::getInstance()->setMode(Video::LETTERBOX);
424 Log::getInstance()->log("Options", Log::DEBUG, "Setting chop-sides");
425 Video::getInstance()->setMode(Video::NORMAL);
431 size_t newTCPsize = 2048;
432 if (options[i]->userSetChoice == 0) newTCPsize = 0; //zero means auto
433 else if (options[i]->userSetChoice == 1) newTCPsize = 1024;
434 else if (options[i]->userSetChoice == 2) newTCPsize = 2048;
435 else if (options[i]->userSetChoice == 3) newTCPsize = 4096;
436 else if (options[i]->userSetChoice == 4) newTCPsize = 8192;
437 else if (options[i]->userSetChoice == 5) newTCPsize = 16384;
438 else if (options[i]->userSetChoice == 6) newTCPsize = 32768;
439 else if (options[i]->userSetChoice == 7) newTCPsize = 65536;
440 Log::getInstance()->log("Options", Log::DEBUG, "Setting TCP window size %i", newTCPsize);
441 VDR::getInstance()->setReceiveWindow(newTCPsize);
445 Osd::getInstance()->setFont(options[i]->optionkeys[options[i]->userSetChoice]);
451 options[i]->opthandler->handleOptionChanges(options[i]);
456 void VOpts::processMessage(Message* m)
458 if (m->message == Message::MOUSE_MOVE)
460 int x=(m->parameter>>16)-getScreenX();
461 int y=(m->parameter&0xFFFF)-getScreenY();
462 if (tabbar.mouseMove(x,y))
464 BoxStack::getInstance()->update(this);
468 else if (m->message == Message::MOUSE_LBDOWN)
470 int x=(m->parameter>>16)-getScreenX();
471 int y=(m->parameter&0xFFFF)-getScreenY();
472 if (tabbar.mouseLBDOWN(x,y))
474 BoxStack::getInstance()->update(this);
476 else if (x<0 || y <0 || x>(int)getWidth() || y>(int)getHeight())
478 BoxStack::getInstance()->handleCommand(Remote::BACK); //simulate cancel press