For a project I have implemented a small IntelliSense like control which is nothing than a ListBox
. Its DataTemplate
consist of a StackPanel
holding one Image
and one TextBlock
. Nothing else. As you can see in the first screenshot of my control, the selection box of the ListBox selects the whole item (which usually is exactly what one would expect):
However my "stolen" icons from VS11 are low-quality so I wanted to adjust the selection like Visual Studio does:
You can see that only the text is selected (the visual representation does ignore the image/icon) and I want to know how I can implement this behavior, too.
EDIT: The icons are just GIF files with a transparent background. I will replace them with better ones, but nevertheless I am interestes in how to get the desired behavior.
Your problem is due to the way WPF renders each item in the ListBox. It uses an ItemContainerStyle which wraps each item in a ListBoxItem. It is this ListBoxItem that contains the content to be displayed (in your case a StackPanel that contains an Image and a TextBlock).
By default, the ListBoxItem displays the blue rectangle around all content that it displays.
I have come up with a solution but it is a hack. Simply make your image larger and have the background pixel colour match the background colour of the Listbox (in my case, white) and use the following XAML.
This is the result:
Update
I have come up with a modification which makes this a little less of a hack. In my ItemTemplate I have surrounded the image with a Border which uses binding to get its background colour from it's parent ListBox. (The image no longer has a border around it).
Update the XAML to this:
This is the new result:
Now all you need to do is update the background colour of the ListBox and everything will adjust automatically. E.G.
Here's a solution by replacing the ListBoxItem control template. In my test I just display two text strings, with the second one highlighted.
The view model contains a collection of simple data items
Giving