Resolved Issues

Viewer Build 12

Unreleased cache references in CDcvStudy

When the user interrupts image downloading, e.g., by closing a study while it is loading, the viewer fails to release some cache object references, leading to a resource leak.  This has been resolved.

Viewer Build 11

Fuzzy images in the CD viewer

If the scheduler is interrupted when the CD viewer is loading images, the study being processed might not complete because the scheduler thread didn’t get restarted. As a result, some images would not be fully processed/decompressed.

Memory leak when there was an invalid study loading

If study load was interrupted when parsing the pbs file, the viewer might not free the study data container, leading to a memory resource leak.

Wrong error handling in image CClipRegion

If the call to draw an image failed to acquire a lock, it returned an error code the viewer didn’t recognize, resulting in inconsistent behavior.

Temp pump calls only one read task

For non-image data downloads, the temp pump was set to make a single request for data. If the data was greater than the requested size (32K), the remaining data was not downloaded.

Misleading info in the "Lock broken" messages

An uninitialized lock age parameter could result in misleading data in a broken log message. To accommodate very old locks, the lock age variable was increased from 32-bits to 64-bits.

Viewer Crash or Hang after logout and relogin

The viewer’s login dialog box was not started by the main thread. When the user logged in from the browser while this dialog was displayed, the viewer could hang or crash if they also attempted to enter data in the viewer’s login dialog box.

Viewer Build 10

Viewer doesn't set the size of thumbnails in some cases

When the viewer resampled a thumbnail image using the image in memory (rather than from the herpa data), the viewer failed to set the thumbnail image size.

Navigation not working when user changed his preference language other than English

Links embedded on the settings panel failed when the applied language profile was not English because the links referenced the page by name, which changed after selecting another language.

Viewer Build 9

UPGRADE DEPENDENCY: This viewer requires desktopApps-9.0.33 or later.

File mapping error after interrupted herpa loading causes crash

The handshake between the cache manager and the viewer (specifically the study pump) could fail if the study pump is blocked but the pump manager removes a study from the list. The cache manager could remove the references after the study closes, but the viewer might attempt to use them when it opens the same study again.

Login and logout can crash if the connection is broken

The viewer failed to handle an exception, likely the result of a broken network connection, when logging in and out of a server, resulting in a viewer crash.

Persistent dictation with Speechmike doesn't always work as expected

If the user received a popup notice while in the persistent recording state, the viewer could become stuck in that state after the popup clears and the user releases the record button.

Viewer Build 8

Issue with submitting report

When the viewer attempted to submit a report containing a status change, it could fail to include the impression data which would cause the server to hang, waiting for it. As a result, the viewer would get stuck in the closing state.  This has been resolved.

Thumbnail panel update can cause crashes at loading

When the viewer is running very slowly, for example, when a misconfigured antivirus solution is running, decompression, thumbnail creation and saving is delayed. As the viewer continues downloading the remaining compressed thumbnail data, the packets could get out-of-sync and some data can get released before it is used, causing the viewer to crash.  This has been resolved.

Stream table crash

The viewer failed to confirm a streaming task record still existed before attempting to access it.  This has been resolved.

Viewer Build 7

The WL histogram window's gradient should be inverted

The scale at the bottom of the window/level distribution graph failed to recognize the greyscale photometric interpretation setting and always assumed zero was black, resulting in an inverted distribution graph when the image is defined as MONOCHROME1.

Viewer crash: save HP with tile layout can crash with hyper streaming setting

When using streaming protocol and the visible image frame in the original layout is set to use more tiles than there are images in the series rendered to that frame, the viewer would crash.

Viewer crash: Stream study table managing

After the viewer stored the study UID in the stream server table, it incorrectly removed it when the session closed rather than when the study container was removed. If the viewer attempted to access the study referenced by the study container, it could crash.

Enable username and password fields for every tool on external reporting settings page

The availability of a configurable user name and password to include in the XML file when dropped was applied to external reporting solutions with the specific label “XML Interface Speech Recognition” rather than any XML file drop solution.

Viewer Build 6

WMI update call can cause deadlock

When updating the thumbnail panel after receiving a request to add a study to the session, the viewer would allocate a structure to store the new studies, overriding the previous structure. However, the viewer did not properly remove the original structure, resulting in a read/write lock conflict and a deadlock condition.

Async study dicom processing mechanism can get stuck

If the reader thread and processing thread complete at the same time, the event signal can get crossed, causing one of the threads to miss the signal and hang indefinitely.

Read write lock can cause hang

The locking mechanism could fail when the viewer attempted to allocate multiple read locks, causing a deadlock condition.

Viewer session log doesn't write the viewer type and name

