mirror of
https://github.com/tuxbox-neutrino/neutrino.git
synced 2025-08-28 16:01:20 +02:00
*neutrino usermenu: rework manage of usermenu name
TODO: - fix handling of menu names on changed buttons in infoviewer - fix handling in user menu setup, if no item was defined ...just to name a few git-svn-id: file:///home/bas/coolstream_public_svn/THIRDPARTY/applications/neutrino-beta@2036 e54a6e83-5905-42d5-8d5c-058d10e6a962
This commit is contained in:
@@ -1327,6 +1327,8 @@ usermenu.item_epg_misc EPG Funktionen
|
|||||||
usermenu.item_none (frei)
|
usermenu.item_none (frei)
|
||||||
usermenu.item_vtxt Teletext
|
usermenu.item_vtxt Teletext
|
||||||
usermenu.msg_info_is_empty Es wurde kein Name für dieses Menü vergeben.\nVerwende Standardname:\n
|
usermenu.msg_info_is_empty Es wurde kein Name für dieses Menü vergeben.\nVerwende Standardname:\n
|
||||||
|
usermenu.msg_warning_name Sie haben mehrere Menüpunkte für dieses Menü angelegt,\naber keinen neuen Namen festgelegt.\nEs ist daher empfohlen, einen neuen Namen zu vergeben!
|
||||||
|
usermenu.msg_warning_no_items Sie haben keine Menüpunkte für dieses Menü angelegt!\nDer Menüname wird daher zurückgesetzt!
|
||||||
usermenu.name Name
|
usermenu.name Name
|
||||||
video_mode_ok Video-Einstellungen OK?
|
video_mode_ok Video-Einstellungen OK?
|
||||||
videomenu.43mode 4:3 Anzeigeverhalten
|
videomenu.43mode 4:3 Anzeigeverhalten
|
||||||
|
@@ -1327,6 +1327,8 @@ usermenu.item_epg_misc EPG functions
|
|||||||
usermenu.item_none (empty)
|
usermenu.item_none (empty)
|
||||||
usermenu.item_vtxt Videotext
|
usermenu.item_vtxt Videotext
|
||||||
usermenu.msg_info_is_empty You don't have definied a name for this menu!\nUsing default name:\n
|
usermenu.msg_info_is_empty You don't have definied a name for this menu!\nUsing default name:\n
|
||||||
|
usermenu.msg_warning_name You have more than one items created for this menu,\nbut none new name for this menue defined.\nIt is recommended to enter a new name!
|
||||||
|
usermenu.msg_warning_no_items No items defined!\nThe menu name is reset!
|
||||||
usermenu.name Name
|
usermenu.name Name
|
||||||
video_mode_ok Is this video mode working ok ?
|
video_mode_ok Is this video mode working ok ?
|
||||||
videomenu.43mode 4:3 Content mode
|
videomenu.43mode 4:3 Content mode
|
||||||
|
@@ -1955,7 +1955,7 @@ void CInfoViewer::showButton_Audio ()
|
|||||||
|
|
||||||
frameBuffer->paintBoxRel(sx, BBarY, asize, InfoHeightY_Info, COL_INFOBAR_BUTTONS_BACKGROUND);
|
frameBuffer->paintBoxRel(sx, BBarY, asize, InfoHeightY_Info, COL_INFOBAR_BUTTONS_BACKGROUND);
|
||||||
|
|
||||||
if (txt.empty())
|
if (txt.empty() || (txt == g_Locale->getText(LOCALE_AUDIOSELECTMENUE_HEAD)))
|
||||||
txt = g_RemoteControl->current_PIDs.APIDs[selected].desc;
|
txt = g_RemoteControl->current_PIDs.APIDs[selected].desc;
|
||||||
|
|
||||||
g_Font[SNeutrinoSettings::FONT_TYPE_INFOBAR_SMALL]->RenderString(sx, BBarFontY, asize,
|
g_Font[SNeutrinoSettings::FONT_TYPE_INFOBAR_SMALL]->RenderString(sx, BBarFontY, asize,
|
||||||
|
@@ -354,8 +354,10 @@ void CPersonalizeGui::ShowUserMenu(CMenuWidget* p_widget, vector<CUserMenuSetup*
|
|||||||
for (uint i = 0; i<USERMENU_ITEMS_COUNT; i++)
|
for (uint i = 0; i<USERMENU_ITEMS_COUNT; i++)
|
||||||
{
|
{
|
||||||
v_umenu.push_back(new CUserMenuSetup(usermenu[i].menue_title, usermenu[i].menue_button));
|
v_umenu.push_back(new CUserMenuSetup(usermenu[i].menue_title, usermenu[i].menue_button));
|
||||||
|
|
||||||
//ensure correct default string, e.g: required after settings reset
|
//ensure correct default string, e.g: required after settings reset
|
||||||
g_settings.usermenu_text[i] = g_settings.usermenu_text[i].empty() ? g_Locale->getText(usermenu[i].def_name) : g_settings.usermenu_text[i].c_str();
|
if (v_umenu[i]->getUsedItemsCount() > 0)
|
||||||
|
g_settings.usermenu_text[i] = g_settings.usermenu_text[i].empty() ? g_Locale->getText(usermenu[i].def_name) : g_settings.usermenu_text[i].c_str();
|
||||||
|
|
||||||
v_umenu_fw.push_back(new CMenuForwarder(usermenu[i].menue_title, true, g_settings.usermenu_text[i], v_umenu[i], NULL, usermenu[i].DirectKey, usermenu[i].IconName));
|
v_umenu_fw.push_back(new CMenuForwarder(usermenu[i].menue_title, true, g_settings.usermenu_text[i], v_umenu[i], NULL, usermenu[i].DirectKey, usermenu[i].IconName));
|
||||||
}
|
}
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
user_menue setup implementation - Neutrino-GUI
|
user_menue setup implementation - Neutrino-GUI
|
||||||
based up implementation by Günther
|
based up implementation by Günther
|
||||||
|
|
||||||
Copyright (C) 2001 Steffen Hehn 'McClean'
|
Copyright (C) 2001 Steffen Hehn 'McClean'
|
||||||
and some other guys
|
and some other guys
|
||||||
|
@@ -54,11 +54,16 @@ CUserMenuSetup::CUserMenuSetup(neutrino_locale_t menue_title, int menue_button)
|
|||||||
button = menue_button;
|
button = menue_button;
|
||||||
max_char = 24;
|
max_char = 24;
|
||||||
width = w_max (40, 10);
|
width = w_max (40, 10);
|
||||||
|
pref_name = g_settings.usermenu_text[button]; //set current button name as prefered name
|
||||||
|
ums = NULL;
|
||||||
|
mf = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
CUserMenuSetup::~CUserMenuSetup()
|
CUserMenuSetup::~CUserMenuSetup()
|
||||||
{
|
{
|
||||||
|
delete ums;
|
||||||
|
if (mf != NULL)
|
||||||
|
delete mf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -93,20 +98,28 @@ int CUserMenuSetup::exec(CMenuTarget* parent, const std::string &)
|
|||||||
parent->hide();
|
parent->hide();
|
||||||
|
|
||||||
int res = showSetup();
|
int res = showSetup();
|
||||||
checkItem();
|
checkButtonName();
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
int CUserMenuSetup::showSetup()
|
int CUserMenuSetup::showSetup()
|
||||||
{
|
{
|
||||||
mn_widget_id_t widget_id = MN_WIDGET_ID_USERMENU_RED + button; //add up ''button'' and becomes to MN_WIDGET_ID_USERMENU_ GREEN, MN_WIDGET_ID_USERMENU_ YELLOW, MN_WIDGET_ID_USERMENU_BLUE
|
if (ums == NULL) {
|
||||||
CMenuWidget * ums = new CMenuWidget(local, NEUTRINO_ICON_KEYBINDING, width, widget_id);
|
mn_widget_id_t widget_id = MN_WIDGET_ID_USERMENU_RED + button; //add up ''button'' and becomes to MN_WIDGET_ID_USERMENU_ GREEN, MN_WIDGET_ID_USERMENU_ YELLOW, MN_WIDGET_ID_USERMENU_BLUE
|
||||||
|
ums = new CMenuWidget(local, NEUTRINO_ICON_KEYBINDING, width, widget_id);
|
||||||
|
}else{
|
||||||
|
//if widget not clean, ensure that we have an empty widget without any item and set the last selected item
|
||||||
|
int sel = ums->getSelected();
|
||||||
|
ums->resetWidget();
|
||||||
|
ums->setSelected(sel);
|
||||||
|
}
|
||||||
|
|
||||||
//CUserMenuNotifier *notify = new CUserMenuNotifier();
|
//CUserMenuNotifier *notify = new CUserMenuNotifier();
|
||||||
CStringInputSMS name(LOCALE_USERMENU_NAME, &g_settings.usermenu_text[button], 11, NONEXISTANT_LOCALE, NONEXISTANT_LOCALE, "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyzäöüß/- "/*, notify*/);
|
CStringInputSMS name(LOCALE_USERMENU_NAME, &g_settings.usermenu_text[button], 11, NONEXISTANT_LOCALE, NONEXISTANT_LOCALE, "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyzäöüß/- "/*, notify*/);
|
||||||
|
|
||||||
CMenuForwarder *mf = new CMenuForwarder(LOCALE_USERMENU_NAME, true, g_settings.usermenu_text[button],&name);
|
if (mf == NULL)
|
||||||
|
mf = new CMenuForwarder(LOCALE_USERMENU_NAME, true, g_settings.usermenu_text[button],&name);
|
||||||
|
|
||||||
//-------------------------------------
|
//-------------------------------------
|
||||||
ums->addIntroItems();
|
ums->addIntroItems();
|
||||||
@@ -119,26 +132,88 @@ int CUserMenuSetup::showSetup()
|
|||||||
{
|
{
|
||||||
snprintf(text,max_char,"%d.",item+1);
|
snprintf(text,max_char,"%d.",item+1);
|
||||||
text[max_char-1]=0;// terminate for sure
|
text[max_char-1]=0;// terminate for sure
|
||||||
ums->addItem( new CMenuOptionChooser(text, &g_settings.usermenu[button][item], USERMENU_ITEM_OPTIONS, USERMENU_ITEM_OPTION_COUNT,true, NULL, CRCInput::RC_nokey, "", true ));
|
ums->addItem(new CMenuOptionChooser(text, &g_settings.usermenu[button][item], USERMENU_ITEM_OPTIONS, USERMENU_ITEM_OPTION_COUNT,true, NULL, CRCInput::RC_nokey, "", true ));
|
||||||
}
|
}
|
||||||
|
|
||||||
int res = ums->exec(NULL, "");
|
int res = ums->exec(NULL, "");
|
||||||
ums->hide();
|
ums->hide();
|
||||||
delete ums;
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
//check item for details like empty string and show an user message
|
//check items of current button menu and set prefered menue name
|
||||||
void CUserMenuSetup::checkItem()
|
void CUserMenuSetup::checkButtonItems()
|
||||||
{
|
{
|
||||||
|
//count of all items of widget
|
||||||
|
int count = ums->getItemsCount();
|
||||||
|
|
||||||
|
//count of configured items
|
||||||
|
int used_items = getUsedItemsCount();
|
||||||
|
|
||||||
|
//warn if no items defined and reset menu name, if empty
|
||||||
|
if (used_items == 0){
|
||||||
|
if (!g_settings.usermenu_text[button].empty()){
|
||||||
|
DisplayInfoMessage(g_Locale->getText(LOCALE_USERMENU_MSG_WARNING_NO_ITEMS));
|
||||||
|
g_settings.usermenu_text[button] = "";
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//found configured items and set as prefered name
|
||||||
|
for(int i = 0; i < count ; i++)
|
||||||
|
{
|
||||||
|
if (ums->getItem(i)->isMenueOptionChooser()) //choosers only
|
||||||
|
{
|
||||||
|
CMenuOptionChooser * opt_c = NULL;
|
||||||
|
opt_c = static_cast <CMenuOptionChooser*>(ums->getItem(i));
|
||||||
|
neutrino_locale_t opt_locale = USERMENU_ITEM_OPTIONS[opt_c->getOptionValue()].value;
|
||||||
|
int set_key = USERMENU_ITEM_OPTIONS[opt_c->getOptionValue()].key;
|
||||||
|
opt_c = NULL;
|
||||||
|
|
||||||
|
if (set_key != SNeutrinoSettings::ITEM_NONE)
|
||||||
|
pref_name = g_Locale->getText(opt_locale);
|
||||||
|
|
||||||
|
//warn if we have more than 1 items and the name of usermenu ist the same like before, exit function and let user decide, what to do
|
||||||
|
if (used_items > 1 && g_settings.usermenu_text[button]==pref_name){
|
||||||
|
DisplayInfoMessage(g_Locale->getText(LOCALE_USERMENU_MSG_WARNING_NAME));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (used_items == 1)
|
||||||
|
g_settings.usermenu_text[button] = pref_name; //if found only 1 configured item, ensure that the caption of usermenu is the same like this
|
||||||
|
}
|
||||||
|
|
||||||
|
//check button name for details like empty string and show an user message on issue
|
||||||
|
void CUserMenuSetup::checkButtonName()
|
||||||
|
{
|
||||||
|
checkButtonItems();
|
||||||
|
|
||||||
|
//exit function, if no items found
|
||||||
|
if (getUsedItemsCount() == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
bool is_empty = g_settings.usermenu_text[button].empty();
|
bool is_empty = g_settings.usermenu_text[button].empty();
|
||||||
if (is_empty)
|
if (is_empty)
|
||||||
{
|
{
|
||||||
std::string msg = g_Locale->getText(LOCALE_USERMENU_MSG_INFO_IS_EMPTY);
|
std::string msg = g_Locale->getText(LOCALE_USERMENU_MSG_INFO_IS_EMPTY);
|
||||||
msg += g_Locale->getText(usermenu[button].def_name);
|
msg += g_Locale->getText(usermenu[button].def_name);
|
||||||
|
|
||||||
DisplayInfoMessage(msg.c_str());
|
DisplayInfoMessage(msg.c_str());
|
||||||
g_settings.usermenu_text[button] = is_empty ? g_Locale->getText(usermenu[button].def_name) : g_settings.usermenu_text[button].c_str();
|
g_settings.usermenu_text[button] = is_empty ? g_Locale->getText(usermenu[button].def_name) : g_settings.usermenu_text[button].c_str();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//get count of used items
|
||||||
|
int CUserMenuSetup::getUsedItemsCount()
|
||||||
|
{
|
||||||
|
int def_items = 0;
|
||||||
|
for(int item = 0; item < SNeutrinoSettings::ITEM_MAX; item++)
|
||||||
|
if (g_settings.usermenu[button][item] != 0)
|
||||||
|
def_items++;
|
||||||
|
|
||||||
|
return def_items;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -33,6 +33,7 @@
|
|||||||
#define __user_menue_setup__
|
#define __user_menue_setup__
|
||||||
|
|
||||||
#include <gui/widget/menue.h>
|
#include <gui/widget/menue.h>
|
||||||
|
|
||||||
#include <system/settings.h>
|
#include <system/settings.h>
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
@@ -63,14 +64,20 @@ const struct usermenu_props_t usermenu[USERMENU_ITEMS_COUNT] =
|
|||||||
int width;
|
int width;
|
||||||
int max_char;
|
int max_char;
|
||||||
int button;
|
int button;
|
||||||
|
std::string pref_name;
|
||||||
neutrino_locale_t local;
|
neutrino_locale_t local;
|
||||||
|
|
||||||
int showSetup();
|
int showSetup();
|
||||||
void checkItem();
|
void checkButtonItems();
|
||||||
|
void checkButtonName();
|
||||||
|
|
||||||
|
CMenuWidget * ums;
|
||||||
|
CMenuForwarder *mf;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CUserMenuSetup(neutrino_locale_t menue_title, int menue_button);
|
CUserMenuSetup(neutrino_locale_t menue_title, int menue_button);
|
||||||
~CUserMenuSetup();
|
~CUserMenuSetup();
|
||||||
|
int getUsedItemsCount();
|
||||||
int exec(CMenuTarget* parent, const std::string & actionKey);
|
int exec(CMenuTarget* parent, const std::string & actionKey);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -1354,6 +1354,8 @@ typedef enum
|
|||||||
LOCALE_USERMENU_ITEM_NONE,
|
LOCALE_USERMENU_ITEM_NONE,
|
||||||
LOCALE_USERMENU_ITEM_VTXT,
|
LOCALE_USERMENU_ITEM_VTXT,
|
||||||
LOCALE_USERMENU_MSG_INFO_IS_EMPTY,
|
LOCALE_USERMENU_MSG_INFO_IS_EMPTY,
|
||||||
|
LOCALE_USERMENU_MSG_WARNING_NAME,
|
||||||
|
LOCALE_USERMENU_MSG_WARNING_NO_ITEMS,
|
||||||
LOCALE_USERMENU_NAME,
|
LOCALE_USERMENU_NAME,
|
||||||
LOCALE_VIDEO_MODE_OK,
|
LOCALE_VIDEO_MODE_OK,
|
||||||
LOCALE_VIDEOMENU_43MODE,
|
LOCALE_VIDEOMENU_43MODE,
|
||||||
|
@@ -1354,6 +1354,8 @@ const char * locale_real_names[] =
|
|||||||
"usermenu.item_none",
|
"usermenu.item_none",
|
||||||
"usermenu.item_vtxt",
|
"usermenu.item_vtxt",
|
||||||
"usermenu.msg_info_is_empty",
|
"usermenu.msg_info_is_empty",
|
||||||
|
"usermenu.msg_warning_name",
|
||||||
|
"usermenu.msg_warning_no_items",
|
||||||
"usermenu.name",
|
"usermenu.name",
|
||||||
"video_mode_ok",
|
"video_mode_ok",
|
||||||
"videomenu.43mode",
|
"videomenu.43mode",
|
||||||
|
Reference in New Issue
Block a user