VGUI PanelListPanel: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
No edit summary
m (Unicodifying, replaced: [[Image: → [[File: (2))
 
(5 intermediate revisions by 2 users not shown)
Line 1: Line 1:
A PanelListPanel is a vgui2 element defined in the vgui_controls library, in the file PanelListPanel.cpp. PanelListPanels are available in all source games. PanelListPanels display a list of user specified label, control pairs.
A PanelListPanel is a vgui2 element defined in the vgui_controls library, in the file PanelListPanel.cpp. PanelListPanels are available in all source games. PanelListPanels display a list of user-specified label, control pairs.


[[Image:PanelListPanel.jpg|thumb|This is a screenshot of a skeleton PanelListPanel using ImagePanels as the added controls.]]
[[File:PanelListPanel.jpg|thumb|This is a screenshot of a skeleton PanelListPanel using ImagePanels as the added controls.]]


== Example Usage ==
== Example Usage ==


Before creating anything, we first need to include our header files and use the vgui namespace.
Before creating anything, we first need to include our header files and use the vgui namespace.
<source lang=cpp>
#include <vgui_controls/Label.h>
#include <vgui_controls/ImagePanel.h>
#include <vgui_controls/PanelListPanel.h>


#include <vgui_controls/Label.h>
using namespace vgui;
#include <vgui_controls/ImagePanel.h>
</source>
#include <vgui_controls/PanelListPanel.h>
 
using namespace vgui;




Line 19: Line 20:
PanelListPanels can be created via the c++ keyword new with a simple call to PanelListPanel:
PanelListPanels can be created via the c++ keyword new with a simple call to PanelListPanel:


PanelListPanel* myPanel = new PanelListPanel(this, "myPanel");
<source lang=cpp>PanelListPanel* myPanel = new PanelListPanel(this, "myPanel");</source>




Once we have our PanelListPanel created, we can now add controls to it:
Once we have our PanelListPanel created, we can now add controls to it:


char buffer [40];
<source lang=cpp>
char buffer [40];
   
   
for (int i = 0; i < 5; i++)
for (int i = 0; i < 5; i++)
{
{
        //Create Image
// Create Image
Q_snprintf(buffer, sizeof(buffer), "image%i", i);
Q_snprintf(buffer, sizeof(buffer), "image%i", i);
ImagePanel* imagePanel = new ImagePanel( this, buffer );
ImagePanel* imagePanel = new ImagePanel( this, buffer );
  imagePanel->SetImage(scheme()->GetImage("", false));
  imagePanel->SetImage(scheme()->GetImage("", false));
   
   
         //Create Label
         // Create Label
  Q_snprintf(buffer, sizeof(buffer), "label%i", i);
  Q_snprintf(buffer, sizeof(buffer), "label%i", i);
  Label* label = new Label( this, buffer, buffer );
  Label* label = new Label( this, buffer, buffer );
  label->SetText(buffer);
  label->SetText(buffer);
   
   
         //Add Label and Image to PanelListPanel
         // Add Label and Image to PanelListPanel
  m_pList->AddItem(label, imagePanel);
  m_pList->AddItem(label, imagePanel);
}
}
</source>


With m_pList being a pointer to the PanelListPanel.
With m_pList being a pointer to the PanelListPanel.


Its also important to note that scheme::GetImage begins from "materials/vgui" and no extensions should be provided. So, scheme()->GetImage("vgui/eye", false) would really point to "materials/vgui/vgui/eye.vmt".
Its also important to note that scheme::GetImage's first argument begins from "materials/vgui" and no extensions should be provided. So, scheme()->GetImage("vgui/eye", false) would really point to "materials/vgui/vgui/eye.vmt".




Lastly we'll set the control size and make it visible.
Lastly we'll set the control size and make it visible.
void CExample::PerformLayout()
<source lang=cpp>
{
void CExample::PerformLayout()
BaseClass::PerformLayout();
{
BaseClass::PerformLayout();
m_pList->SetBounds( 280, 300, 200, 200 ); //posX, posY, width, height
 
        m_pList->SetVisible( true );
m_pList->SetBounds( 280, 300, 200, 200 ); //posX, posY, width, height
}
m_pList->SetVisible( true );
}
</source>




Line 65: Line 70:


* Adding labels to to the list is optional. If you do not want to add a label to the control, you can call AddItem with a NULL label.
* Adding labels to to the list is optional. If you do not want to add a label to the control, you can call AddItem with a NULL label.
  m_pList->AddItem(NULL, imagePanel);
  <source lang=cpp>m_pList->AddItem(NULL, imagePanel);</source>




* The size of the leftmost column (reserved for labels) can be adjusted by calling SetFirstColumnWidth(int)
* The size of the leftmost labels column can be adjusted by calling SetFirstColumnWidth(int)




Line 75: Line 80:
== Known Problems With PanelListPanel ==
== Known Problems With PanelListPanel ==


[[Image:PanelListPanelBug.jpg|thumb|Notice that the labels are stacked ontop of eachother.]]
[[File:PanelListPanelBug.jpg|thumb|Notice that the labels are stacked ontop of eachother.]]


* On multi-columned PanelListPanels, the labels are stacked ontop of eachother.
* On multi-columned PanelListPanels, the labels are stacked ontop of eachother.


[[Category:VGUI_Controls|P]]
[[Category:VGUI_Controls|P]]

Latest revision as of 00:19, 7 January 2024

A PanelListPanel is a vgui2 element defined in the vgui_controls library, in the file PanelListPanel.cpp. PanelListPanels are available in all source games. PanelListPanels display a list of user-specified label, control pairs.

This is a screenshot of a skeleton PanelListPanel using ImagePanels as the added controls.

Example Usage

Before creating anything, we first need to include our header files and use the vgui namespace.

#include <vgui_controls/Label.h>
#include <vgui_controls/ImagePanel.h>
#include <vgui_controls/PanelListPanel.h>

using namespace vgui;


These next two blocks of code generally should be added to the constructor.


PanelListPanels can be created via the c++ keyword new with a simple call to PanelListPanel:

PanelListPanel* myPanel = new PanelListPanel(this, "myPanel");


Once we have our PanelListPanel created, we can now add controls to it:

char buffer [40];
 
for (int i = 0; i < 5; i++)
{
	// Create Image
	Q_snprintf(buffer, sizeof(buffer), "image%i", i);
	ImagePanel* imagePanel = new ImagePanel( this, buffer );
 	imagePanel->SetImage(scheme()->GetImage("", false));
 
        // Create Label
 	Q_snprintf(buffer, sizeof(buffer), "label%i", i);
 	Label* label = new Label( this, buffer, buffer );
 	label->SetText(buffer);
 
        // Add Label and Image to PanelListPanel
 	m_pList->AddItem(label, imagePanel);
}

With m_pList being a pointer to the PanelListPanel.

Its also important to note that scheme::GetImage's first argument begins from "materials/vgui" and no extensions should be provided. So, scheme()->GetImage("vgui/eye", false) would really point to "materials/vgui/vgui/eye.vmt".


Lastly we'll set the control size and make it visible.

void CExample::PerformLayout()
{
	BaseClass::PerformLayout();

	m_pList->SetBounds( 280, 300, 200, 200 ); //posX, posY, width, height
	m_pList->SetVisible( true );
}


And we're done!

Interesting Notes

  • While the latest episodic code does not support multiple columns, the orangebox code might (needs verification).


  • Adding labels to to the list is optional. If you do not want to add a label to the control, you can call AddItem with a NULL label.
m_pList->AddItem(NULL, imagePanel);


  • The size of the leftmost labels column can be adjusted by calling SetFirstColumnWidth(int)


  • You can download my Custom VGUI Control, VGUI ControlGrid, to add support for multiple columns (if you don't already have it) and to fix the bug mentioned below.

Known Problems With PanelListPanel

Notice that the labels are stacked ontop of eachother.
  • On multi-columned PanelListPanels, the labels are stacked ontop of eachother.