当前位置: 首页 > wzjs >正文

虚拟主机可以做视频视频网站吗百度seo排名点击软件

虚拟主机可以做视频视频网站吗,百度seo排名点击软件,深圳网站制作公司咨询,做盗版小说网站赚钱嘛WPF中实现动态加载图片浏览器(边滚动边加载) 在做图片浏览器程序时,遇到图片数量巨大的情况(如几百张、上千张),一次性加载所有图片会导致界面卡顿甚至程序崩溃。 本文介绍一种 WPF Prism 实现动态分页加…

WPF中实现动态加载图片浏览器(边滚动边加载)

在做图片浏览器程序时,遇到图片数量巨大的情况(如几百张、上千张),一次性加载所有图片会导致界面卡顿甚至程序崩溃。

本文介绍一种 WPF + Prism 实现动态分页加载图片的方法,结合 ScrollViewer 滚动条触底检测,实现 “边滚动,边加载” 的流畅体验。

1. 界面设计:4×4 显示 + 滚动条

我们希望界面每次显示 4×4,共 16 张图片,每张图片带有边框。

XAML示例

<ScrollViewer VerticalScrollBarVisibility="Auto" ScrollChanged="ScrollViewer_ScrollChanged"><ItemsControl ItemsSource="{Binding Images}"><ItemsControl.ItemsPanel><ItemsPanelTemplate><UniformGrid Columns="4"/></ItemsPanelTemplate></ItemsControl.ItemsPanel><ItemsControl.ItemTemplate><DataTemplate><Border BorderBrush="Gray" BorderThickness="1" Margin="5"><Image Source="{Binding}" Stretch="Uniform"/></Border></DataTemplate></ItemsControl.ItemTemplate></ItemsControl>
</ScrollViewer>
  • ScrollViewer 包裹 ItemsControl,开启垂直滚动。
  • 使用 UniformGrid 布局,4列均匀分布。
  • 每张图片用 Border 包一层,美观且清晰分隔。

2. 后台逻辑:ViewModel 分页加载

ViewModel 负责管理图片列表和分页逻辑。

public class ImageBrowserViewModel : BindableBase
{private const int PageSize = 16;private readonly List<string> allImagePaths = new();public ObservableCollection<BitmapImage> Images { get; } = new();private int currentPage = 0;public bool IsLoading { get; private set; }public void LoadAllImagePaths(string folderPath){allImagePaths.Clear();var extensions = new[] { ".jpg", ".png", ".bmp" };var files = Directory.GetFiles(folderPath).Where(f => extensions.Contains(Path.GetExtension(f).ToLower())).ToList();allImagePaths.AddRange(files);currentPage = 0;Images.Clear();}public async Task LoadNextPageAsync(){if (IsLoading) return;IsLoading = true;var nextImages = allImagePaths.Skip(currentPage * PageSize).Take(PageSize).ToList();foreach (var path in nextImages){await Task.Run(() =>{var bitmap = new BitmapImage();bitmap.BeginInit();bitmap.CacheOption = BitmapCacheOption.OnLoad;bitmap.UriSource = new Uri(path);bitmap.EndInit();bitmap.Freeze();App.Current.Dispatcher.Invoke(() => Images.Add(bitmap));});}currentPage++;IsLoading = false;}
}
  • LoadAllImagePaths:一次性记录所有图片路径,但不立刻加载图片内容。
  • LoadNextPageAsync:每次按页加载图片,使用 Task.Run + Dispatcher.Invoke,避免界面卡顿。

3. 滚动到底时加载新图片

ScrollViewerScrollChanged 事件中,检测是否接近底部,如果是则请求 ViewModel 加载下一页:

private async void ScrollViewer_ScrollChanged(object sender, ScrollChangedEventArgs e)
{var scrollViewer = (ScrollViewer)sender;if (scrollViewer.VerticalOffset + scrollViewer.ViewportHeight >= scrollViewer.ExtentHeight - 50) // 接近底部50像素{if (DataContext is ImageBrowserViewModel vm && !vm.IsLoading){await vm.LoadNextPageAsync();}}
}

ExtentHeight 是总高度,ViewportHeight 是当前可视区域高度,VerticalOffset 是当前滚动位置。

当滚动接近底部 50px 内,就触发加载。

4. 总结

通过以上方法,我们实现了:

  • 初始只加载少量图片,快速打开界面。
  • 用户滚动时,按需分页加载后续图片。
  • 界面不卡顿,体验丝滑流畅。

这种设计特别适合处理大量图片浏览、视频帧查看、缩略图管理器等场景。

http://www.dtcms.com/wzjs/36403.html

相关文章:

  • 百度公司可以做网站么爱站工具包的模块有哪些
  • 西藏网站建设南宁seo全网营销
  • 哪个网站建设商招代理产品网络推广方案
  • 做网站如何让用户注册好用的视频播放器app
  • 乐温州网站建设自动推广工具
  • 花草网站有人做找seo外包公司需要注意什么
  • 网站建设的知识网络营销个人感悟小结
  • 装修公司的网站百度官网入口链接
  • 商业网页设计与制作图片seowhy培训
  • 对政府网站建设不足之处的建议g3云推广靠谱吗
  • 揭阳高端品牌网站建设扬州百度关键词优化
  • 提供佛山顺德网站设计百度快速提交入口
  • 做广告联盟怎么做网站品牌推广
  • 桌子上做嗯啊干爹网站百度安装app
  • 广东网站设计公司电话seo网站结构优化
  • 如何做好网站首页建设网络优化师是什么工作
  • 广州安全教育平台登陆优化排名案例
  • 网站内容与功能模块设计经典软文案例标题加内容
  • 如何做淘宝返利网站seo整站优化服务
  • 辽宁省工程造价百中搜优化软件靠谱吗
  • 建设公司网站源码长沙网站设计
  • 成都大型网站建设公司网站seo外包
  • 上海人才中心网站上海网站建设开发公司
  • 020网站设计培训课程网站
  • 福州网站营销陕西网站设计
  • 泸州百度做网站联系东方网络律师团队
  • 靠谱的软件下载网站想做网站找什么公司
  • 新闻网站开发的相关文献谷歌浏览器网址
  • 石家庄网站建设全包网店运营教学
  • 厦门做英文网站seo搜索引擎优化公司