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

有做酒席酒水网站吗最近比较火的关键词

有做酒席酒水网站吗,最近比较火的关键词,管理软件属于什么软件,做网站公司需要什么条件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/122710.html

相关文章:

  • 今日重点新闻seo教学平台
  • 镇平哪家网站做的好怎么推广自己的微信号
  • 手机如做网站竞价排名软件
  • 如何做好网站建设和宣传公司个人怎么做网络推广
  • 评论回复网站怎么做网络营销热点事件案例分析
  • 网站地图什么意思百度搜索量怎么查
  • 电销做网站的话术百度seo排名工具
  • 兰州appseo上首页
  • 信阳做网站优化武汉seo关键词排名
  • 教育网站开发seo是指什么职位
  • 网站开发系统学习怎么推广
  • 郑州手机网站推广公司长春网站建设定制
  • google地图嵌入网站百度投诉中心24人工客服电话
  • 做个购物商城网站多长时间谷歌seo什么意思
  • 广州企业网站制作哪家好太原首页推广
  • 微信小程序前端开发工具西宁网站seo
  • 清远做网站的公司注册百度推广账号
  • 地方门户网站运营cnzz数据统计
  • 佛山网页网站设计多少钱市场营销策略
  • 做网站在手机端预览乱码了seo外链发布平台
  • 海南网站公司模板免费网站建设
  • 网站app充值记账凭证怎么做友情链接
  • 昆明网站建设公司猎狐科技怎么样磁力搜索
  • 怎么做微拍网站台湾永久免费加密一
  • 用dede做网站后台河南seo
  • 免费看电影的网站是什么班级优化大师电脑版
  • 用jsp做电影网站的界面电子商务软文写作
  • 长沙优化网站价格免费源码资源源码站
  • 北京手机网站开发费用小程序推广运营的公司
  • 建设外贸b2c网站百度新闻官网首页