wxHyperlink page for widgets presentation.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@39473 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
233
samples/widgets/hyperlnk.cpp
Normal file
233
samples/widgets/hyperlnk.cpp
Normal file
@@ -0,0 +1,233 @@
|
|||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Program: wxWidgets Widgets Sample
|
||||||
|
// Name: hyperlnk.cpp
|
||||||
|
// Purpose: Part of the widgets sample showing wxHyperlinkCtrl
|
||||||
|
// Author: Dimitri Schoolwerth, Vadim Zeitlin
|
||||||
|
// Created: 27 Sep 2003
|
||||||
|
// Id: $Id$
|
||||||
|
// Copyright: (c) 2003 wxWindows team
|
||||||
|
// License: wxWindows license
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// declarations
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// headers
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// for compilers that support precompilation, includes "wx/wx.h".
|
||||||
|
#include "wx/wxprec.h"
|
||||||
|
|
||||||
|
#ifdef __BORLANDC__
|
||||||
|
#pragma hdrstop
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if wxUSE_HYPERLINKCTRL
|
||||||
|
|
||||||
|
// for all others, include the necessary headers
|
||||||
|
#ifndef WX_PRECOMP
|
||||||
|
#include "wx/app.h"
|
||||||
|
#include "wx/log.h"
|
||||||
|
|
||||||
|
#include "wx/bitmap.h"
|
||||||
|
#include "wx/button.h"
|
||||||
|
#include "wx/checkbox.h"
|
||||||
|
#include "wx/radiobox.h"
|
||||||
|
#include "wx/statbox.h"
|
||||||
|
#include "wx/stattext.h"
|
||||||
|
#include "wx/textctrl.h"
|
||||||
|
|
||||||
|
#include "wx/sizer.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "wx/Hyperlink.h"
|
||||||
|
|
||||||
|
#include "widgets.h"
|
||||||
|
|
||||||
|
#include "icons/hyperlnk.xpm"
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// constants
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// control ids
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
HyperlinkPage_Reset = wxID_HIGHEST,
|
||||||
|
HyperlinkPage_SetLabel,
|
||||||
|
HyperlinkPage_SetURL,
|
||||||
|
HyperlinkPage_Ctrl
|
||||||
|
};
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// CheckBoxWidgetsPage
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class HyperlinkWidgetsPage : public WidgetsPage
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
HyperlinkWidgetsPage(WidgetsBookCtrl *book, wxImageList *imaglist);
|
||||||
|
virtual ~HyperlinkWidgetsPage(){};
|
||||||
|
|
||||||
|
virtual wxControl *GetWidget() const { return m_hyperlink; }
|
||||||
|
virtual void RecreateWidget() { CreateHyperlink(); }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
// event handlers
|
||||||
|
void OnButtonSetLabel(wxCommandEvent& event);
|
||||||
|
void OnButtonSetURL(wxCommandEvent& event);
|
||||||
|
|
||||||
|
void OnButtonReset(wxCommandEvent& event);
|
||||||
|
|
||||||
|
// reset the control parameters
|
||||||
|
void Reset();
|
||||||
|
|
||||||
|
// (re)create the hyperctrl
|
||||||
|
void CreateHyperlink();
|
||||||
|
|
||||||
|
// the controls
|
||||||
|
// ------------
|
||||||
|
|
||||||
|
// the checkbox itself and the sizer it is in
|
||||||
|
wxHyperlinkCtrl *m_hyperlink;
|
||||||
|
wxSizer *m_sizerHyperlink;
|
||||||
|
|
||||||
|
wxTextCtrl *m_label;
|
||||||
|
wxTextCtrl *m_url;
|
||||||
|
|
||||||
|
wxStaticText *m_visit;
|
||||||
|
wxStaticText *m_fun;
|
||||||
|
|
||||||
|
// the text entries for command parameters
|
||||||
|
wxTextCtrl *m_textLabel;
|
||||||
|
|
||||||
|
private:
|
||||||
|
DECLARE_EVENT_TABLE()
|
||||||
|
DECLARE_WIDGETS_PAGE(HyperlinkWidgetsPage)
|
||||||
|
};
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// event tables
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
BEGIN_EVENT_TABLE(HyperlinkWidgetsPage, WidgetsPage)
|
||||||
|
EVT_BUTTON(HyperlinkPage_Reset, HyperlinkWidgetsPage::OnButtonReset)
|
||||||
|
EVT_BUTTON(HyperlinkPage_SetLabel, HyperlinkWidgetsPage::OnButtonSetLabel)
|
||||||
|
EVT_BUTTON(HyperlinkPage_SetURL, HyperlinkWidgetsPage::OnButtonSetURL)
|
||||||
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// implementation
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
IMPLEMENT_WIDGETS_PAGE(HyperlinkWidgetsPage, wxT("Hyperlink"),
|
||||||
|
GENERIC_CTRLS
|
||||||
|
);
|
||||||
|
|
||||||
|
HyperlinkWidgetsPage::HyperlinkWidgetsPage(WidgetsBookCtrl *book,
|
||||||
|
wxImageList *imaglist)
|
||||||
|
:WidgetsPage(book, imaglist, hyperlnk_xpm)
|
||||||
|
{
|
||||||
|
wxSizer *sizerTop = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
|
||||||
|
// left pane
|
||||||
|
wxStaticBox *box = new wxStaticBox(this, wxID_ANY, wxT("Hyperlink details"));
|
||||||
|
|
||||||
|
wxSizer *sizerLeft = new wxStaticBoxSizer(box, wxVERTICAL);
|
||||||
|
|
||||||
|
sizerLeft->Add( CreateSizerWithTextAndButton( HyperlinkPage_SetLabel , wxT("Set &Label"), wxID_ANY, &m_label ),
|
||||||
|
0, wxALL | wxALIGN_RIGHT , 5 );
|
||||||
|
|
||||||
|
sizerLeft->Add( CreateSizerWithTextAndButton( HyperlinkPage_SetURL , wxT("Set &URL"), wxID_ANY, &m_url ),
|
||||||
|
0, wxALL | wxALIGN_RIGHT , 5 );
|
||||||
|
|
||||||
|
// right pane
|
||||||
|
wxSizer *sizerRight = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
|
||||||
|
m_visit = new wxStaticText(this, wxID_ANY, wxT("Visit "));
|
||||||
|
|
||||||
|
m_hyperlink = new wxHyperlinkCtrl(this,
|
||||||
|
HyperlinkPage_Ctrl,
|
||||||
|
wxT("wxWidgets website"),
|
||||||
|
wxT("www.wxwidgets.org"));
|
||||||
|
|
||||||
|
m_fun = new wxStaticText(this, wxID_ANY, wxT(" for fun!"));
|
||||||
|
|
||||||
|
sizerRight->Add(0, 0, 1, wxCENTRE);
|
||||||
|
sizerRight->Add(m_visit, 0, wxCENTRE);
|
||||||
|
sizerRight->Add(m_hyperlink, 0, wxCENTRE);
|
||||||
|
sizerRight->Add(m_fun, 0, wxCENTRE);
|
||||||
|
sizerRight->Add(0, 0, 1, wxCENTRE);
|
||||||
|
sizerRight->SetMinSize(150, 0);
|
||||||
|
m_sizerHyperlink = sizerRight; // save it to modify it later
|
||||||
|
|
||||||
|
// the 3 panes panes compose the window
|
||||||
|
sizerTop->Add(sizerLeft, 0, (wxALL & ~wxLEFT), 10);
|
||||||
|
sizerTop->Add(sizerRight, 1, wxGROW | (wxALL & ~wxRIGHT), 10);
|
||||||
|
|
||||||
|
// final initializations
|
||||||
|
Reset();
|
||||||
|
|
||||||
|
SetSizer(sizerTop);
|
||||||
|
|
||||||
|
sizerTop->Fit(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
void HyperlinkWidgetsPage::Reset()
|
||||||
|
{
|
||||||
|
m_label->SetValue(m_hyperlink->GetLabel());
|
||||||
|
m_url->SetValue(m_hyperlink->GetURL());
|
||||||
|
}
|
||||||
|
|
||||||
|
void HyperlinkWidgetsPage::CreateHyperlink()
|
||||||
|
{
|
||||||
|
const wxString label = m_hyperlink->GetLabel();
|
||||||
|
const wxString url = m_hyperlink->GetURL();
|
||||||
|
|
||||||
|
size_t count = m_sizerHyperlink->GetChildren().GetCount();
|
||||||
|
for ( size_t n = 0; n < count; n++ )
|
||||||
|
{
|
||||||
|
m_sizerHyperlink->Remove(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
delete m_hyperlink;
|
||||||
|
|
||||||
|
m_hyperlink = new wxHyperlinkCtrl(this,
|
||||||
|
HyperlinkPage_Ctrl,
|
||||||
|
label,
|
||||||
|
url);
|
||||||
|
|
||||||
|
m_sizerHyperlink->Add(0, 0, 1, wxCENTRE);
|
||||||
|
m_sizerHyperlink->Add(m_visit, 0, wxCENTRE);
|
||||||
|
m_sizerHyperlink->Add(m_hyperlink, 0, wxCENTRE);
|
||||||
|
m_sizerHyperlink->Add(m_fun, 0, wxCENTRE);
|
||||||
|
m_sizerHyperlink->Add(0, 0, 1, wxCENTRE);
|
||||||
|
m_sizerHyperlink->Layout();
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// event handlers
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void HyperlinkWidgetsPage::OnButtonReset(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Reset();
|
||||||
|
|
||||||
|
CreateHyperlink();
|
||||||
|
}
|
||||||
|
|
||||||
|
void HyperlinkWidgetsPage::OnButtonSetLabel(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
m_hyperlink->SetLabel(m_label->GetValue());
|
||||||
|
CreateHyperlink();
|
||||||
|
}
|
||||||
|
|
||||||
|
void HyperlinkWidgetsPage::OnButtonSetURL(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
m_hyperlink->SetURL(m_url->GetValue());
|
||||||
|
CreateHyperlink();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // wxUSE_HYPERLINKCTRL
|
54
samples/widgets/icons/hyperlnk.xpm
Normal file
54
samples/widgets/icons/hyperlnk.xpm
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
/* XPM */
|
||||||
|
static char *hyperlnk_xpm[] = {
|
||||||
|
/* columns rows colors chars-per-pixel */
|
||||||
|
"32 32 16 1",
|
||||||
|
" c Gray0",
|
||||||
|
". c #808000",
|
||||||
|
"X c #000080",
|
||||||
|
"o c #808080",
|
||||||
|
"O c #000000",
|
||||||
|
"+ c #808000",
|
||||||
|
"@ c #000080",
|
||||||
|
"# c none",
|
||||||
|
"$ c #808080",
|
||||||
|
"% c Red",
|
||||||
|
"& c Green",
|
||||||
|
"* c Yellow",
|
||||||
|
"= c Blue",
|
||||||
|
"- c Magenta",
|
||||||
|
"; c Cyan",
|
||||||
|
": c Gray100",
|
||||||
|
/* pixels */
|
||||||
|
"################################",
|
||||||
|
"################################",
|
||||||
|
"################################",
|
||||||
|
"#######################%######%#",
|
||||||
|
"#######################%#####%%%",
|
||||||
|
"#######################%######%#",
|
||||||
|
"%###%#%###%#%###%####%%%##%%##%#",
|
||||||
|
"%#%#%#%#%#%#%#%#%###%##%#%##%#%#",
|
||||||
|
"%#%#%#%#%#%#%#%#%###%##%#%##%#%#",
|
||||||
|
"#%#%###%#% #%#%##%##%%%##%%##%#",
|
||||||
|
"######### :: ###################",
|
||||||
|
"%%%%%%%%% :: %%%%%%%%%%%%%%%%%%%",
|
||||||
|
"######### :: ###################",
|
||||||
|
"######### :: ###################",
|
||||||
|
"######### :: ###################",
|
||||||
|
"######## :: #################",
|
||||||
|
"####### : :: :: ##############",
|
||||||
|
"###### :: :: :: :: ###########",
|
||||||
|
"###### :: :: :: :: :: ##########",
|
||||||
|
"###### :::::::: :: :: ##########",
|
||||||
|
"###### ::::::::::: :: ##########",
|
||||||
|
"###### :::::::::::::: ##########",
|
||||||
|
"###### :::::::::::::: ##########",
|
||||||
|
"###### :::::::::::::: ##########",
|
||||||
|
"###### :::::::::::::: ##########",
|
||||||
|
"###### ::::::::::::: ###########",
|
||||||
|
"####### :::::::::::: ###########",
|
||||||
|
"####### ::::::::::: ############",
|
||||||
|
"####### ############",
|
||||||
|
"################################",
|
||||||
|
"################################",
|
||||||
|
"################################"
|
||||||
|
};
|
@@ -39,6 +39,7 @@ WIDGETS_OBJECTS = \
|
|||||||
$(OBJS)\widgets_combobox.obj \
|
$(OBJS)\widgets_combobox.obj \
|
||||||
$(OBJS)\widgets_datepick.obj \
|
$(OBJS)\widgets_datepick.obj \
|
||||||
$(OBJS)\widgets_gauge.obj \
|
$(OBJS)\widgets_gauge.obj \
|
||||||
|
$(OBJS)\widgets_hyperlnk.obj \
|
||||||
$(OBJS)\widgets_listbox.obj \
|
$(OBJS)\widgets_listbox.obj \
|
||||||
$(OBJS)\widgets_notebook.obj \
|
$(OBJS)\widgets_notebook.obj \
|
||||||
$(OBJS)\widgets_radiobox.obj \
|
$(OBJS)\widgets_radiobox.obj \
|
||||||
@@ -253,6 +254,9 @@ $(OBJS)\widgets_datepick.obj: .\datepick.cpp
|
|||||||
$(OBJS)\widgets_gauge.obj: .\gauge.cpp
|
$(OBJS)\widgets_gauge.obj: .\gauge.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(WIDGETS_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(WIDGETS_CXXFLAGS) $**
|
||||||
|
|
||||||
|
$(OBJS)\widgets_hyperlnk.obj: .\hyperlnk.cpp
|
||||||
|
$(CXX) -q -c -P -o$@ $(WIDGETS_CXXFLAGS) $**
|
||||||
|
|
||||||
$(OBJS)\widgets_listbox.obj: .\listbox.cpp
|
$(OBJS)\widgets_listbox.obj: .\listbox.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(WIDGETS_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(WIDGETS_CXXFLAGS) $**
|
||||||
|
|
||||||
|
@@ -32,6 +32,7 @@ WIDGETS_OBJECTS = \
|
|||||||
$(OBJS)\widgets_combobox.o \
|
$(OBJS)\widgets_combobox.o \
|
||||||
$(OBJS)\widgets_datepick.o \
|
$(OBJS)\widgets_datepick.o \
|
||||||
$(OBJS)\widgets_gauge.o \
|
$(OBJS)\widgets_gauge.o \
|
||||||
|
$(OBJS)\widgets_hyperlnk.o \
|
||||||
$(OBJS)\widgets_listbox.o \
|
$(OBJS)\widgets_listbox.o \
|
||||||
$(OBJS)\widgets_notebook.o \
|
$(OBJS)\widgets_notebook.o \
|
||||||
$(OBJS)\widgets_radiobox.o \
|
$(OBJS)\widgets_radiobox.o \
|
||||||
@@ -246,6 +247,9 @@ $(OBJS)\widgets_datepick.o: ./datepick.cpp
|
|||||||
$(OBJS)\widgets_gauge.o: ./gauge.cpp
|
$(OBJS)\widgets_gauge.o: ./gauge.cpp
|
||||||
$(CXX) -c -o $@ $(WIDGETS_CXXFLAGS) $(CPPDEPS) $<
|
$(CXX) -c -o $@ $(WIDGETS_CXXFLAGS) $(CPPDEPS) $<
|
||||||
|
|
||||||
|
$(OBJS)\widgets_hyperlnk.o: ./hyperlnk.cpp
|
||||||
|
$(CXX) -c -o $@ $(WIDGETS_CXXFLAGS) $(CPPDEPS) $<
|
||||||
|
|
||||||
$(OBJS)\widgets_listbox.o: ./listbox.cpp
|
$(OBJS)\widgets_listbox.o: ./listbox.cpp
|
||||||
$(CXX) -c -o $@ $(WIDGETS_CXXFLAGS) $(CPPDEPS) $<
|
$(CXX) -c -o $@ $(WIDGETS_CXXFLAGS) $(CPPDEPS) $<
|
||||||
|
|
||||||
|
@@ -32,6 +32,7 @@ WIDGETS_OBJECTS = \
|
|||||||
$(OBJS)\widgets_combobox.obj \
|
$(OBJS)\widgets_combobox.obj \
|
||||||
$(OBJS)\widgets_datepick.obj \
|
$(OBJS)\widgets_datepick.obj \
|
||||||
$(OBJS)\widgets_gauge.obj \
|
$(OBJS)\widgets_gauge.obj \
|
||||||
|
$(OBJS)\widgets_hyperlnk.obj \
|
||||||
$(OBJS)\widgets_listbox.obj \
|
$(OBJS)\widgets_listbox.obj \
|
||||||
$(OBJS)\widgets_notebook.obj \
|
$(OBJS)\widgets_notebook.obj \
|
||||||
$(OBJS)\widgets_radiobox.obj \
|
$(OBJS)\widgets_radiobox.obj \
|
||||||
@@ -328,6 +329,9 @@ $(OBJS)\widgets_datepick.obj: .\datepick.cpp
|
|||||||
$(OBJS)\widgets_gauge.obj: .\gauge.cpp
|
$(OBJS)\widgets_gauge.obj: .\gauge.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(WIDGETS_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(WIDGETS_CXXFLAGS) $**
|
||||||
|
|
||||||
|
$(OBJS)\widgets_hyperlnk.obj: .\hyperlnk.cpp
|
||||||
|
$(CXX) /c /nologo /TP /Fo$@ $(WIDGETS_CXXFLAGS) $**
|
||||||
|
|
||||||
$(OBJS)\widgets_listbox.obj: .\listbox.cpp
|
$(OBJS)\widgets_listbox.obj: .\listbox.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(WIDGETS_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(WIDGETS_CXXFLAGS) $**
|
||||||
|
|
||||||
|
@@ -229,6 +229,7 @@ WIDGETS_OBJECTS = &
|
|||||||
$(OBJS)\widgets_combobox.obj &
|
$(OBJS)\widgets_combobox.obj &
|
||||||
$(OBJS)\widgets_datepick.obj &
|
$(OBJS)\widgets_datepick.obj &
|
||||||
$(OBJS)\widgets_gauge.obj &
|
$(OBJS)\widgets_gauge.obj &
|
||||||
|
$(OBJS)\widgets_hyperlnk.obj &
|
||||||
$(OBJS)\widgets_listbox.obj &
|
$(OBJS)\widgets_listbox.obj &
|
||||||
$(OBJS)\widgets_notebook.obj &
|
$(OBJS)\widgets_notebook.obj &
|
||||||
$(OBJS)\widgets_radiobox.obj &
|
$(OBJS)\widgets_radiobox.obj &
|
||||||
@@ -283,6 +284,9 @@ $(OBJS)\widgets_datepick.obj : .AUTODEPEND .\datepick.cpp
|
|||||||
$(OBJS)\widgets_gauge.obj : .AUTODEPEND .\gauge.cpp
|
$(OBJS)\widgets_gauge.obj : .AUTODEPEND .\gauge.cpp
|
||||||
$(CXX) -bt=nt -zq -fo=$^@ $(WIDGETS_CXXFLAGS) $<
|
$(CXX) -bt=nt -zq -fo=$^@ $(WIDGETS_CXXFLAGS) $<
|
||||||
|
|
||||||
|
$(OBJS)\widgets_hyperlnk.obj : .AUTODEPEND .\hyperlnk.cpp
|
||||||
|
$(CXX) -bt=nt -zq -fo=$^@ $(WIDGETS_CXXFLAGS) $<
|
||||||
|
|
||||||
$(OBJS)\widgets_listbox.obj : .AUTODEPEND .\listbox.cpp
|
$(OBJS)\widgets_listbox.obj : .AUTODEPEND .\listbox.cpp
|
||||||
$(CXX) -bt=nt -zq -fo=$^@ $(WIDGETS_CXXFLAGS) $<
|
$(CXX) -bt=nt -zq -fo=$^@ $(WIDGETS_CXXFLAGS) $<
|
||||||
|
|
||||||
|
@@ -10,6 +10,7 @@
|
|||||||
combobox.cpp
|
combobox.cpp
|
||||||
datepick.cpp
|
datepick.cpp
|
||||||
gauge.cpp
|
gauge.cpp
|
||||||
|
hyperlnk.cpp
|
||||||
listbox.cpp
|
listbox.cpp
|
||||||
notebook.cpp
|
notebook.cpp
|
||||||
radiobox.cpp
|
radiobox.cpp
|
||||||
|
@@ -488,6 +488,10 @@ SOURCE=.\gauge.cpp
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\hyperlnk.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=.\listbox.cpp
|
SOURCE=.\listbox.cpp
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
Reference in New Issue
Block a user