Click here to Skip to main content
15,896,118 members
Articles / Desktop Programming / WPF

Multi-touch development with WPF - A multi-touch RSS reader

Rate me:
Please Sign up or sign in to vote.
4.94/5 (36 votes)
1 Nov 2009GPL315 min read 179.3K   5.7K   97  
A multi-touch RSS reader built with Multi-Touch Vista.
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
                    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
                    xmlns:vm="clr-namespace:VirtualDreams.TouchReader.ViewModel">
    <DataTemplate DataType="{x:Type vm:FeedItemViewModel}">
        <Border Style="{StaticResource ItemBorder}">
            <TextBlock x:Name="text"
                       Text="{Binding Title}"
                       Style="{StaticResource ItemText}" />
        </Border>
        <DataTemplate.Triggers>
            <DataTrigger Binding="{Binding IsRead}"
                         Value="False">
                <Setter TargetName="text"
                        Property="FontWeight"
                        Value="Bold" />
            </DataTrigger>
        </DataTemplate.Triggers>
    </DataTemplate>

    <DataTemplate DataType="{x:Type vm:FeedViewModel}">
        <Border Style="{StaticResource ItemBorder}">
            <DockPanel>
                <Image Source="/Resources/Images/feed.png"
                       DockPanel.Dock="Left"
                       Style="{StaticResource Icon}" />
                <TextBlock x:Name="text"
                           Text="{Binding TitleAndUnreadItemCount}"
                           Style="{StaticResource ItemText}"
                           MaxHeight="50"
                           TextTrimming="CharacterEllipsis" />
            </DockPanel>
        </Border>
        <DataTemplate.Triggers>
            <DataTrigger Binding="{Binding HasUnreadItems}"
                         Value="True">
                <Setter TargetName="text"
                        Property="FontWeight"
                        Value="Bold" />
            </DataTrigger>
        </DataTemplate.Triggers>
    </DataTemplate>

    <DataTemplate DataType="{x:Type vm:FolderViewModel}">
        <Border Style="{StaticResource ItemBorder}">
            <DockPanel>
                <Image Source="/Resources/Images/folder.png"
                       DockPanel.Dock="Left"
                       Style="{StaticResource Icon}" />
                <TextBlock Text="{Binding Title}"
                           Style="{StaticResource ItemText}"
                           MaxHeight="50"
                           TextTrimming="CharacterEllipsis" />
            </DockPanel>
        </Border>
    </DataTemplate>
</ResourceDictionary>

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article, along with any associated source code and files, is licensed under The GNU General Public License (GPLv3)


Written By
Virtual Dreams
Brazil Brazil
Hi! I'm Roberto. I'm a Brazilian Engineering student at the University of São Paulo and the Ecole Centrale de Lille (France).

I've participated in the Imagine Cup competition and went to the world finals every year from 2005 to 2009. I also won the 1st place award in 2006, in India, for the Interface Design invitational, in 2007 in Korea, for the Embedded Development invitational, and in 2009 in Egypt for the Windows Mobile Award.

Currently I keep a blog (in English and Portuguese) at http://virtualdreams.com.br/blog/ and a weekly webcast about WPF and Silverlight (in Portuguese) at http://www.xamlcast.net.

Comments and Discussions