Support ListBox.HorizontalContentAlignment
See original GitHub issueVanilla WPF has ListBox.HorizontalContentAlignment. In the following scenario:
xaml:
<ListBox ItemsSource="{Binding Items}">
<ListBox.ItemTemplate>
<DataTemplate>
<TextBlock Text="{Binding .}" MouseDown="TextBlock_MouseDown"/>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
xaml.cs:
private void TextBlock_MouseDown(object sender, MouseButtonEventArgs e)
{
Debug.WriteLine("Mouse Down!");
}
The “Mouse Down!” text will be printed only if the text in the TextBox is clicked, as the TextBox “shrinks” its bounds to the size of the text. But, if we add HorizontalContentAlignment="Stretch"
to the ListBox
declaration, then the TextBox will fill the horizontal space and accept the click event anywhere on the ListBoxItem
(even outside the text).
Avalonia does not currently support ListBox.HorizontalContentAlignment
- the ask is to add it. Is there currently a workaround? Maybe using styles?
Issue Analytics
- State:
- Created 3 years ago
- Comments:8 (4 by maintainers)
Top Results From Across the Web
ListBoxItem HorizontalContentAlignment To Stretch Across ...
I ran into the same in XAML and it drove me nuts wondering why my TextBlock was not fully colored across the width....
Read more >How to align items of ListBoxItem's DataTemplate?
Here in the Balance view everything is aligned properly since I've set fixed width for the columns of Grid inside DataTemplate.
Read more >ListBoxEdit - How to horizontally stretch custom content ...
Hello,. i kinda made it work. You have to set HorizontalContentAlignment directly in the ListBoxEdit. Though i realized stretch wasnt what i ...
Read more >Silverlight (and WPF): How to make items stretch horizontally ...
A quick thought would be to assign HorizontalContentAlignment property to ... We need to specify this property for the ListBoxItem that ...
Read more >The ListBox control - The complete WPF tutorial
Please notice the HorizontalContentAlignment property that I set to Stretch on the ListBox. The default content alignment for a ListBox item is Left, ......
Read more >
Top Related Medium Post
No results found
Top Related StackOverflow Question
No results found
Troubleshoot Live Code
Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free
Top Related Reddit Thread
No results found
Top Related Hackernoon Post
No results found
Top Related Tweet
No results found
Top Related Dev.to Post
No results found
Top Related Hashnode Post
No results found
I think it works if you set
Background="Transparent"
on theTextBlock
and this style:Also, this seems to be a problem on fluent theme only:
https://github.com/AvaloniaUI/Avalonia/blob/d53920bc99fab3b0aaeb8c2f065096c071d2c388/src/Avalonia.Themes.Fluent/Controls/ListBoxItem.xaml#L21
Default theme doesn’t set
HorizontalContentAlignment
(I think the default isStretch
).If ListBoxItem is already stretched, you need to check the same property on your CheckBox. I am also not sure right now if it has Transparent (clickable) background.