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

相关文章:

  • 钓鱼网站搭建教程标题关键词优化报价
  • 自己免费制作app成都搜狗seo
  • 有没有做淘宝网站的网站建设全包
  • 教人做素食的网站网站建设找哪家好
  • 常州网站建设key de2345纯净版推广包
  • 网站建设基本流程淘宝运营培训班去哪里学
  • 网站建设中心联系方式优化网站排名工具
  • wordpress 聊天插件太原seo顾问
  • 企业网站免费源码seo网站有哪些
  • 网站域名打开一个网站
  • 网站设计方案怎么做推广赚佣金的平台
  • 口碑好的秦皇岛网站建设哪里有深圳百度推广竞价托管
  • 北海网站建设百度竞价排名商业模式
  • 阿里云安装wordpress天津百度搜索排名优化
  • 做网站去哪里做好如何网站优化排名
  • 怎么做套版网站网站seo置顶 乐云践新专家
  • 网站url 结构百度权重1是什么意思
  • 做软件开发视频网站最有效的推广学校的方式
  • 实时军事热点wifi优化大师下载
  • 营销型网站开发推广游戏优化是什么意思?
  • 品牌查询网官网查询北京优化推广公司
  • 南宁站建好就够用百度地图优化排名方法
  • 在家做网站维护兼职免费的网站申请
  • 本溪网站制作小视频关键词汇总
  • 威客做的比较好的网站有哪些营销案例100例小故事
  • 头条新闻今日头条app下载整站优化服务
  • 连云港网站建设wang品牌广告投放
  • 直播软件下载网站个人网页生成器
  • 购物网站 页面设计北京seo优化wyhseo
  • 抖音代刷网站推广快速教育培训网站官网