为了演示这里的问题是我的代码背后的代码
public partial class MainPage : PhoneApplicationPage
{
ObservableCollection<ABC> listTest = new ObservableCollection<ABC>();
// Constructor
public MainPage()
{
InitializeComponent();
for (int i = 0; i < 50; i++)
{
ABC conv = new ABC(string.Format("Test:{0}", i));
listTest.Add(conv);
}
testLls.ItemsSource = listTest;
}
private void Button_Tap_1(object sender, System.Windows.Input.GestureEventArgs e)
{
testLls.ScrollTo(listTest[listTest.Count - 1]);
}
private void TitlePanel_Tap_1(object sender, System.Windows.Input.GestureEventArgs e)
{
Stopwatch st = Stopwatch.StartNew();
testLls.ScrollTo(listTest[listTest.Count - 1]);
st.Stop();
Debug.WriteLine("tttt:", st.ElapsedMilliseconds);
}
class ABC
{
private string _name;
public ABC(string aa)
{
this._name = aa;
}
public string Name
{
get
{
return _name;
}
}
public Visibility GroupMemberVisibility
{
get
{
return Visibility.Collapsed;
}
}
}
}
Xaml 代码
<StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28" Tap="TitlePanel_Tap_1">
<TextBlock Text="MY APPLICATION" Style="{StaticResource PhoneTextNormalStyle}" Margin="12,0"/>
<TextBlock Text="page name" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/>
</StackPanel>
<!--ContentPanel - place additional content here-->
<Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
<phone:LongListSelector Name="testLls" VirtualizingStackPanel.VirtualizationMode="Standard" >
<phone:LongListSelector.ItemTemplate>
<DataTemplate x:Name="dtRecievedBubbleText" >
<Grid x:Name="LayoutRoot" Background="Transparent" Margin="24 0 0 14" HorizontalAlignment="Left">
<Grid.RowDefinitions>
<RowDefinition Height="14" />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>
<Grid Grid.Row="1">
<Grid.RowDefinitions>
<RowDefinition Height="Auto" />
<RowDefinition Height="Auto" />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto"/>
</Grid.ColumnDefinitions>
<Rectangle Grid.RowSpan="3" Fill="{Binding BubbleBackGroundColor}" />
<TextBlock Text="test" Visibility="{Binding GroupMemberVisibility}" FontSize="22" FontFamily="Segoe WP Semibold" Margin="12, 12, 0, 0" />
<TextBlock Grid.Row="2" Text="{Binding Name}" HorizontalAlignment="Right" Margin="0,0,12,6" FontSize="18" />
</Grid>
</Grid>
</DataTemplate>
</phone:LongListSelector.ItemTemplate>
</phone:LongListSelector>
</Grid>
在点击标题时,包含元素的长列表选择器滚动到底部。当元素的值从 30-50-100 个元素更改时,观察到的时间为 20 毫秒、744 毫秒、815 毫秒。测试是使用诺基亚 Lumia 620 完成的。
在此示例中,项目模板非常简单,但在实际场景中我的项目templates are much more complex
。因此,在那种情况下所花费的时间是1753ms for 100 elements
。
为什么这么庞大time difference
。Can this be improved
以任何方式?
有没有其他人观察到这一点?