//========= Copyright Valve Corporation, All rights reserved. ============// // // Purpose: // // $NoKeywords: $ //=============================================================================// #include "DemoPage.h" #include "vgui/IVGui.h" #include "vgui_controls/Controls.h" #include "tier1/KeyValues.h" #include <vgui_controls/EditablePanel.h> #include <vgui_controls/Label.h> #include <vgui_controls/ComboBox.h> using namespace vgui; // EditablePanels are panels that can create certain vgui controls // by using the function createControlByName() class EditablePanelDemo: public DemoPage { public: EditablePanelDemo(Panel *parent, const char *name); ~EditablePanelDemo(); private: EditablePanel *m_pEditablePanel; Label *m_pSpeedLabel; ComboBox *m_pInternetSpeed; }; //----------------------------------------------------------------------------- // Purpose: Constructor //----------------------------------------------------------------------------- EditablePanelDemo::EditablePanelDemo(Panel *parent, const char *name) : DemoPage(parent, name) { // Create an EditablePanel. m_pEditablePanel = new EditablePanel(this, "AnEditablePanel"); // Set its position and size m_pEditablePanel->SetSize(400, 200); m_pEditablePanel->SetPos(0, 0); // Add a child Label panel to the EditablePanel m_pSpeedLabel = (Label *)(m_pEditablePanel->CreateControlByName("Label")); // Set its parent to our editable panel. m_pSpeedLabel->SetParent(m_pEditablePanel); // Set its Position m_pSpeedLabel->SetPos(20, 30); // Set its size m_pSpeedLabel->SetSize(96,20); // Set it not to resize with the window. m_pSpeedLabel->SetAutoResize(PIN_TOPLEFT, AUTORESIZE_NO, 0, 0, 0, 0 ); // Set it visible m_pSpeedLabel->SetVisible(true); // Set it enabled m_pSpeedLabel->SetEnabled(true); // Set its tab position m_pSpeedLabel->SetTabPosition(0); // Set the text in the label m_pSpeedLabel->SetText("Internet &Speed"); // Set its text alignment m_pSpeedLabel->SetContentAlignment(Label::a_east); // Add another child panel to the EditablePanel, this time a ComboBox. // This will be the menu items of our combo box menu. // List of all the different internet speeds char *g_Speeds[] = { { "Modem - 14.4k"}, { "Modem - 28.8k"}, { "Modem - 33.6k"}, { "Modem - 56k"}, { "ISDN - 112k"}, { "DSL > 256k"}, { "LAN/T1 > 1M"}, }; // Create the combo box using the create function m_pInternetSpeed = (ComboBox *)(m_pEditablePanel->CreateControlByName("ComboBox")); // Set its parent to our editable panel. m_pInternetSpeed->SetParent(m_pEditablePanel); // Set its position next to the label. m_pInternetSpeed->SetPos(124, 30); // Set its size m_pInternetSpeed->SetSize(200, 20); // Set it not to resize with the window. m_pInternetSpeed->SetAutoResize(PIN_TOPLEFT, AUTORESIZE_NO, 0, 0, 0, 0 ); // Set it visible m_pInternetSpeed->SetVisible(true); // Set it enabled m_pInternetSpeed->SetEnabled(true); // Set its tab position m_pInternetSpeed->SetTabPosition(0); // Set its text hidden attribute m_pInternetSpeed->SetTextHidden(false); // Set it not editable m_pInternetSpeed->SetEditable(false); // Set its maxchars to -1 since it is not editable //m_pInternetSpeed->SetMaximumCharCount(-1); // Set the number of items in the combo box menu m_pInternetSpeed->SetNumberOfEditLines(ARRAYSIZE(g_Speeds)); // Set the drop down arrow button visible m_pInternetSpeed->SetDropdownButtonVisible(true); // Add menu items to this combo box. for (int i = 0; i < ARRAYSIZE(g_Speeds); i++) { m_pInternetSpeed->AddItem(g_Speeds[i], NULL ); } // Associate our label with our combo box m_pSpeedLabel->SetAssociatedControl(m_pInternetSpeed); // Now you're saying... why bother using an EditablePanel class for this? // I could have just created a panel and just created each child panel on my own // using code like this: memberLabel = new Label(NULL, NULL, "Label"); // I could have even saved many lines of code by choosing nice constructor args. // Well the real power of editable panels lies in the use of Resource Files // as seen in the next example. } //----------------------------------------------------------------------------- // Purpose: Destructor //----------------------------------------------------------------------------- EditablePanelDemo::~EditablePanelDemo() { } Panel* EditablePanelDemo_Create(Panel *parent) { return new EditablePanelDemo(parent, "EditablePanelDemo"); }