The application name is taken from the resource file but not until after the resource file was loaded. As a result, the application name was missing from the session log file.

Viewer doesn't load the cached study from CWL

If the herpa data is cached on the workstation and the open request is redirected to a server (for example, from a hub server to a child server when the open request was submitted to the worklist server), the viewer failed to initiate a function causing the study parsing to remain incomplete. And when the viewer session ended, the viewer would not close because it was waiting for the thread to close first.

Thumbnail panel crashing when displaying overlay information

If the thumbnail panel’s overlay information setting changed during or after closing the study, the pointer to the thumbnail header object became invalid and caused a crash when accessed.

SetGridMode with Reuse mode crashes if the selected image is removed

After changing the grid mode setting to reuse data in populated image frames when eight or more image frames are on the screen with the selected frame being the last frame, and then changing the layout to one frame per screen, the viewer could crash because the viewer failed to update the selected image frame which no longer existed, even as a frame on a virtual monitor.

Patient Folder opening crashes

Some attempts have been made to address an unidentified crash in low-level Windows libraries when using the viewer’s patient folder.

Invalid server name causes viewer crash

If the server sent the viewer an invalid or empty stream server URL, an exception occurred but the viewer failed to catch it and crashed.

DICOM print crashes with empty ShowImageTrueSizeFlag tag

If the DICOM printer configuration contains an empty value for the true size flag setting, the viewer could crash when printing to the DICOM printer.

Spine label bugs

Spine labeling configuration data was mismanaged and the application of spine labels was mishandled, resulting in unavailable features or unintended behavior. This included the inconsistent storage of spine labels in the current XML-based storage format, improper application of spine label sets when modifying their configuration, and failure to update applied spine label values and connector lines after modifying their settings.

Loading reports dialogue persists after re-opening bookmarked study

Continuing dictation recording after restoring a bookmarked session with a partial dictation popped up a progress panel that would not disappear after reloading completed.

Stream table sorting by priority causes crash

Managing the streaming table failed to recognize a condition in which the study being removed from the table was also in the current sending list, resulting in a viewer crash.

Thumbnail panel update crashing

After removing an auto-generated presentation state image, the viewer might still attempt to update it in the thumbnail panel, causing the viewer to crash.

Light setting (Window/Level) can crash after updating

When reloading a viewer session containing an image that was updated on the server, and for which a modality-specific preset W/L setting was applied, the viewer could crash because the viewer attempted to use the general preset values instead.

Empty frames are loaded when setting grid mode as "Reuse" with the same grid layout

When populated virtual monitors exist, the viewer is configured to reuse populated frames, and the user sets the grid layout to some value twice, the second refresh displays no image in the first monitor’s frames.

VOI LUT range calculation can result in empty range

When the LUT table provided in an image object contained zeroes in both the first and last position, calculating the minimum and maximum values resulted in an error causing the viewer to crash.

Viewer Build 5

Viewer crash getting image download percentage

The viewer could crash when collecting an image’s decompression rate for the download percentage calculation because the thread was not locked.

Viewer hang using spin count of CriticalSection

A recent fix applied to restoring a bookmarked study resulted in the viewer blocking Windows application messages. One of these messages attempted to refresh a locked image, but the viewer didn’t receive the message.

Crash when creating plugin from not downloaded images

If no data has started downloading before the plugin checks to see how much data has arrived, the plugin would crash.

Deleting an image can cause viewer crash

After deleting an image or series that was exported from a plugin, the viewer failed to update the thumbnail panel. When the viewer refreshed the thumbnail panel, for any reason, the viewer would crash.

Multi finalizing call for a view at rare timing

When the viewer is loading multiple studies and processing for the last two (or more) completes at the same time, the viewer can make multiple calls declaring the session is ready to use when only one is needed.

Viewer crash at stream table update

A failure to lock the streaming table when opening a study or appending a study to an existing session resulted in a crash.

Image created by plugins creates a file remaining on the Temporary directory

Image files created by plugin modules remained in the viewer’s temp directory after uploading them to the server.

Empty outline eye icon not shown on unviewed series in the thumbnail panel

When creating a hanging protocol, the viewer failed to recognize the state of non-visible frames. As a result, series loading into non-visible frames when applying a hanging protocol displayed the incorrect viewed image icon on the thumbnail image.

Unable to append a study to an open session

A recent change eliminated a required thumbnail panel refresh. As a result, some data failed to appear in the thumbnail panel after appending a study to an active viewer session.

Empty rescale slope attribute results in a black image

A change in the DICOM library resulted in a different return code when the viewer extracted the rescale slope value from the object. As a result, a default value wasn’t applied when no value was present, causing all pixel values to set to black.

Viewer crash on unsafe thread container initialization

