联系人图片需要很长时间才能加载

时间:2013-07-17 07:48:11

标签: c# wpf xaml windows-phone-8 windows-phone

我正在尝试为Windows手机创建一个应用程序,它需要显示人员中心中显示的联系人列表。

这是用于显示联系人的xaml。

<toolkit:LongListMultiSelector x:Name="ContactList" IsGroupingEnabled="True" HideEmptyGroups="True">
    <toolkit:LongListMultiSelector.ItemTemplate>
        <DataTemplate>
            <StackPanel Orientation="Horizontal">
                <Border BorderThickness="2" HorizontalAlignment="Left" BorderBrush="{StaticResource PhoneAccentBrush}" >
                    <Image Source=" {Binding Converter={StaticResource ContactPictureConverter}}" Width="48" Height="48" Stretch="Fill" />
                </Border>
                <TextBlock Text="{Binding Path=DisplayName, Mode=OneWay}" />
            </StackPanel>
        </DataTemplate>
    </toolkit:LongListMultiSelector.ItemTemplate>
</toolkit:LongListMultiSelector>

这是ContactPicureConverter

public class ContactPictureConverter : System.Windows.Data.IValueConverter
{
    public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
    {
        Contact c = value as Contact;
        if (c == null) return null;

        System.IO.Stream imageStream = c.GetPicture();
        if (null != imageStream)
        {
            return Microsoft.Phone.PictureDecoder.DecodeJpeg(imageStream);
        }
        return null;
    }

    public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
    {
        throw new NotImplementedException();
    }
}

我也在构造函数中指定联系人,如下所示

    public ContactListPage()
    {
        InitializeComponent();
        Contacts cons = new Contacts();
        cons.SearchCompleted += new EventHandler<ContactsSearchEventArgs>((sender,e)=>{ContactList.DataContext=e.Results;});
        cons.SearchAsync(String.Empty, FilterKind.None, "bla");
    }

但是当我打开此页面时,联系人需要很长时间才能加载。但是,当我在人员中心打开相同的联系人列表时,它的加载速度会快得多。 那么我该怎么办才能使联系人立即加载。

1 个答案:

答案 0 :(得分:0)

您可以预加载图像并将其另存为BitmapImage。因此,每次打开页面时都不必重新加载图像。而且我认为应该有办法让他们保持同步。

创建一个新类并将新类的列表绑定到LongListMultiSelector

新课程:

支持联系, prop BitmapImage