Difference between revisions of "Documentation/Nightly/Announcements"

From Slicer Wiki
Jump to: navigation, search
(Redirected page to Documentation/4.8/Announcements)
 
(186 intermediate revisions by 9 users not shown)
Line 1: Line 1:
<noinclude>{{documentation/versioncheck}}</noinclude>
+
#REDIRECT [[Documentation/4.8/Announcements]]
__NOTOC__
 
 
 
 
 
 
 
{|width="100%"
 
|align="center"|
 
[[image:Slicer4Announcement-HiRes.png|center|'''{{documentation/version}}''']]
 
|}
 
 
 
 
 
{|align="center" border="1" style="text-align:center; font-size:120%; border-spacing: 0; padding: 0px;" cellpadding="10"
 
|[[#Summary|Summary ]]
 
|[[#What is 3D Slicer|What is 3D Slicer]]
 
|[[#Slicer {{documentation/version}} Highlights|Slicer {{documentation/version}} Highlights]]
 
|[[#Slicer Extensions|Slicer Extensions]]
 
|[[#Other Improvements, Additions & Documentation|Other Improvements,  Additions & Documentation]]
 
|}
 
 
 
= Summary =
 
 
 
The [http://www.slicer.org/pages/Acknowledgments community] of Slicer developers is proud to announce the release of '''Slicer {{documentation/version}}'''.
 
 
 
* Slicer {{documentation/version}} introduces
 
** an improved App store, known as the extension manager, for adding capabilities to Slicer. More than 50 plug-ins are currently available.
 
** close to 400 feature improvements and bug fixes lead to improved performance and stability.
 
** augmentation of many modules.
 
 
 
* Click here to [http://download.slicer.org/ download] Slicer {{documentation/version}} for different platforms and find pointers to the source code, mailing lists and bug tracker.
 
* Please note that Slicer continues to be a research package and is not intended for clinical use. Testing of functionality is an ongoing activity with high priority, however, some features of Slicer are not fully tested.
 
* The [[Documentation/{{documentation/version}}/Training|Slicer Training]] page provides a series of courses for learning how to use Slicer. The portfolio contains self-guided presentation and sample data sets.
 
 
 
The main [http://www.slicer.org slicer.org] pages provide a guided tour to the application, training materials, and the development community.  New users should start there because we try to keep the pages organized and up to date.
 
 
 
= What is 3D Slicer =
 
Slicer is  a community platform created for the purpose of subject specific image analysis and visualization.
 
 
 
* Multi-modality imaging including, MRI, CT, US, nuclear medicine, and microscopy
 
* Multi organ from head to toe
 
* Bidirectional interface for devices
 
* Expandable and interfaced to multiple toolkits
 
 
 
There is no restriction on use, but permissions and compliance with rules are responsibility of users. For details on the license see [http://www.slicer.org/cgi-bin/License/SlicerLicenseForm.pl here]
 
 
 
= Slicer {{documentation/version}} Highlights =
 
 
 
<gallery caption="New and Improved Modules" widths="350px" heights="250px" perrow="3">
 
 
 
Image:LandmarkRegistration-4.4.png|New [[Documentation/Nightly/Modules/LandmarkRegistration|LandmarkRegistration]] module providing interactive registration and inspection.
 
 
 
Image:20141116_SubjectHierarchyAnnouncement.png|New [[Documentation/Nightly/Modules/SubjectHierarchy|Subject hierarchy]] module organizes and handles loaded data, providing processing and analysis features through plugins.
 
 
 
Image:GlyphArrow2d.png|Improved [[Documentation/{{documentation/version}}/Modules/Transforms|Transforms]] module with support for non-linear transforms, visualization of transforms in 2D and 3D, detailed transform properties view.
 
 
 
Image:ExtensionWizard-and-ExtensionsManager.png|New [[Documentation/{{documentation/version}}/Developers/ExtensionWizard|ExtensionsWizard]] tool deprecating the [[Documentation/{{documentation/version}}/Developers/ModuleWizard|ModuleWizard]]. <ul><li>This new tool separates the concepts of extensions and modules, and allows creating an extension containing several modules, as well as adding modules to an existing extension.</li><li>It allows to publish an extension source code to github.</li><li>It provides an easy way to create a pull request on the extension index.</li></ul>
 
 
 
Image:CompareVolumes-1-volume.png|New [[Documentation/{{documentation/version}}/Modules/CompareVolumes|Compare Volumes]] supports an overview of one or more volumes in the scene.
 
<ul>
 
<li>For one volume you can look at an array of equally spaced images (like [[Documentation/{{documentation/version}}/SlicerApplication/MainApplicationGUI#Slice_Viewers|LightBox mode]], but wth an independent viewer per slice.</li><li>You can have a look at one viewer per loaded volume.</li><li>You can choose a common label or background volume for each per-volume viewer.</li>
 
<li>The RevealCursor allows you to look in detail at the fg/bg layers.</li>
 
</ul>
 
 
 
Image:SlicerErrorReportDialog.png|All application error and warning messages are saved to file. Logged messages for the current and recent sessions are available from the new error report box (menu: Help / Report a bug).
 
 
 
</gallery>
 
 
 
== DICOM ==
 
 
 
* Improve [[Documentation/{{documentation/version}}/Modules/DICOM|DICOM]] support user experience
 
** Add a way to change the table densities in three levels: compact, cozy and comfortable.
 
** Re-arranged the patient, study and series search box so that the search box will be on the top of tables for both horizontal and vertical cases.
 
** Resize tables based on contents.
 
** Allow users to acknowledge all DICOM loading errors with a single click
 
** Add DICOM header viewer
 
 
 
== Transforms ==
 
 
 
* Improved integration of non rigid deformations, including grid (displacement field) and bspline transforms
 
* Interactive application of non rigid deformations to volume slices, models, markups
 
* Visualization of non rigid deformations as glyphs, grid, or contours in 2D and 3D views
 
* Detailed transform information display (type of transform, basic properties, displacement at current position)
 
* Loading/saving of oriented bspline transforms with or without additive bulk component
 
* Loading/saving of oriented grid transforms
 
* Loading/saving of transforms in h5 file format
 
 
 
== Markups ==
 
 
 
* Improved [[Documentation/{{documentation/version}}/Modules/Markups|Markups]] module user interface
 
** Add slice intersections toggle
 
** Add right click option to copy markups list
 
** Add coordinates to right click menu
 
 
 
== Editor ==
 
 
 
* Add a Sphere option to the PaintEffect to make it quicker to segment large anatomical regions that are somewhat spherical.
 
* Paint using pixel mode if brush size is too small
 
* Button effect are checked/unchecked based on the 'effect' property stored in the parameter node
 
 
 
== Extensions Manager ==
 
* Add search box
 
* Add 'More' link
 
* Load extension icon from disk
 
* Implement downloading of extension icons
 
* Install extension dependencies
 
* Add mechanism to check for extensions updates
 
 
 
=Slicer Extensions=
 
 
 
TODO: Will be generating automatically list.
 
 
 
<gallery caption="New and Improved Extensions" widths="250px" heights="150px" perrow="4">
 
 
 
<!--
 
Image:Foo.png|[[Documentation/{{documentation/version}}/Extensions/Foo|Foo]] for doing awesome stuff.{{new}}
 
-->
 
 
 
<!-- You could user either {{new}} or {{updated}} macros.
 
</gallery>
 
 
 
= Other Improvements,  Additions & Documentation =
 
 
 
== Optimization ==
 
 
 
* Improve Rendering pipeline performance optimizing observations management
 
 
 
* Reduce memory footprint (Fix memory leaks)
 
 
 
* Reduce installer size
 
 
 
* Faster image stack (png, jpg, bmp, tiff...) loading
 
 
 
== Rendering / Visualization ==
 
 
 
* Add Multi-sampling option
 
* Improved scalar bar to allow displaying of annotations in conjunction with labels.
 
* Slice Annotations: enhance the [[Documentation/{{documentation/version}}/Modules/DataProbe|DataProbe]] module providing an easy way to show/hide/customize corner annotations, ruler and color bar in the Slice viewers.
 
 
 
== CLI / SlicerExecutionModel ==
 
 
 
* Improved [http://www.kitware.com/blog/home/post/482 CLI AutoRun] ensuring slice view is not reset when inputs are updated.
 
* In developer mode do not remove CLI input and output files
 
* Reduce the chance of crashes when CLI returns result images
 
 
 
== Python scripting ==
 
 
 
* Add support for real Qt resources in Python. See [http://viewvc.slicer.org/viewvc.cgi/Slicer4?view=revision&revision=23290 r23290] for details.
 
 
 
* Improve VTK event support adding a way to specify the CallData type. See [https://github.com/Kitware/VTK/blob/0ed018620d0a3187ee2ed2831843132ca3337c97/Wrapping/Python/README_WRAP.txt#L266-296 here] for details.
 
 
 
* Bundle [http://code.google.com/p/pydicom/ pydicom] python module in Slicer package
 
 
 
* Add helper methods to <code>ScriptedLoadableModuleLogic</code> for managing parameter nodes
 
 
 
* SelfTest: Add <code>clickAndDrag()</code> method to the scripted module. It allows to send synthetic mouse events to the specified widget ([http://slicer.org/doc/html/classqMRMLSliceWidget.html qMRMLSliceWidget] or [http://slicer.org/doc/html/classqMRMLThreeDView.html qMRMLThreeDView])
 
 
 
* Improve <code>slicer.util</code> python module.
 
** Add <code>modulePath(moduleName)</code> method
 
** Add <code>resetThreeDViews/resetSliceViews</code>
 
** Add <code>VTKObservationMixin</code>
 
** Add <code>getFirstNodeByClassAndName()</code>
 
** Add <code>NodeModify</code> context manager: It allows to easily disable modified event associated with a node, and automatically re-enable them and invoking them if it applies.
 
 
 
* Markups: Add an event [http://slicer.org/doc/html/classvtkMRMLMarkupsNode.html#a527d30c581763822ef32fc14b2ab5a94ad628dfaf54f410d2f4c6bc5800aa8a30 PointEndInteractionEvent] for the end of a fiducial interaction
 
 
* TODO: Add reference to VTKv6 blog posts
 
 
 
== Other ==
 
 
 
* Help / Report a bug: Application error/warning/debug log messages are now saved to file. Added option to copy/paste log file contents of recent Slicer sessions to bug reports.
 
 
 
<!--
 
== Improved Transforms module ==
 
 
 
* Short video demonstrating the main features: https://www.youtube.com/watch?v=kZUAfR0mqqI
 
* Support non-linear transforms in the Transforms module: allow Apply, Harden, Invert transform
 
* Transform information displayed in the Transforms module (type of transform, basic properties)
 
* Transform visualization:
 
** Built into the Transforms module
 
** Three main modes: Glyphs (show an array of arrows, cones, spheres), Grid (show a deformed grid), or Contour (show isolines/isosurfaces for specified displacement magnitude values)
 
** All transform types are supported (chains of transforms as well)
 
** Visualization in the slice viewers
 
** Visualization in the 3D viewers, in the specified region (region can be a slice viewer, a volume, or a ROI widget)
 
** Real-time update: if the transform (or any visualization parameter) is changed then the visualization is updated immediately (interactive visualization while editing the transform)
 
** Built-in colormap editor
 
* MetaImage (mha), NIFTI (nii) vector volumes can be loaded as displacement field (grid) transform
 
-->
 
 
 
 
 
<gallery caption="TODO - Please add entry to illustrate awesome feature listed above" widths="250px" heights="150px" perrow="3">
 
 
 
</gallery>
 
 
 
= For Developers =
 
 
 
== Under the hood ==
 
 
 
* VolumeLogic:
 
** Add method [http://slicer.org/doc/html/classvtkSlicerVolumesLogic.html#a1fe71cc716593ac47988e71bdee736c9 ResampleVolumeToReferenceVolume]
 
** Add method [http://slicer.org/doc/html/classvtkSlicerVolumesLogic.html#ab852b66dc8108a8a544b845c0e055109 CloneVolumeWithoutImageData]
 
 
 
* Add support for user-defined stereo-viewing options
 
 
 
* Build-system
 
** Improve support for Visual Studio 2013
 
** Refactor management of external project launcher settings. See [http://viewvc.slicer.org/viewvc.cgi/Slicer4?view=revision&revision=23724 r23724]
 
** Add option <code>Slicer_ITKV3_COMPATIBILITY</code>. This option enabled by default will allow (if disabled) to build Slicer with ITKv3 compatibility later disabled and <code>ITK_USE_64BITS_IDS</code> enabled.
 
 
 
* SlicerExecutionModel: Add [https://github.com/Slicer/SlicerExecutionModel/pull/20#issue-18339466 ParameterSerializer support].
 
 
 
 
 
<gallery caption="Improved Toolkits" widths="250px" heights="150px" perrow="3">
 
Image:CTK-Logo.png|Moved from CTK [https://github.com/commontk/CTK/commit/f64b68a f64b68a] to [https://github.com/commontk/CTK/commit/1c97e54 1c97e54] (499 commits) <!-- git log --oneline f64b68acd717dab060db41e8bee3f0f30df1a58f...1c97e5426f898bc7d074e6122992d0dd12bab56b --no-merges | wc -l -->
 
Image:CTKApplauncher_Logo.png|Moved from CTKAppLauncher v0.1.11 to v0.1.14 (43 commits) <!-- git log --oneline v0.1.11..v0.1.14 --no-merges | wc -l -->
 
Image:ITK_logo.png|Moved from ITK v4.4.1 to v4.6.0 (1089 commits) <!-- git log --oneline v4.4.1..56fae27 --no-merges | wc -l -->
 
Image:OpenIGTLink-Logo.png|Moved from OpenIGTLink [https://github.com/openigtlink/OpenIGTLink/compare/66e272d...849b434 66e272d to 849b434] (53 commits) <!-- git log --no-merges  --oneline  66e272d..849b434 | wc -l -->
 
Image:Qt-logo.png |Moved from Qt 4.7.4 to Qt 4.8.6
 
Image:VTK_logo.png|Moved from VTK v5.10.1 to VTK v6.2.0 (5490 commits) <!-- git log --oneline v5.10.1..b55dad7 --no-merges | wc -l -->
 
</gallery>
 
 
 
 
 
== Looking at the Code Changes ==
 
 
 
From a git checkout you can easily see the all the commits since the time of the 4.4.0 release:
 
 
 
git log v4.3.0..HEAD
 
 
 
To see a summary of your own commits, you could use something like:
 
 
 
git log v4.3.0..HEAD  --oneline --author=pieper
 
 
 
see [https://www.kernel.org/pub/software/scm/git/docs/git-log.html the git log man page] for more options.
 
 
 
[[Release_Details#Slicer_{{documentation/version}}.0|Commit stats and full changelog]]
 
 
 
= Related Projects =
 
<gallery caption="" widths="250px" heights="150px" perrow="3">
 
</gallery>
 

Latest revision as of 05:24, 27 October 2017

Home < Documentation < Nightly < Announcements