当前位置: 首页 > 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/427387.html

相关文章:

  • 坪山做网站的公司seo在线诊断工具
  • 大连网站建设仟亿科技自媒体平台有哪些
  • 北京住房和城乡建设委员会网站公告腾讯企业qq
  • 企业做网站要注意些什么问题济南优化网站关键词
  • 巧家县住房和城乡建设局网站在线seo
  • 如何用用dw做网站后台网站seo的优化怎么做
  • 创新的手机网站建设发软文是什么意思
  • 东莞东城做网站公司网站seo在线优化
  • 济南智能网站建设费用怎么申请网站
  • c语言做项目网站csdn可以推广网站
  • 网站内图片变换怎么做广东省最新新闻
  • 有网站公司源码可以重建网站吗福州网站排名推广
  • 建设工程网站怎么在百度上发布信息广告
  • 网站10m数据库做百度推广多少钱
  • 网站怎么做微信送红包活动网站排名查询软件
  • 大城 网站建设泉州全网营销
  • 网站内链工作做足万能软文模板
  • 网站建设的问题疑问优化关键词的正确方法
  • wordpress slug北京谷歌优化
  • 交互式网站如何做百度官网进入
  • 企业vi设计一般包括哪些内容北京整站线上推广优化
  • 如何看网站的ftp推广平台app
  • 个人免费网站如何做网站关键词如何优化上首页
  • 西安知名网站建设公司排名seo排名软件价格
  • 沭阳哪里可以做网站新闻摘抄2022最新5篇
  • 校园网站建设情况说明网站设计与建设
  • 网站做海外的防护网络优化工程师证书
  • 网站续费通知单企业网站优化外包
  • 大学生网站建设百度提问在线回答问题
  • 济南网站建站宁波网络营销怎么做