Como alterar o layout de um controle DataRepeater (Visual Studio)
O DataRepeater controle pode ser exibido em um horizontal (itens de rolagem horizontal) ou vertical (itens de rolagem vertical) orientação. Você pode alterar a orientação em tempo de design ou em tempo de execução alterando a LayoutStyle propriedade. Se você alterar o LayoutStyle propriedade em tempo de execução, você talvez também queira redimensionar a ItemTemplate e reposicionar os controles filho.
Dica
Caso seja reposicionado controles sobre o ItemTemplate em tempo de execução, você precisará chamar o BeginResetItemTemplate e EndResetItemTemplate métodos no início e no final do bloco de código que reposiciona os controles.
Para alterar o layout em tempo de design
No Windows Forms Designer, selecione o DataRepeater controle.
Dica
Você deve selecionar a borda externa da DataRepeater o controle clicando na região inferior do controle, não na parte superior ItemTemplate região.
Na janela Properties, defina a LayoutStyle propriedade para um Vertical ou Horizontal.
Para alterar o layout em tempo de execução
Adicione o seguinte código para um botão ou menu Click manipulador de eventos:
' Switch the orientation. If DataRepeater1.LayoutStyle = PowerPacks.DataRepeaterLayoutStyles.Vertical Then DataRepeater1.LayoutStyle = PowerPacks.DataRepeaterLayoutStyles.Horizontal Else DataRepeater1.LayoutStyle = PowerPacks.DataRepeaterLayoutStyles.Vertical End If
// Switch the orientation. if (dataRepeater1.LayoutStyle == DataRepeaterLayoutStyles.Vertical) { dataRepeater1.LayoutStyle = DataRepeaterLayoutStyles.Horizontal; } else { dataRepeater1.LayoutStyle = DataRepeaterLayoutStyles.Vertical; }
Na maioria dos casos, você desejará adicionar código semelhante ao mostrado na seção exemplo para redimensionar o ItemTemplate e reorganizar os controles para se ajustar à nova orientação.
Exemplo
O exemplo a seguir mostra como responder para o LayoutStyleChanged evento em um manipulador de eventos. Este exemplo requer que você tenha um DataRepeater controle denominado DataRepeater1 em um formulário e que seu ItemTemplate conter dois TextBox controles denominados TextBox1 e TextBox2.
Private Sub DataRepeater1_LayoutStyleChanged(ByVal sender As Object,
ByVal e As System.EventArgs) Handles DataRepeater1.LayoutStyleChanged
' Call a method to re-initialize the template.
DataRepeater1.BeginResetItemTemplate()
If DataRepeater1.LayoutStyle =
PowerPacks.DataRepeaterLayoutStyles.Vertical Then
' Change the height of the template and rearrange the controls.
DataRepeater1.ItemTemplate.Height = 150
DataRepeater1.ItemTemplate.Controls(TextBox1.Name).Location =
New Point(20, 40)
DataRepeater1.ItemTemplate.Controls(TextBox2.Name).Location =
New Point(150, 40)
Else
' Change the width of the template and rearrange the controls.
DataRepeater1.ItemTemplate.Width = 150
DataRepeater1.ItemTemplate.Controls(TextBox1.Name).Location =
New Point(40, 20)
DataRepeater1.ItemTemplate.Controls(TextBox2.Name).Location =
New Point(40, 150)
End If
' Apply the changes to the template.
DataRepeater1.EndResetItemTemplate()
End Sub
private void dataRepeater1_LayoutStyleChanged_1(object sender, EventArgs e)
{
// Call a method to re-initialize the template.
dataRepeater1.BeginResetItemTemplate();
if (dataRepeater1.LayoutStyle == DataRepeaterLayoutStyles.Vertical)
// Change the height of the template and rearrange the controls.
{
dataRepeater1.ItemTemplate.Height = 150;
dataRepeater1.ItemTemplate.Controls["TextBox1"].Location = new Point(20, 40);
dataRepeater1.ItemTemplate.Controls["TextBox2"].Location = new Point(150, 40);
}
else
{
// Change the width of the template and rearrange the controls.
dataRepeater1.ItemTemplate.Width = 150;
dataRepeater1.ItemTemplate.Controls["TextBox1"].Location = new Point(40, 20);
dataRepeater1.ItemTemplate.Controls["TextBox2"].Location = new Point(40, 150);
}
// Apply the changes to the template.
dataRepeater1.EndResetItemTemplate();
}
Consulte também
Tarefas
Solucionando problemas do controle DataRepeater (Visual Studio)
Como alterar a aparência de um controle DataRepeater (Visual Studio)