ListBox.HorizontalExtent Propriedade
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Obtém ou define a largura pela qual a barra de deslocamento horizontal de um ListBox can scroll.
public:
property int HorizontalExtent { int get(); void set(int value); };
public int HorizontalExtent { get; set; }
member this.HorizontalExtent : int with get, set
Public Property HorizontalExtent As Integer
Valor de Propriedade
A largura, em pixels, que a barra de scroll horizontal pode fazer scroll no controlo. O padrão é zero.
Exemplos
O exemplo de código seguinte demonstra como usar as HorizontalScrollbar propriedades e HorizontalExtent para mostrar uma barra de deslocamento horizontal que mostra todo o texto dos itens no ListBox controlo. O exemplo também utiliza a IntegralHeight propriedade para garantir que os itens não são parcialmente exibidos devido ao tamanho do ListBox controlo. Este exemplo exige que um ListBox controlo, chamado listBox1, tenha sido adicionado a uma forma.
private:
void DisplayHScroll()
{
// Make sure no items are displayed partially.
listBox1->IntegralHeight = true;
// Add items that are wide to the ListBox.
for ( int x = 0; x < 10; x++ )
{
listBox1->Items->Add( String::Format( "Item {0} is a very large value that requires scroll bars", x ) );
}
// Display a horizontal scroll bar.
listBox1->HorizontalScrollbar = true;
// Create a Graphics object to use when determining the size of the largest item in the ListBox.
Graphics^ g = listBox1->CreateGraphics();
// Determine the size for HorizontalExtent using the MeasureString method using the last item in the list.
int hzSize = (int)g->MeasureString( dynamic_cast<String^>(listBox1->Items[ listBox1->Items->Count - 1 ]), listBox1->Font ).Width;
// Set the HorizontalExtent property.
listBox1->HorizontalExtent = hzSize;
}
private void DisplayHScroll()
{
// Make sure no items are displayed partially.
listBox1.IntegralHeight = true;
// Add items that are wide to the ListBox.
for (int x = 0; x < 10; x++)
{
listBox1.Items.Add("Item " + x.ToString() + " is a very large value that requires scroll bars");
}
// Display a horizontal scroll bar.
listBox1.HorizontalScrollbar = true;
// Create a Graphics object to use when determining the size of the largest item in the ListBox.
Graphics g = listBox1.CreateGraphics();
// Determine the size for HorizontalExtent using the MeasureString method using the last item in the list.
int hzSize = (int) g.MeasureString(listBox1.Items[listBox1.Items.Count -1].ToString(),listBox1.Font).Width;
// Set the HorizontalExtent property.
listBox1.HorizontalExtent = hzSize;
}
Private Sub DisplayHScroll()
' Make sure no items are displayed partially.
listBox1.IntegralHeight = True
Dim x As Integer
' Add items that are wide to the ListBox.
For x = 0 To 10
listBox1.Items.Add("Item " + x.ToString() + " is a very large value that requires scroll bars")
Next x
' Display a horizontal scroll bar.
listBox1.HorizontalScrollbar = True
' Create a Graphics object to use when determining the size of the largest item in the ListBox.
Dim g As System.Drawing.Graphics = listBox1.CreateGraphics()
' Determine the size for HorizontalExtent using the MeasureString method using the last item in the list.
Dim hzSize As Integer = g.MeasureString(listBox1.Items(listBox1.Items.Count - 1).ToString(), listBox1.Font).Width
' Set the HorizontalExtent property.
listBox1.HorizontalExtent = hzSize
End Sub
Observações
Esta propriedade só reporta um valor útil se a HorizontalScrollbar propriedade estiver definida para true. Se a largura do ListBox for menor do que o valor desta propriedade, a barra horizontal de scroll desliza horizontalmente os itens no ListBox. Se a largura de o ListBox for igual ou maior que este valor, a barra de deslocamento horizontal fica oculta. O valor desta propriedade não é atualizado dinamicamente pelo ListBox. Esta propriedade é útil quando os itens ListBox são desenhados pelo proprietário. Por exemplo, se o proprietário desenhou os itens de têm ListBox 200 pixels de largura, mas os ListBox têm 60 pixels, a HorizontalExtent propriedade teria de ser definida para 200 para que se possa deslocar a borda direita dos itens para a região visível do controlo.