数据绑定 ItemsControl 中的 wpf 自动滚动项目(如新闻滚动条)

发布于 2024-11-19 22:38:41 字数 630 浏览 6 评论 0原文

我正在为我的应用程序创建一个消息自动收录器。

 <UserControl.Resources>
    <DataTemplate x:Key="MessagesDataTemplate">
        <TextBlock 
           FontWeight="Bold" 
           FontSize="12" 
           Text="{Binding Path=Message}" 
           Height="30" 
           Margin="2"/>
    </DataTemplate>
</UserControl.Resources>

<Grid>
    <ItemsControl 
       ItemsSource="{Binding Messages}" 
       ItemTemplate="{StaticResource MessagesDataTemplate}">          
    </ItemsControl>
</Grid>

我想显示一个消息项目(即 TextBlock)5 秒钟,然后移动到下一个项目(垂直)。

有人可以指导我吗?

I am creating a messages ticker for my application.

 <UserControl.Resources>
    <DataTemplate x:Key="MessagesDataTemplate">
        <TextBlock 
           FontWeight="Bold" 
           FontSize="12" 
           Text="{Binding Path=Message}" 
           Height="30" 
           Margin="2"/>
    </DataTemplate>
</UserControl.Resources>

<Grid>
    <ItemsControl 
       ItemsSource="{Binding Messages}" 
       ItemTemplate="{StaticResource MessagesDataTemplate}">          
    </ItemsControl>
</Grid>

I want to display a Message item (i.e. the TextBlock) for 5 seconds then move to the next item (vertically).

Can anyone guide me on this please?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

只是偏爱你 2024-11-26 22:38:41

我创建了一个样本
这是 xaml 和该

<UserControl x:Class="WpfApplication1.MessageTicker"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
             xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
             mc:Ignorable="d" Height="30">
     <UserControl.Resources>
    <DataTemplate x:Key="MessagesDataTemplate">
        <Grid x:Name="grid" RenderTransformOrigin="0.5,0.5">
            <Grid.Resources>
                <Storyboard x:Key="sb2">
                    <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleX)" >
                        <EasingDoubleKeyFrame KeyTime="0:0:1" Value="2"/>
                    </DoubleAnimationUsingKeyFrames>
                    <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleY)" >
                        <EasingDoubleKeyFrame KeyTime="0:0:1" Value="2"/>
                    </DoubleAnimationUsingKeyFrames>
                    <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleX)" >
                        <EasingDoubleKeyFrame KeyTime="0:0:1" Value="2"/>
                        <EasingDoubleKeyFrame KeyTime="0:0:2" Value="1"/>
                    </DoubleAnimationUsingKeyFrames>
                    <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleY)">
                        <EasingDoubleKeyFrame KeyTime="0:0:1" Value="2"/>
                        <EasingDoubleKeyFrame KeyTime="0:0:2" Value="1"/>
                    </DoubleAnimationUsingKeyFrames>
                </Storyboard>
            </Grid.Resources>
            <Grid.RenderTransform>
                <TransformGroup>
                    <ScaleTransform ScaleX="1" ScaleY="1"/>
                    <SkewTransform/>
                    <RotateTransform/>
                    <TranslateTransform/>
                </TransformGroup>
            </Grid.RenderTransform>
            <Grid.Style>
                <Style>
                    <Style.Triggers>
                        <DataTrigger Binding="{Binding RelativeSource={RelativeSource Mode=FindAncestor,AncestorType={x:Type ListBoxItem}},Path=IsSelected}" Value="True">
                            <DataTrigger.EnterActions>
                                <BeginStoryboard Storyboard="{StaticResource sb2}"> 

                                </BeginStoryboard>
                            </DataTrigger.EnterActions>
                        </DataTrigger>
                    </Style.Triggers>
                </Style>
            </Grid.Style>
            <TextBlock 
       FontWeight="Bold" 
       FontSize="12" 
       Text="{Binding Path=Message}" 
       Height="30" 
       Margin="2"/>
        </Grid>
    </DataTemplate>
</UserControl.Resources>

<Grid>
    <ListBox BorderThickness="0" BorderBrush="Transparent" Name="messagesLB"
   ItemsSource="{Binding Messages}" 
   ItemTemplate="{StaticResource MessagesDataTemplate}">
    </ListBox>
</Grid>
</UserControl>

代码隐藏的代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.Windows.Threading;

