-
Notifications
You must be signed in to change notification settings - Fork 12
Backlog
Richard Domander edited this page Aug 13, 2018
·
33 revisions
This page catalogues ideas for future enhancements and fixes to BoneJ code. The idea is that the team creates issues and project notes from these, after they've decided which go to the next release. Some items are here, because they're waiting for technology to mature, e.g. SciView. Some items also need discussion before we decide to work on them.
- Complete GitHub recommended community standards
- PR template could be useful, but do we really need a code of conduct?
- Credit the authors of Skeletonize / AnalyzeSkeleton / Thickness in the wrappers. We should make clear that we're calling other peoples' code, even if we provide support on the forum.
- Implement dynamic setup dialogs by extending
DynamicCommand
- Having callBacks, verifiers and persistent @Parameters makes this difficult. You can use
AbstractModule.initialize()
to setup your saved values correctly, when they depend on each other. However this creates problems when your plug-in gets called throughCommandService.run
, i.e. inputs are ignored / overridden. See this forum post for more details.
- Having callBacks, verifiers and persistent @Parameters makes this difficult. You can use
- Change
uiService.showDialog
tostatusService.showStatus
in case of warnings- Pros:
showStatus
doesn't interrupt plug-in - Cons: user might miss the warning
- Pros:
- When messages for contingency checks become possible, add explanations to Ops why matchings fail
- Add unit tests to
sc.fiji.LocalThickness_
from legacy BoneJ - Remove remaining dependencies to ImageJ3D from the Legacy module
- Fix
ImageCheck.checkEnvironment()
in Legacy. Only check for ImageJ3D where necessary - Add BoneJ1 style usage reporting to wrapper plug-ins
- Should all the results of the wrappers be output @Parameters in case someone wants to run them headless or from scripts?
- It is possible to grab results from the
SharedTable
, but it's not as handy. Also not all results are there. - We don't know yet how post-processors will automatically display different types of results, i.e. a
@Parameter Double importantMeasure
could be displayed in a dialog in addition to our table. To avoid this we'd have to code a custom post-processor (a lot of work), or hack the wrapper so that it leaves output parametersnull
unless the plug-in is running headless. - Someone writing a script might as well call the ops our wrappers call, even though they do calculate some simple derived results, e.g. degree of anisotropy from the radii of an ellipsoid returned by
QuadricToEllipsoid
- It is possible to grab results from the
-
@Parameter ImagePlus
doesn't work without the legacy UI (because autoconversion / legacy input harvester is not activated..?) - Investigate persistence issues (parameters stop remembering their changed values)
-
MetadataViewer
tool for SCIFIO formats such as Kontron IMG (or wait ImageJ2/Fiji to implement support)- Metadata harvested by SCIFIO is not shown in the image info dialog (the
i
key)
- Metadata harvested by SCIFIO is not shown in the image info dialog (the
- Anisotropy for 2D images
- Either anisotropy wrapper should accept both 2D / 3D and choose appropriate ops, or we create a separate 2D wrapper
- Use SciView for rendering like ImageJ3DViewer is used in BoneJ1
- We should wait for SciView to further integrate with Fiji for two reasons:
- No need to worry about supplying native libraries from BoneJ update site (which might break peoples' ImageJ)
- No need to worry about people having JRE with JavaFX libraries. In the future either Fiji will ship with JavaFX, or SciView will drop JavaFX.
- SciView will (very likely) become the go-to renderer for Fiji
- We should wait for SciView to further integrate with Fiji for two reasons:
- A boolean parameter to filter outlier points before calling
Quadric
op
- A boolean parameter to limit calculations to ROIs
- Wait until modern ROIs have been implemented
- Should Δχ be calculated by implementing χ for 2D faces, 1D edges and 0D vertices as here? Should we add euler characteristic ops for 2D, 1D and 0D?
- Plot log(n) / log(m) data points
- Add goodness of fit output
- The pQCT file reader needs to support the additional metadata in the
.typ
files- See
ExportHeader
andCTHeaderReader
insc.fiji.pQCT_
- See