Patch level : 10.0
Files correlati : xvaga.dll Ricompilazione Demo : [ ] Commento : Migliorata gestione cambi booleani nei property sheet git-svn-id: svn://10.65.10.50/trunk@20120 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
parent
031b00e220
commit
b12d6131d3
127
xvaga/xvaga.cpp
127
xvaga/xvaga.cpp
@ -104,7 +104,7 @@ XVTDLL void xvt_app_pre_create(void)
|
||||
#endif
|
||||
}
|
||||
|
||||
void xvt_app_create(int argc, char** argv, unsigned long WXUNUSED(flags),
|
||||
void xvt_app_create(int WXUNUSED(argc), char** WXUNUSED(argv), unsigned long WXUNUSED(flags),
|
||||
EVENT_HANDLER eh, XVT_CONFIG* config)
|
||||
{
|
||||
_task_win_handler = eh;
|
||||
@ -932,8 +932,12 @@ void xvt_dwin_draw_oval(WINDOW win, const RCT* rctp)
|
||||
dc.DrawEllipse(rct);
|
||||
}
|
||||
|
||||
void xvt_dwin_draw_pie(WINDOW win, const RCT *rctp, int start_x, int start_y, int stop_x, int stop_y)
|
||||
{ SORRY_BOX(); }
|
||||
void xvt_dwin_draw_pie(WINDOW win, const RCT *rctp,
|
||||
int WXUNUSED(start_x), int WXUNUSED(start_y), int WXUNUSED(stop_x), int WXUNUSED(stop_y))
|
||||
{
|
||||
SORRY_BOX();
|
||||
xvt_dwin_draw_oval(win, rctp);
|
||||
}
|
||||
|
||||
void xvt_dwin_draw_polygon(WINDOW win, const PNT *lpnts, int npnts)
|
||||
{
|
||||
@ -1872,7 +1876,7 @@ XVT_IMAGE xvt_image_capture(WINDOW win, const RCT* src)
|
||||
return (XVT_IMAGE)i;
|
||||
}
|
||||
|
||||
XVT_IMAGE xvt_image_create(XVT_IMAGE_FORMAT format, short width, short height, COLOR color)
|
||||
XVT_IMAGE xvt_image_create(XVT_IMAGE_FORMAT WXUNUSED(format), short width, short height, COLOR color)
|
||||
{
|
||||
TXVT_IMAGE* i = new TXVT_IMAGE;
|
||||
i->Image().Create(width, height);
|
||||
@ -2082,7 +2086,7 @@ void xvt_image_replace_color(XVT_IMAGE image, COLOR old_color, COLOR new_color)
|
||||
}
|
||||
|
||||
|
||||
void xvt_image_set_ncolors(XVT_IMAGE image, short ncolors)
|
||||
void xvt_image_set_ncolors(XVT_IMAGE WXUNUSED(image), short WXUNUSED(ncolors))
|
||||
{
|
||||
// SORRY_BOX();
|
||||
}
|
||||
@ -2290,8 +2294,10 @@ void xvt_menu_translate_tree(WINDOW win, TRANSLATE_CALLBACK tc)
|
||||
}
|
||||
}
|
||||
|
||||
void xvt_menu_set_font_sel(WINDOW win, XVT_FNTID font_id)
|
||||
{ /* Ignored */ }
|
||||
void xvt_menu_set_font_sel(WINDOW win, XVT_FNTID WXUNUSED(font_id))
|
||||
{
|
||||
XVT_ASSERT(win == TASK_WIN);
|
||||
}
|
||||
|
||||
static wxMenuItem* GetXvtMenuItem(WINDOW win, MENU_TAG tag)
|
||||
{
|
||||
@ -2352,14 +2358,14 @@ void xvt_menu_update(WINDOW /*win*/)
|
||||
// Palette management
|
||||
///////////////////////////////////////////////////////////
|
||||
|
||||
short xvt_palet_add_colors(XVT_PALETTE palet, COLOR *colorsp, short numcolors) { return 0; }
|
||||
short xvt_palet_add_colors_from_image(XVT_PALETTE palet, XVT_IMAGE image) { return 0; }
|
||||
XVT_PALETTE xvt_palet_create(XVT_PALETTE_TYPE type, XVT_PALETTE_ATTR reserved) { return NULL; }
|
||||
void xvt_palet_destroy(XVT_PALETTE palet) { SORRY_BOX(); }
|
||||
short xvt_palet_get_colors(XVT_PALETTE palet, COLOR *colorsp, short maxcolors) { return 0; }
|
||||
short xvt_palet_get_ncolors(XVT_PALETTE palet) { return 0; }
|
||||
int xvt_palet_get_tolerance(XVT_PALETTE p) { return 0; }
|
||||
void xvt_palet_set_tolerance(XVT_PALETTE p, int t) { SORRY_BOX(); }
|
||||
short xvt_palet_add_colors(XVT_PALETTE WXUNUSED(palet), COLOR* WXUNUSED(colorsp), short numcolors) { return numcolors; }
|
||||
short xvt_palet_add_colors_from_image(XVT_PALETTE WXUNUSED(palet), XVT_IMAGE image) { return xvt_image_get_ncolors(image); }
|
||||
XVT_PALETTE xvt_palet_create(XVT_PALETTE_TYPE WXUNUSED(type), XVT_PALETTE_ATTR WXUNUSED(reserved)) { return NULL; }
|
||||
void xvt_palet_destroy(XVT_PALETTE WXUNUSED(palet)) { SORRY_BOX(); }
|
||||
short xvt_palet_get_colors(XVT_PALETTE WXUNUSED(palet), COLOR* WXUNUSED(colorsp), short WXUNUSED(maxcolors)) { return 0; }
|
||||
short xvt_palet_get_ncolors(XVT_PALETTE WXUNUSED(palet)) { return 0; }
|
||||
int xvt_palet_get_tolerance(XVT_PALETTE WXUNUSED(p)) { return 0; }
|
||||
void xvt_palet_set_tolerance(XVT_PALETTE WXUNUSED(p), int WXUNUSED(t)) { SORRY_BOX(); }
|
||||
|
||||
///////////////////////////////////////////////////////////
|
||||
// Rectangles
|
||||
@ -3023,6 +3029,41 @@ char* xvt_str_number_format(char* str, int size)
|
||||
return str;
|
||||
}
|
||||
|
||||
static const char* const ENCRYPTION_KEY = "QSECOFR-";
|
||||
|
||||
int xvt_str_encode(const char* text, char* cipher, int mode)
|
||||
{
|
||||
int i = 0;
|
||||
switch (mode)
|
||||
{
|
||||
case 1: // BASE64
|
||||
break;
|
||||
default: // AGA
|
||||
for (i = 0; text[i]; i++)
|
||||
cipher[i] = text[i] + (i < 8 ? ENCRYPTION_KEY[i] : text[i - 8]);
|
||||
cipher[i] = '\0';
|
||||
break;
|
||||
}
|
||||
return i;
|
||||
}
|
||||
|
||||
int xvt_str_decode(const char* cipher, char* text, int mode)
|
||||
{
|
||||
int i = 0;
|
||||
switch (mode)
|
||||
{
|
||||
case 1: // BASE64
|
||||
break;
|
||||
default: // AGA
|
||||
for (i = 0; cipher[i]; i++)
|
||||
text[i] = cipher[i] - (i < 8 ? ENCRYPTION_KEY[i] : text[i - 8]);
|
||||
text[i] = '\0';
|
||||
break;
|
||||
}
|
||||
return i;
|
||||
}
|
||||
|
||||
|
||||
BOOLEAN xvt_str_match(const char* mbs, const char *pat, BOOLEAN case_sensitive)
|
||||
{
|
||||
/*
|
||||
@ -3191,6 +3232,8 @@ long xvt_sys_execute(const char* cmdline, BOOLEAN sync, BOOLEAN iconizetask)
|
||||
wxEnableTopLevelWindows(FALSE);
|
||||
|
||||
TIconizeTaskThread* it = new TIconizeTaskThread(); // No need to delete
|
||||
if (it != NULL)
|
||||
{
|
||||
__bChildRunning = true;
|
||||
exitcode = wxExecute(cmd, wxEXEC_SYNC);
|
||||
__bChildRunning = false;
|
||||
@ -3199,6 +3242,7 @@ long xvt_sys_execute(const char* cmdline, BOOLEAN sync, BOOLEAN iconizetask)
|
||||
_task_win->Restore();
|
||||
wxEnableTopLevelWindows(TRUE);
|
||||
}
|
||||
}
|
||||
else
|
||||
exitcode = wxExecute(cmd, wxEXEC_SYNC); // Valutare wxEXEC_NODISABLE
|
||||
_task_win->Raise();
|
||||
@ -3281,29 +3325,19 @@ BOOLEAN xvt_sys_dongle_server_is_running()
|
||||
return sic.IsAnotherRunning();
|
||||
}
|
||||
|
||||
int xvt_sys_get_oem_string(const char* name, const char* defval, char* value, int maxsize)
|
||||
{
|
||||
wxString strFileName = _startup_dir + "/setup/oem.ini";
|
||||
const int oem = xvt_sys_get_profile_int(strFileName, "MAIN", "OEM", -1);
|
||||
if (oem >= 0)
|
||||
{
|
||||
wxString strPara; strPara << "OEM_" << oem;
|
||||
return xvt_sys_get_profile_string(strFileName, strPara, name, defval, value, maxsize);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
#define OEM_INI wxString(_startup_dir+wxT("/setup/oem.ini"))
|
||||
|
||||
long xvt_sys_get_oem_int(const char* name, long defval)
|
||||
{
|
||||
static long _oem = -1;
|
||||
if (_oem < 0)
|
||||
_oem = xvt_sys_get_profile_int(_startup_dir+"/setup/oem.ini", "MAIN", "OEM", -1);
|
||||
_oem = xvt_sys_get_profile_int(OEM_INI, "MAIN", "OEM", -1);
|
||||
if (_oem >= 0)
|
||||
{
|
||||
if (wxStricmp(name, "OEM") != 0)
|
||||
if (wxStricmp(name, wxT("OEM")) != 0)
|
||||
{
|
||||
wxString strPara; strPara << "OEM_" << _oem;
|
||||
defval = xvt_sys_get_profile_int(_startup_dir+"/setup/oem.ini", strPara, name, defval);
|
||||
wxString strPara; strPara.Printf(wxT("OEM_%d"), _oem);
|
||||
defval = xvt_sys_get_profile_int(OEM_INI, strPara, name, defval);
|
||||
}
|
||||
else
|
||||
defval = _oem;
|
||||
@ -3311,6 +3345,26 @@ long xvt_sys_get_oem_int(const char* name, long defval)
|
||||
return defval;
|
||||
}
|
||||
|
||||
int xvt_sys_get_oem_string(const char* name, const char* defval, char* value, int maxsize)
|
||||
{
|
||||
const int oem = xvt_sys_get_oem_int("OEM", -1);
|
||||
if (oem >= 0)
|
||||
{
|
||||
if (wxStricmp(name, wxT("OEM")) != 0)
|
||||
{
|
||||
wxString strPara; strPara.Printf(wxT("OEM_%d"), oem);
|
||||
return xvt_sys_get_profile_string(OEM_INI, strPara, name, defval, value, maxsize);
|
||||
}
|
||||
else
|
||||
{
|
||||
wxString str; str.Printf("%d", oem);
|
||||
wxStrncpy(value, str, maxsize);
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int xvt_sys_get_profile_string(const char* file, const char* paragraph, const char* name,
|
||||
const char* defval, char* value, int maxsize)
|
||||
{
|
||||
@ -3999,7 +4053,7 @@ void xvt_vobj_set_enabled(WINDOW win, BOOLEAN enabled)
|
||||
w.Enable(enabled != 0);
|
||||
}
|
||||
|
||||
void xvt_vobj_set_palet(WINDOW win, XVT_PALETTE palet)
|
||||
void xvt_vobj_set_palet(WINDOW WXUNUSED(win), XVT_PALETTE WXUNUSED(palet))
|
||||
{
|
||||
// Do not implement!
|
||||
}
|
||||
@ -4037,7 +4091,8 @@ void xvt_vobj_translate_points(WINDOW from_win, WINDOW to_win, PNT *pntp, int np
|
||||
// Real windows
|
||||
///////////////////////////////////////////////////////////
|
||||
|
||||
WINDOW xvt_win_create(WIN_TYPE wtype, const RCT* rct_p, const char* title, int menu_rid, WINDOW parent, long win_flags, EVENT_MASK mask, EVENT_HANDLER eh, long app_data)
|
||||
WINDOW xvt_win_create(WIN_TYPE wtype, const RCT* rct_p, const char* title, int menu_rid, WINDOW parent, long win_flags,
|
||||
EVENT_MASK WXUNUSED(mask), EVENT_HANDLER eh, long app_data)
|
||||
{
|
||||
const wxRect rct = RCT2Rect(rct_p);
|
||||
const wxString caption = title;
|
||||
@ -4288,16 +4343,16 @@ XVT_FNTID statbar_get_fontid(WINDOW win, XVT_FNTID font_id)
|
||||
return font_id;
|
||||
}
|
||||
|
||||
WINDOW statbar_create(int cid, int left, int top, int right, int bottom,
|
||||
int prop_count, char **prop_list, WINDOW parent_win,
|
||||
int parent_rid, long parent_flags, char *parent_class)
|
||||
WINDOW statbar_create(int cid, int WXUNUSED(left), int WXUNUSED(top), int WXUNUSED(right), int WXUNUSED(bottom),
|
||||
int WXUNUSED(prop_count), char** WXUNUSED(prop_list), WINDOW parent_win,
|
||||
int WXUNUSED(parent_rid), long WXUNUSED(parent_flags), char* WXUNUSED(parent_class))
|
||||
{
|
||||
wxStatusBar* pStatusBar = NULL;
|
||||
wxFrame* w = wxDynamicCast(SafeCastWin(parent_win), wxFrame);
|
||||
if (w != NULL)
|
||||
{
|
||||
const int nStyle = 0; // not wxST_SIZEGRIP
|
||||
pStatusBar = w->CreateStatusBar(3, nStyle);
|
||||
pStatusBar = w->CreateStatusBar(3, nStyle, cid);
|
||||
if (pStatusBar != NULL)
|
||||
{
|
||||
const int widths[4] = { -4, -2, -2, 0 };
|
||||
|
@ -342,6 +342,8 @@ XVTDLL SLIST_ELT xvt_slist_get_first(SLIST list);
|
||||
XVTDLL SLIST_ELT xvt_slist_get_next(SLIST list, SLIST_ELT item);
|
||||
|
||||
XVTDLL int xvt_str_compare_ignoring_case (const char* s1, const char* s2);
|
||||
XVTDLL int xvt_str_encode(const char* text, char* cypher, int mode);
|
||||
XVTDLL int xvt_str_decode(const char* cypher, char* text, int mode);
|
||||
XVTDLL char* xvt_str_duplicate(const char* str);
|
||||
XVTDLL BOOLEAN xvt_str_match(const char* str, const char* pat, BOOLEAN case_sensitive);
|
||||
XVTDLL double xvt_str_fuzzy_compare (const char* s1, const char* s2);
|
||||
@ -483,9 +485,12 @@ typedef BOOLEAN PROP_CALLBACK(WINDOW win, XVT_TREEVIEW_NODE node, void* app_data
|
||||
XVTDLL XVT_TREEVIEW_NODE xvt_prop_add(WINDOW win, const char* type, const char* name, const char* value, const char* label);
|
||||
XVTDLL XVT_TREEVIEW_NODE xvt_prop_current(WINDOW win);
|
||||
XVTDLL XVT_TREEVIEW_NODE xvt_prop_find(WINDOW win, const char* name);
|
||||
XVTDLL void xvt_prop_fit_columns(WINDOW win);
|
||||
XVTDLL BOOLEAN xvt_prop_for_each(WINDOW win, PROP_CALLBACK pcb, void* jolly);
|
||||
XVTDLL int xvt_prop_get_string(WINDOW win, XVT_TREEVIEW_NODE node, char* label, int maxlen);
|
||||
XVTDLL int xvt_prop_get_data(WINDOW win, XVT_TREEVIEW_NODE node, char* value, int maxlen);
|
||||
XVTDLL int xvt_prop_get_string(WINDOW win, XVT_TREEVIEW_NODE node, char* label, int maxlen);
|
||||
XVTDLL int xvt_prop_get_type(WINDOW win, XVT_TREEVIEW_NODE node, char* type, int maxlen);
|
||||
XVTDLL BOOLEAN xvt_prop_remove(WINDOW win, XVT_TREEVIEW_NODE node);
|
||||
XVTDLL BOOLEAN xvt_prop_restart(WINDOW win);
|
||||
XVTDLL BOOLEAN xvt_prop_set_data(WINDOW win, XVT_TREEVIEW_NODE node, const char* value);
|
||||
XVTDLL BOOLEAN xvt_prop_set_read_only(WINDOW win, XVT_TREEVIEW_NODE node, BOOLEAN ro);
|
||||
|
106
xvaga/xvtctl.cpp
106
xvaga/xvtctl.cpp
@ -944,8 +944,7 @@ void TwxTreeCtrl::OnExpanding(wxTreeEvent& evt)
|
||||
if (!m_nFrozen)
|
||||
{
|
||||
const wxTreeItemId id = evt.GetItem();
|
||||
EVENT e; memset(&e, 0, sizeof(EVENT));
|
||||
e.type = E_CONTROL;
|
||||
XVT_EVENT e(E_CONTROL);
|
||||
e.v.ctl.id = evt.GetId();
|
||||
e.v.ctl.ci.type = WC_TREE;
|
||||
e.v.ctl.ci.win = WINDOW(this);
|
||||
@ -965,8 +964,7 @@ void TwxTreeCtrl::OnCollapsed(wxTreeEvent& evt)
|
||||
if (!m_nFrozen)
|
||||
{
|
||||
Suspend();
|
||||
EVENT e; memset(&e, 0, sizeof(EVENT));
|
||||
e.type = E_CONTROL;
|
||||
XVT_EVENT e(E_CONTROL);
|
||||
e.v.ctl.id = evt.GetId();
|
||||
e.v.ctl.ci.type = WC_TREE;
|
||||
e.v.ctl.ci.win = WINDOW(this);
|
||||
@ -983,8 +981,7 @@ void TwxTreeCtrl::OnClick(wxTreeEvent& evt, bool bDouble)
|
||||
if (!m_nFrozen)
|
||||
{
|
||||
Suspend();
|
||||
EVENT e; memset(&e, 0, sizeof(EVENT));
|
||||
e.type = E_CONTROL;
|
||||
XVT_EVENT e(E_CONTROL);
|
||||
e.v.ctl.id = evt.GetId();
|
||||
e.v.ctl.ci.type = WC_TREE;
|
||||
e.v.ctl.ci.win = WINDOW(this);
|
||||
@ -1038,8 +1035,7 @@ void TwxTreeCtrl::OnRightDown(wxMouseEvent& evt)
|
||||
TwxWindow* pParent = wxDynamicCast(GetParent(), TwxWindow);
|
||||
if (pParent != NULL)
|
||||
{
|
||||
EVENT e; memset(&e, 0, sizeof(EVENT));
|
||||
e.type = E_MOUSE_DOWN;
|
||||
XVT_EVENT e(E_MOUSE_DOWN);
|
||||
e.v.mouse.button = 1;
|
||||
e.v.mouse.control = evt.ControlDown();
|
||||
e.v.mouse.shift = evt.ShiftDown();
|
||||
@ -1524,7 +1520,26 @@ void TwxOutlookBar::OnDrawItem(wxDC& dc, const wxRect& rect, size_t n) const
|
||||
color = wxSystemSettings::GetColour(wxSYS_COLOUR_CAPTIONTEXT);
|
||||
dc.SetTextForeground(color);
|
||||
|
||||
const wxSize szText = dc.GetTextExtent(oi.m_strText);
|
||||
const wxString& str = oi.m_strText;
|
||||
const int nMaxX = rect.width - nTextOffset;
|
||||
const wxSize szText = dc.GetTextExtent(str);
|
||||
if (szText.x > nMaxX && szText.y*2 < nSide)
|
||||
{
|
||||
const int nMid = str.Len() / 2;
|
||||
int nBest = nMid, nDist = nMid;
|
||||
for (int i = 0; i < 2*nMid; i++) if (str[i] <= wxChar(' '))
|
||||
{
|
||||
const int d = abs(nMid-i);
|
||||
if (d < nDist)
|
||||
{
|
||||
nBest = i;
|
||||
nDist = d;
|
||||
}
|
||||
}
|
||||
dc.DrawText(str.Left(nBest+1), rect.x+nTextOffset, rect.y+nSide/2-szText.y);
|
||||
dc.DrawText(str.Mid(nBest+1), rect.x+nTextOffset, rect.y+nSide/2);
|
||||
}
|
||||
else
|
||||
dc.DrawText(oi.m_strText, rect.x+nTextOffset, rect.y+(nSide-szText.y)/2);
|
||||
}
|
||||
|
||||
@ -1568,8 +1583,7 @@ void TwxOutlookBar::OnSelected(wxCommandEvent& evt)
|
||||
TwxWindow* win = wxDynamicCast(GetParent(), TwxWindow);
|
||||
if (win != NULL)
|
||||
{
|
||||
EVENT e; memset(&e, 0, sizeof(EVENT));
|
||||
e.type = E_CONTROL;
|
||||
XVT_EVENT e(E_CONTROL);
|
||||
e.v.ctl.id = evt.GetId();
|
||||
e.v.ctl.ci.type = WC_OUTLOOKBAR;
|
||||
e.v.ctl.ci.win = WINDOW(this);
|
||||
@ -1778,8 +1792,7 @@ void TwxPopUp::NotifySelection()
|
||||
TwxWindow* win = wxDynamicCast(GetParent(), TwxWindow);
|
||||
if (win != NULL)
|
||||
{
|
||||
EVENT e; memset(&e, 0, sizeof(EVENT));
|
||||
e.type = E_CONTROL;
|
||||
XVT_EVENT e(E_CONTROL);
|
||||
e.v.ctl.id = GetId();
|
||||
e.v.ctl.ci.type = WC_LISTEDIT;
|
||||
e.v.ctl.ci.win = WINDOW(this);
|
||||
@ -1972,8 +1985,7 @@ END_EVENT_TABLE();
|
||||
|
||||
void TwxToolBar::OnTool(wxCommandEvent& evt)
|
||||
{
|
||||
EVENT e; memset(&e, 0, sizeof(EVENT));
|
||||
e.type = E_CONTROL;
|
||||
XVT_EVENT e(E_CONTROL);
|
||||
e.v.ctl.id = evt.GetId();
|
||||
e.v.ctl.ci.type = WC_ICON; // WC_PUSHBUTTON entra in conflitto coi bottoni
|
||||
e.v.ctl.ci.win = WINDOW(this);
|
||||
@ -2237,8 +2249,7 @@ void TwxPropertyGrid::OnPropertyChanged(wxPropertyGridEvent& evt)
|
||||
TwxWindow* win = wxDynamicCast(GetParent(), TwxWindow);
|
||||
if (win != NULL && !IsFrozen())
|
||||
{
|
||||
EVENT e; memset(&e, 0, sizeof(EVENT));
|
||||
e.type = E_CONTROL;
|
||||
XVT_EVENT e(E_CONTROL);
|
||||
e.v.ctl.id = evt.GetId();
|
||||
e.v.ctl.ci.v.treeview.sgl_click = TRUE;
|
||||
e.v.ctl.ci.v.treeview.node = evt.GetProperty();
|
||||
@ -2319,7 +2330,9 @@ BOOLEAN xvt_prop_set_data(WINDOW win, XVT_TREEVIEW_NODE node, const char* value)
|
||||
else
|
||||
{
|
||||
if (strType == "long" || strType == "int")
|
||||
pgp->SetValue(atol(value));
|
||||
pgp->SetValue(atol(value)); else
|
||||
if (strType == "bool")
|
||||
pgp->SetValue(*value > '0' && strchr("1TXY", *value) != NULL);
|
||||
else
|
||||
pgp->SetValue(value);
|
||||
}
|
||||
@ -2342,10 +2355,20 @@ XVT_TREEVIEW_NODE xvt_prop_add(WINDOW win, const char* type, const char* name, c
|
||||
{
|
||||
switch (toupper(*type))
|
||||
{
|
||||
case 'C': pgp = new wxColourProperty(strLabel, name, STR2COLOUR(value)); break;
|
||||
case 'B':
|
||||
pgp = new wxBoolProperty(strLabel, name, *value > '0' && strchr("1TXY", *value) != NULL);
|
||||
pgp->SetAttribute(wxString("UseCheckbox"), true);
|
||||
break;
|
||||
case 'C':
|
||||
pgp = new wxColourProperty(strLabel, name, STR2COLOUR(value));
|
||||
break;
|
||||
case 'I':
|
||||
case 'L': pgp = new wxIntProperty(strLabel, name, atol(value)); break;
|
||||
default : pgp = new wxStringProperty(strLabel, name, value); break;
|
||||
case 'L':
|
||||
pgp = new wxIntProperty(strLabel, name, atol(value));
|
||||
break;
|
||||
default :
|
||||
pgp = new wxStringProperty(strLabel, name, value);
|
||||
break;
|
||||
}
|
||||
}
|
||||
else
|
||||
@ -2377,6 +2400,28 @@ XVT_TREEVIEW_NODE xvt_prop_find(WINDOW win, const char* name)
|
||||
return node;
|
||||
}
|
||||
|
||||
void xvt_prop_fit_columns(WINDOW win)
|
||||
{
|
||||
wxPropertyGrid* pg = wxDynamicCast((wxObject*)win, wxPropertyGrid);
|
||||
if (pg != NULL)
|
||||
pg->FitColumns();
|
||||
}
|
||||
|
||||
BOOLEAN xvt_prop_remove(WINDOW win, XVT_TREEVIEW_NODE node)
|
||||
{
|
||||
wxPropertyGrid* pg = wxDynamicCast((wxObject*)win, wxPropertyGrid);
|
||||
if (pg != NULL)
|
||||
{
|
||||
wxPGProperty* pgp = wxDynamicCast((wxObject*)node, wxPGProperty);
|
||||
if (pgp != NULL)
|
||||
{
|
||||
pg->DeleteProperty(pgp->GetId());
|
||||
return TRUE;
|
||||
}
|
||||
}
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
int xvt_prop_get_string(WINDOW win, XVT_TREEVIEW_NODE node, char* label, int maxlen)
|
||||
{
|
||||
int len = -1;
|
||||
@ -2398,6 +2443,25 @@ int xvt_prop_get_string(WINDOW win, XVT_TREEVIEW_NODE node, char* label, int max
|
||||
return len;
|
||||
}
|
||||
|
||||
int xvt_prop_get_type(WINDOW win, XVT_TREEVIEW_NODE node, char* type, int maxlen)
|
||||
{
|
||||
int len = 0;
|
||||
wxPropertyGrid* pg = wxDynamicCast((wxObject*)win, wxPropertyGrid);
|
||||
if (pg != NULL)
|
||||
{
|
||||
const wxPGProperty* pgp = wxDynamicCast((wxObject*)node, wxPGProperty);
|
||||
if (pgp != NULL)
|
||||
{
|
||||
wxString strType = pgp->GetType();
|
||||
if (strType == "wxColour")
|
||||
strType = "color";
|
||||
wxStrncpy(type, strType, maxlen);
|
||||
len = strType.Len();
|
||||
}
|
||||
}
|
||||
return len;
|
||||
}
|
||||
|
||||
int xvt_prop_get_data(WINDOW win, XVT_TREEVIEW_NODE node, char* value, int maxlen)
|
||||
{
|
||||
int len = -1;
|
||||
|
@ -352,7 +352,7 @@ void xvt_dm_speech_enable(int mode)
|
||||
{
|
||||
#ifdef SPEECH_API
|
||||
m_nSpeechMode = mode;
|
||||
#ifdef WIN32
|
||||
#ifdef __WXMSW__
|
||||
if (m_nSpeechMode != 0)
|
||||
{
|
||||
if (!OsWin32_InitializeSpeech())
|
||||
@ -513,7 +513,7 @@ BOOLEAN xvt_dm_post_speech(const char* text, int priority, BOOLEAN async)
|
||||
#ifdef SPEECH_API
|
||||
if ((m_nSpeechMode & (1 << priority)) != 0)
|
||||
{
|
||||
#ifdef WIN32
|
||||
#ifdef __WXMSW__
|
||||
ok = OsWin32_Speak(text, async != 0);
|
||||
#endif
|
||||
}
|
||||
@ -521,7 +521,7 @@ BOOLEAN xvt_dm_post_speech(const char* text, int priority, BOOLEAN async)
|
||||
return ok;
|
||||
}
|
||||
|
||||
ASK_RESPONSE xvt_dm_post_ask(const char* Btn1, const char* Btn2, const char* Btn3, const char* fmt)
|
||||
ASK_RESPONSE xvt_dm_post_ask(const char* Btn1, const char* WXUNUSED(Btn2), const char* Btn3, const char* fmt)
|
||||
{
|
||||
int nFlags = wxICON_QUESTION | wxYES_NO;
|
||||
if (Btn3 == NULL)
|
||||
@ -707,7 +707,7 @@ void xvt_help_close_helpfile(XVT_HELP_INFO hi)
|
||||
hi = (XVT_HELP_INFO)&help_info;
|
||||
}
|
||||
|
||||
BOOLEAN xvt_help_process_event(XVT_HELP_INFO hi, WINDOW win, EVENT *ev)
|
||||
BOOLEAN xvt_help_process_event(XVT_HELP_INFO WXUNUSED(hi), WINDOW win, EVENT *ev)
|
||||
{
|
||||
BOOLEAN bProcessed = FALSE;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user