namespace WpfApplication1
{
    /// <summary>
    /// Interaction logic for MessageTicker.xaml
    /// </summary>
    public partial class MessageTicker : UserControl
    {
        public MessageTicker()
        {
            InitializeComponent();
            List<Temp> Messages = new List<Temp>();
            for (int i = 0; i < 10; i++)
            {
                Messages.Add(new Temp { Message = "Message" + i });
            }
            messagesLB.ItemsSource = Messages;
            DispatcherTimer dt = new DispatcherTimer();
            dt.Tick += new EventHandler(dt_Tick);
            dt.Interval = TimeSpan.FromSeconds(2);
            dt.Start();
        }

        void dt_Tick(object sender, EventArgs e)
        {
            if ((messagesLB.SelectedIndex + 1) < messagesLB.Items.Count)
                messagesLB.SelectedIndex = messagesLB.SelectedIndex + 1;
            else
                messagesLB.SelectedIndex = 0;
            messagesLB.ScrollIntoView(messagesLB.SelectedItem);
        }

        public class Temp
        {
            public string Message { get; set; }
        }
    }


}

I have created a sample
here is xaml and code behind for that

<UserControl x:Class="WpfApplication1.MessageTicker"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
             xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
             mc:Ignorable="d" Height="30">
     <UserControl.Resources>
    <DataTemplate x:Key="MessagesDataTemplate">
        <Grid x:Name="grid" RenderTransformOrigin="0.5,0.5">
            <Grid.Resources>
                <Storyboard x:Key="sb2">
                    <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleX)" >
                        <EasingDoubleKeyFrame KeyTime="0:0:1" Value="2"/>
                    </DoubleAnimationUsingKeyFrames>
                    <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleY)" >
                        <EasingDoubleKeyFrame KeyTime="0:0:1" Value="2"/>
                    </DoubleAnimationUsingKeyFrames>
                    <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleX)" >
                        <EasingDoubleKeyFrame KeyTime="0:0:1" Value="2"/>
                        <EasingDoubleKeyFrame KeyTime="0:0:2" Value="1"/>
                    </DoubleAnimationUsingKeyFrames>
                    <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleY)">
                        <EasingDoubleKeyFrame KeyTime="0:0:1" Value="2"/>
                        <EasingDoubleKeyFrame KeyTime="0:0:2" Value="1"/>
                    </DoubleAnimationUsingKeyFrames>
                </Storyboard>
            </Grid.Resources>
            <Grid.RenderTransform>
                <TransformGroup>
                    <ScaleTransform ScaleX="1" ScaleY="1"/>
                    <SkewTransform/>
                    <RotateTransform/>
                    <TranslateTransform/>
                </TransformGroup>
            </Grid.RenderTransform>
            <Grid.Style>
                <Style>
                    <Style.Triggers>
                        <DataTrigger Binding="{Binding RelativeSource={RelativeSource Mode=FindAncestor,AncestorType={x:Type ListBoxItem}},Path=IsSelected}" Value="True">
                            <DataTrigger.EnterActions>
                                <BeginStoryboard Storyboard="{StaticResource sb2}"> 

                                </BeginStoryboard>
                            </DataTrigger.EnterActions>
                        </DataTrigger>
                    </Style.Triggers>
                </Style>
            </Grid.Style>
            <TextBlock 
       FontWeight="Bold" 
       FontSize="12" 
       Text="{Binding Path=Message}" 
       Height="30" 
       Margin="2"/>
        </Grid>
    </DataTemplate>
</UserControl.Resources>

<Grid>
    <ListBox BorderThickness="0" BorderBrush="Transparent" Name="messagesLB"
   ItemsSource="{Binding Messages}" 
   ItemTemplate="{StaticResource MessagesDataTemplate}">
    </ListBox>
</Grid>
</UserControl>

Code Behind

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.Windows.Threading;

namespace WpfApplication1
{
    /// <summary>
    /// Interaction logic for MessageTicker.xaml
    /// </summary>
    public partial class MessageTicker : UserControl
    {
        public MessageTicker()
        {
            InitializeComponent();
            List<Temp> Messages = new List<Temp>();
            for (int i = 0; i < 10; i++)
            {
                Messages.Add(new Temp { Message = "Message" + i });
            }
            messagesLB.ItemsSource = Messages;
            DispatcherTimer dt = new DispatcherTimer();
            dt.Tick += new EventHandler(dt_Tick);
            dt.Interval = TimeSpan.FromSeconds(2);
            dt.Start();
        }

        void dt_Tick(object sender, EventArgs e)
        {
            if ((messagesLB.SelectedIndex + 1) < messagesLB.Items.Count)
                messagesLB.SelectedIndex = messagesLB.SelectedIndex + 1;
            else
                messagesLB.SelectedIndex = 0;
            messagesLB.ScrollIntoView(messagesLB.SelectedItem);
        }

        public class Temp
        {
            public string Message { get; set; }
        }
    }


}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文