以编程方式滚动ScrollableTextBlock控件

时间:2012-03-09 12:18:19

标签: c# windows-phone-7

由于我需要在我的一个WP7项目中显示长文本字符串,因此我添加了Alex Yakhnin's ScrollableTextBlock控件。

它按预期工作,但我需要在某些用户交互时自动滚动文本块,但控件不支持开箱即用的ScrollToVerticalOffset,我不知道如何去做。

我想删除元素并添加新元素就可以了,但我认为这对于这么简单的任务来说太过分了。

2 个答案:

答案 0 :(得分:1)

一种丑陋的解决方法是向ScrollViewer添加一个Load事件。当事件触发时,获取发送者(这是ScrollViewer,呃!)并将其存储在类级变量中。这样您就可以使用其他方法访问它,并且可以使用ScrollToVerticalOffset方法。

XAML

<PhoneApp1:ScrollableTextBlock x:Name="TextBlockOne" Margin="0,0,-12,0">
    <PhoneApp1:ScrollableTextBlock.Style>
        <Style TargetType="PhoneApp1:ScrollableTextBlock" >
            <Setter Property="Foreground" Value="{StaticResource PhoneForegroundBrush}"/>
            <Setter Property="Background" Value="Transparent"/>
            <Setter Property="FontSize" Value="{StaticResource PhoneFontSizeMedium}"/>
            <Setter Property="Padding" Value="0"/>
            <Setter Property="Template">
                <Setter.Value>
                    <ControlTemplate TargetType="PhoneApp1:ScrollableTextBlock">
                        <ScrollViewer Foreground="{TemplateBinding Foreground}"
                                      Background="{TemplateBinding Background}" 
                                      BorderBrush="{TemplateBinding BorderBrush}"
                                      BorderThickness="{TemplateBinding BorderThickness}" 
                                      Padding="{TemplateBinding Padding}"
                                      Loaded="ScrollViewer_Loaded">
                            <StackPanel Orientation="Vertical" x:Name="StackPanel" />
                        </ScrollViewer>
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>
    </PhoneApp1:ScrollableTextBlock.Style>
</PhoneApp1:ScrollableTextBlock>

C#

private ScrollViewer _scroller;

private void ScrollViewer_Loaded(object sender, System.Windows.RoutedEventArgs e)
{
    _scroller = sender as ScrollViewer;
}

private void SomeMethod()
{
    _scroller.ScrollToVerticalOffset(200d);
}

我知道这可能不是最好的解决方案,但它确实有效。希望这有帮助!

答案 1 :(得分:0)

当您已经获得ScrollViewer实例(使用FindName或其他内容)时,您需要在scroll offset上创建依赖项属性以对其进行动画处理。 This可能会对您有所帮助。