ShellViewModel.cs 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. // Copyright (c) 2012-2018 fo-dicom contributors.
  2. // Licensed under the Microsoft Public License (MS-PL).
  3. using Caliburn.Micro;
  4. using Dicom;
  5. using Dicom.Imaging;
  6. using SimpleViewer.Universal.Services;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Linq;
  10. using System.Threading.Tasks;
  11. using Windows.UI.Xaml.Media;
  12. namespace SimpleViewer.Universal.ViewModels
  13. {
  14. public class ShellViewModel : PropertyChangedBase
  15. {
  16. #region FIELDS
  17. private readonly IDicomFileReaderService _readerService;
  18. private DicomFile _file;
  19. private int _currentImageIndex;
  20. private IList<ImageSource> _images;
  21. private int _numberOfImages;
  22. #endregion
  23. #region CONSTRUCTORS
  24. public ShellViewModel(IDicomFileReaderService readerService)
  25. {
  26. _readerService = readerService;
  27. }
  28. #endregion
  29. #region PROPERTIES
  30. public DicomFile File
  31. {
  32. get
  33. {
  34. return _file;
  35. }
  36. private set
  37. {
  38. if (Equals(value, _file))
  39. {
  40. return;
  41. }
  42. _file = value;
  43. NotifyOfPropertyChange(() => File);
  44. }
  45. }
  46. public int NumberOfImages
  47. {
  48. get
  49. {
  50. return _numberOfImages;
  51. }
  52. set
  53. {
  54. if (value == _numberOfImages)
  55. {
  56. return;
  57. }
  58. _numberOfImages = value;
  59. NotifyOfPropertyChange(() => NumberOfImages);
  60. CurrentImageIndex = 0;
  61. }
  62. }
  63. public int CurrentImageIndex
  64. {
  65. get
  66. {
  67. return _currentImageIndex;
  68. }
  69. set
  70. {
  71. _currentImageIndex = value;
  72. NotifyOfPropertyChange(() => CurrentImageIndex);
  73. NotifyOfPropertyChange(() => CurrentImage);
  74. }
  75. }
  76. public ImageSource CurrentImage
  77. => NumberOfImages > 0 ? _images[Math.Max(CurrentImageIndex - 1, 0)] : null;
  78. #endregion
  79. #region METHODS
  80. public async Task OpenFiles()
  81. {
  82. var files = await _readerService.GetFilesAsync();
  83. if (files == null || files.Count == 0)
  84. {
  85. return;
  86. }
  87. _images = null;
  88. File = null;
  89. NumberOfImages = 0;
  90. if (files.Count == 1)
  91. {
  92. File = files.Single();
  93. }
  94. var imageFiles = files.Where(f => f.Dataset.Contains(DicomTag.PixelData)).ToList();
  95. if (imageFiles.Count > 0)
  96. {
  97. _images = imageFiles.SelectMany(
  98. imageFile =>
  99. {
  100. try
  101. {
  102. var dicomImage = new DicomImage(imageFile.Dataset);
  103. var frames =
  104. Enumerable.Range(0, dicomImage.NumberOfFrames)
  105. .Select(frame => dicomImage.RenderImage(frame).As<ImageSource>());
  106. return frames;
  107. }
  108. catch
  109. {
  110. return new ImageSource[0];
  111. }
  112. }).ToList();
  113. NumberOfImages = _images.Count;
  114. }
  115. }
  116. #endregion
  117. }
  118. }