The process for initializing large studies with many objects was not thread-safe, causing the viewer to crash when multiple threads attempted to initialize the same container.

Viewer crash when Modality LUT data is not cleared

An uninitialized modality LUT structure in the viewer could cause the viewer to crash if the image object defined a modality LUT.

Viewer Build 4

Standalone (CD) viewer doesn't work

Changes to the caching mechanism broke the DICOM processing mechanism in the standalone viewer, causing the standalone viewer to fail image loading. Note that the standalone viewer uses the thumbnail image until the full image has been fully processed and ready for display.

Mammo CAD isn't shown in HP

The fix for missing CAD markers when restoring a bookmarked viewer session disabled automatic application of CAD markers for stored data. As a result, the viewer failed to recognize the default CAD display setting saved in hanging protocols.

Viewer Build 3

Restoring a bookmarked study can cause crashes

If the viewer received an open request, such as a second restore request, while still processing a bookmark restore request, the viewer could crash when the open request completed because it mismanaged the interrupted process.

Key image not added properly when added to prior studies

When adding a key image to a prior study, as a report addendum, the viewer failed to submit it to the server because the mechanism for sending the key image had not been updated to make the call.

Viewer crash when scanning an image

When the viewer-based scanning panel is opened from the Scan button on the worklist, some modules required the character set containers but they were not loaded, causing the viewer to crash.

Print layouts crash

If the print layout manager panel is invoked before the viewer has established a connection with the server, the viewer would crash.

Incorrect image decompression completion detection

The viewer was not checking the image data type so if it was the initial quality (IQ) image only and the remaining data did not follow (for some reason), the viewer could mislabel the image as full resolution.

The view icon on thumbnail panel isn't updated after the full image decompression

The viewer called a refresh for every decompression event, even for images that were not visible. The large number of events might cause the viewer to miss a refresh, causing the image in the thumbnail panel to remain unchanged. Now, refresh events are called for visible images only.

Incorrect compression overlay value

The compression ratio overlay field misreported its value because the calculation was not using the full uncompressed image size.

Viewer doesn't create new image data in scanner mode

After refactoring the image storing process, some data was not initialized when scanning an image, resulting in a crash.

Annotations not preserved after restoring a bookmarked MG study

When restoring an annotated, bookmarked image to an image frame, the viewer would incorrectly clear saved annotations like it does when temporary annotations exist.

Releasing mechanism of memory manager doesn't lock the data

Because the memory manager unnecessarily accessed the image data without locking it, it could use the image data while the viewer was closing the session. If the viewer released the image first, the viewer might crash.

Streaming issue: more robust error handling

When the streaming packet header is corrupted, data streaming stops and the channel needs to be reset.

Stream issue: performance measurement request cause broken packet

When the viewer requested the performance measurement data from the server, it submitted the request on the data streaming connection. When the server submitted the response on the same connection, the data interfered with the streaming data, resulting in corrupted data. The viewer now requests performance data using the control stream connection.

Viewer crash when key image objects exist without image objects

The viewer failed to handle (empty) herpa data when the study consisted of non-image objects only, resulting in a crash. Now, the viewer displays the study details in the thumbnail header and indicates no image objects exist.

Incorrect priority for full decompression

When prioritizing data for decompression, the viewer could download some non-visible images before fully downloading and decompressing visible images, causing a delay in rendering the visible images.

Viewer Build 2

DEPENDENCY NOTICE: Dependencies exist. See details below.

Herpa streaming

DEPENDENCY NOTICE: This feature requires medsrv-9.0.2.
The herpa download uses streaming through the stream server rather than HTTP from the application server.

Incorporate gwav4 compression

DEPENDENCY NOTICE: This feature requires medsrv-9.0.2.
The streaming technology has added support for gwav version 4, permitting better initial quality from smaller thumbnail images. The viewer still accepts gwav3 and gwav1, if offered by the server.

Viewer Build 1

UDI for v9 viewer

The UDI displayed in the viewer details panel has been set to 0086699400025590.

Baseline viewer code base on v8.0

The baseline code base for version 9.0 viewer is viewer-8.0.85, desktopApp-8.0.31 and plugins-8.0.8 and includes the new (v9) caching mechanism (cache into memory, only), optimized image loading and only hyper+ streaming support.

Remove settings for retired features

All configurable settings and visible indications for and about retired features have been removed, including prefetch settings, cache management settings and HTTP-based streaming settings.

Series matching algorithm performance improvement

The series matching feature used by the hanging protocol manager and for series grouping has been optimized for performance, removing unnecessary calculations as well.

Server provided stream server addresses

The viewer uses the stream server assigned by the server when streaming data during the session. If no stream server is provided, the viewer uses the server that sent the session (PBS) data.