melage 0.0.65__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- melage/__init__.py +16 -0
- melage/cli.py +4 -0
- melage/graphics/GLGraphicsItem.py +286 -0
- melage/graphics/GLViewWidget.py +595 -0
- melage/graphics/Transform3D.py +55 -0
- melage/graphics/__init__.py +8 -0
- melage/graphics/functions.py +101 -0
- melage/graphics/items/GLAxisItem.py +149 -0
- melage/graphics/items/GLGridItem.py +178 -0
- melage/graphics/items/GLPolygonItem.py +77 -0
- melage/graphics/items/GLScatterPlotItem.py +135 -0
- melage/graphics/items/GLVolumeItem.py +280 -0
- melage/graphics/items/GLVolumeItem_b.py +237 -0
- melage/graphics/items/__init__.py +0 -0
- melage/graphics/shaders.py +202 -0
- melage/main.py +270 -0
- melage/requirements22.txt +25 -0
- melage/requirements_old.txt +28 -0
- melage/resource/0circle.png +0 -0
- melage/resource/0circle_faded.png +0 -0
- melage/resource/3d.png +0 -0
- melage/resource/3d.psd +0 -0
- melage/resource/3dFaded.png +0 -0
- melage/resource/Eraser.png +0 -0
- melage/resource/EraserFaded.png +0 -0
- melage/resource/EraserX.png +0 -0
- melage/resource/EraserXFaded.png +0 -0
- melage/resource/Eraser_icon.svg +79 -0
- melage/resource/Hand.png +0 -0
- melage/resource/HandIcons_0.png +0 -0
- melage/resource/Hand_IX.png +0 -0
- melage/resource/Hand_IXFaded.png +0 -0
- melage/resource/Handsqueezed.png +0 -0
- melage/resource/Handwriting (copy).png +0 -0
- melage/resource/Handwriting.png +0 -0
- melage/resource/HandwritingMinus.png +0 -0
- melage/resource/HandwritingMinusX.png +0 -0
- melage/resource/HandwritingPlus.png +0 -0
- melage/resource/HandwritingPlusX.png +0 -0
- melage/resource/Move_icon.svg +8 -0
- melage/resource/PngItem_2422924.png +0 -0
- melage/resource/about.png +0 -0
- melage/resource/about_logo.png +0 -0
- melage/resource/about_logo0.png +0 -0
- melage/resource/action_check.png +0 -0
- melage/resource/action_check_OFF.png +0 -0
- melage/resource/arrow).png +0 -0
- melage/resource/arrow.png +0 -0
- melage/resource/arrowFaded.png +0 -0
- melage/resource/arrow_org.png +0 -0
- melage/resource/arrow_org.png.png +0 -0
- melage/resource/arrows.png +0 -0
- melage/resource/authors.mp4 +0 -0
- melage/resource/box.png +0 -0
- melage/resource/check-image-icon-0.jpg +0 -0
- melage/resource/circle.png +0 -0
- melage/resource/circle_faded.png +0 -0
- melage/resource/circle_or.png +0 -0
- melage/resource/close.png +0 -0
- melage/resource/close_bg.png +0 -0
- melage/resource/color/Simple.txt +18 -0
- melage/resource/color/Tissue.txt +24 -0
- melage/resource/color/Tissue12.txt +27 -0
- melage/resource/color/albert_LUT.txt +102 -0
- melage/resource/color/mcrib_LUT.txt +102 -0
- melage/resource/color/pediatric1.txt +29 -0
- melage/resource/color/pediatric1_old.txt +27 -0
- melage/resource/color/pediatric2.txt +87 -0
- melage/resource/color/pediatric3.txt +29 -0
- melage/resource/color/pediatrics (copy).csv +103 -0
- melage/resource/color/tissue_seg.txt +4 -0
- melage/resource/contour.png +0 -0
- melage/resource/contour.svg +2 -0
- melage/resource/contourFaded.png +0 -0
- melage/resource/contourX.png +0 -0
- melage/resource/contourXFaded.png +0 -0
- melage/resource/dti.png +0 -0
- melage/resource/dti0.png +0 -0
- melage/resource/dti222.png +0 -0
- melage/resource/dti_or.png +0 -0
- melage/resource/eco.png +0 -0
- melage/resource/eco22.png +0 -0
- melage/resource/eco_old.png +0 -0
- melage/resource/eco_or.png +0 -0
- melage/resource/eco_or2.png +0 -0
- melage/resource/eco_seg.png +0 -0
- melage/resource/eco_seg_old.png +0 -0
- melage/resource/export.png +0 -0
- melage/resource/hand-grab-icon-10.jpg +0 -0
- melage/resource/hand-grab-icon-25.jpg +0 -0
- melage/resource/info.png +0 -0
- melage/resource/line.png +0 -0
- melage/resource/linefaded.png +0 -0
- melage/resource/load.png +0 -0
- melage/resource/main.ico +0 -0
- melage/resource/manual_images/3D_rightc.png +0 -0
- melage/resource/manual_images/3D_rightc_goto.png +0 -0
- melage/resource/manual_images/3D_rightc_paint.png +0 -0
- melage/resource/manual_images/3D_rightc_paint_draw1.png +0 -0
- melage/resource/manual_images/3D_rightc_paint_draw2.png +0 -0
- melage/resource/manual_images/3D_rightc_paint_render.png +0 -0
- melage/resource/manual_images/3D_rightc_paint_render2.png +0 -0
- melage/resource/manual_images/3D_rightc_paint_render3.png +0 -0
- melage/resource/manual_images/3D_rightc_paint_render4.png +0 -0
- melage/resource/manual_images/3D_rightc_paint_render5.png +0 -0
- melage/resource/manual_images/3D_rightc_paint_render6.png +0 -0
- melage/resource/manual_images/3D_rightc_seg.png +0 -0
- melage/resource/manual_images/exit_toolbar.png +0 -0
- melage/resource/manual_images/load_image_file.png +0 -0
- melage/resource/manual_images/load_image_file_openp.png +0 -0
- melage/resource/manual_images/main_page.png +0 -0
- melage/resource/manual_images/menu_file.png +0 -0
- melage/resource/manual_images/menu_file_export.png +0 -0
- melage/resource/manual_images/menu_file_import.png +0 -0
- melage/resource/manual_images/menu_file_settings.png +0 -0
- melage/resource/manual_images/menu_file_ss.png +0 -0
- melage/resource/manual_images/open_save_load.png +0 -0
- melage/resource/manual_images/panning_toolbar.png +0 -0
- melage/resource/manual_images/segmentation_toolbar.png +0 -0
- melage/resource/manual_images/tab_mri.png +0 -0
- melage/resource/manual_images/tab_us.png +0 -0
- melage/resource/manual_images/tabs.png +0 -0
- melage/resource/manual_images/toolbar_tools.png +0 -0
- melage/resource/manual_images/tools_basic.png +0 -0
- melage/resource/manual_images/tools_bet.png +0 -0
- melage/resource/manual_images/tools_cs.png +0 -0
- melage/resource/manual_images/tools_deepbet.png +0 -0
- melage/resource/manual_images/tools_imageinfo.png +0 -0
- melage/resource/manual_images/tools_maskO.png +0 -0
- melage/resource/manual_images/tools_masking.png +0 -0
- melage/resource/manual_images/tools_n4b.png +0 -0
- melage/resource/manual_images/tools_resize.png +0 -0
- melage/resource/manual_images/tools_ruler.png +0 -0
- melage/resource/manual_images/tools_seg.png +0 -0
- melage/resource/manual_images/tools_threshold.png +0 -0
- melage/resource/manual_images/tools_tools.png +0 -0
- melage/resource/manual_images/widget_color.png +0 -0
- melage/resource/manual_images/widget_color_add.png +0 -0
- melage/resource/manual_images/widget_color_add2.png +0 -0
- melage/resource/manual_images/widget_color_additional.png +0 -0
- melage/resource/manual_images/widget_images.png +0 -0
- melage/resource/manual_images/widget_images2.png +0 -0
- melage/resource/manual_images/widget_images3.png +0 -0
- melage/resource/manual_images/widget_marker.png +0 -0
- melage/resource/manual_images/widget_mri.png +0 -0
- melage/resource/manual_images/widget_mri2.png +0 -0
- melage/resource/manual_images/widget_segintensity.png +0 -0
- melage/resource/manual_images/widget_tab_mutualview.png +0 -0
- melage/resource/manual_images/widget_tab_mutualview2.png +0 -0
- melage/resource/manual_images/widget_table.png +0 -0
- melage/resource/manual_images/widget_table2.png +0 -0
- melage/resource/manual_images/widget_us.png +0 -0
- melage/resource/melage_top.ico +0 -0
- melage/resource/melage_top.png +0 -0
- melage/resource/melage_top0.png +0 -0
- melage/resource/melage_top1.png +0 -0
- melage/resource/melage_top4.png +0 -0
- melage/resource/mri (copy).png +0 -0
- melage/resource/mri.png +0 -0
- melage/resource/mri0.png +0 -0
- melage/resource/mri000.png +0 -0
- melage/resource/mri22.png +0 -0
- melage/resource/mri_big.png +0 -0
- melage/resource/mri_old.png +0 -0
- melage/resource/mri_seg.png +0 -0
- melage/resource/mri_seg_old.png +0 -0
- melage/resource/new.png +0 -0
- melage/resource/open.png +0 -0
- melage/resource/open2.png +0 -0
- melage/resource/pan.png +0 -0
- melage/resource/pencil.png +0 -0
- melage/resource/pencilFaded.png +0 -0
- melage/resource/points.png +0 -0
- melage/resource/pointsFaded.png +0 -0
- melage/resource/rotate.png +0 -0
- melage/resource/ruler.png +0 -0
- melage/resource/rulerFaded.png +0 -0
- melage/resource/s.png +0 -0
- melage/resource/s.psd +0 -0
- melage/resource/save.png +0 -0
- melage/resource/saveas.png +0 -0
- melage/resource/seg_mri.png +0 -0
- melage/resource/seg_mri2.png +0 -0
- melage/resource/settings.png +0 -0
- melage/resource/synch.png +0 -0
- melage/resource/synchFaded.png +0 -0
- melage/resource/theme/rc/.keep +1 -0
- melage/resource/theme/rc/arrow_down.png +0 -0
- melage/resource/theme/rc/arrow_down@2x.png +0 -0
- melage/resource/theme/rc/arrow_down_disabled.png +0 -0
- melage/resource/theme/rc/arrow_down_disabled@2x.png +0 -0
- melage/resource/theme/rc/arrow_down_focus.png +0 -0
- melage/resource/theme/rc/arrow_down_focus@2x.png +0 -0
- melage/resource/theme/rc/arrow_down_pressed.png +0 -0
- melage/resource/theme/rc/arrow_down_pressed@2x.png +0 -0
- melage/resource/theme/rc/arrow_left.png +0 -0
- melage/resource/theme/rc/arrow_left@2x.png +0 -0
- melage/resource/theme/rc/arrow_left_disabled.png +0 -0
- melage/resource/theme/rc/arrow_left_disabled@2x.png +0 -0
- melage/resource/theme/rc/arrow_left_focus.png +0 -0
- melage/resource/theme/rc/arrow_left_focus@2x.png +0 -0
- melage/resource/theme/rc/arrow_left_pressed.png +0 -0
- melage/resource/theme/rc/arrow_left_pressed@2x.png +0 -0
- melage/resource/theme/rc/arrow_right.png +0 -0
- melage/resource/theme/rc/arrow_right@2x.png +0 -0
- melage/resource/theme/rc/arrow_right_disabled.png +0 -0
- melage/resource/theme/rc/arrow_right_disabled@2x.png +0 -0
- melage/resource/theme/rc/arrow_right_focus.png +0 -0
- melage/resource/theme/rc/arrow_right_focus@2x.png +0 -0
- melage/resource/theme/rc/arrow_right_pressed.png +0 -0
- melage/resource/theme/rc/arrow_right_pressed@2x.png +0 -0
- melage/resource/theme/rc/arrow_up.png +0 -0
- melage/resource/theme/rc/arrow_up@2x.png +0 -0
- melage/resource/theme/rc/arrow_up_disabled.png +0 -0
- melage/resource/theme/rc/arrow_up_disabled@2x.png +0 -0
- melage/resource/theme/rc/arrow_up_focus.png +0 -0
- melage/resource/theme/rc/arrow_up_focus@2x.png +0 -0
- melage/resource/theme/rc/arrow_up_pressed.png +0 -0
- melage/resource/theme/rc/arrow_up_pressed@2x.png +0 -0
- melage/resource/theme/rc/base_icon.png +0 -0
- melage/resource/theme/rc/base_icon@2x.png +0 -0
- melage/resource/theme/rc/base_icon_disabled.png +0 -0
- melage/resource/theme/rc/base_icon_disabled@2x.png +0 -0
- melage/resource/theme/rc/base_icon_focus.png +0 -0
- melage/resource/theme/rc/base_icon_focus@2x.png +0 -0
- melage/resource/theme/rc/base_icon_pressed.png +0 -0
- melage/resource/theme/rc/base_icon_pressed@2x.png +0 -0
- melage/resource/theme/rc/branch_closed.png +0 -0
- melage/resource/theme/rc/branch_closed@2x.png +0 -0
- melage/resource/theme/rc/branch_closed_disabled.png +0 -0
- melage/resource/theme/rc/branch_closed_disabled@2x.png +0 -0
- melage/resource/theme/rc/branch_closed_focus.png +0 -0
- melage/resource/theme/rc/branch_closed_focus@2x.png +0 -0
- melage/resource/theme/rc/branch_closed_pressed.png +0 -0
- melage/resource/theme/rc/branch_closed_pressed@2x.png +0 -0
- melage/resource/theme/rc/branch_end.png +0 -0
- melage/resource/theme/rc/branch_end@2x.png +0 -0
- melage/resource/theme/rc/branch_end_disabled.png +0 -0
- melage/resource/theme/rc/branch_end_disabled@2x.png +0 -0
- melage/resource/theme/rc/branch_end_focus.png +0 -0
- melage/resource/theme/rc/branch_end_focus@2x.png +0 -0
- melage/resource/theme/rc/branch_end_pressed.png +0 -0
- melage/resource/theme/rc/branch_end_pressed@2x.png +0 -0
- melage/resource/theme/rc/branch_line.png +0 -0
- melage/resource/theme/rc/branch_line@2x.png +0 -0
- melage/resource/theme/rc/branch_line_disabled.png +0 -0
- melage/resource/theme/rc/branch_line_disabled@2x.png +0 -0
- melage/resource/theme/rc/branch_line_focus.png +0 -0
- melage/resource/theme/rc/branch_line_focus@2x.png +0 -0
- melage/resource/theme/rc/branch_line_pressed.png +0 -0
- melage/resource/theme/rc/branch_line_pressed@2x.png +0 -0
- melage/resource/theme/rc/branch_more.png +0 -0
- melage/resource/theme/rc/branch_more@2x.png +0 -0
- melage/resource/theme/rc/branch_more_disabled.png +0 -0
- melage/resource/theme/rc/branch_more_disabled@2x.png +0 -0
- melage/resource/theme/rc/branch_more_focus.png +0 -0
- melage/resource/theme/rc/branch_more_focus@2x.png +0 -0
- melage/resource/theme/rc/branch_more_pressed.png +0 -0
- melage/resource/theme/rc/branch_more_pressed@2x.png +0 -0
- melage/resource/theme/rc/branch_open.png +0 -0
- melage/resource/theme/rc/branch_open@2x.png +0 -0
- melage/resource/theme/rc/branch_open_disabled.png +0 -0
- melage/resource/theme/rc/branch_open_disabled@2x.png +0 -0
- melage/resource/theme/rc/branch_open_focus.png +0 -0
- melage/resource/theme/rc/branch_open_focus@2x.png +0 -0
- melage/resource/theme/rc/branch_open_pressed.png +0 -0
- melage/resource/theme/rc/branch_open_pressed@2x.png +0 -0
- melage/resource/theme/rc/checkbox_checked.png +0 -0
- melage/resource/theme/rc/checkbox_checked0.png +0 -0
- melage/resource/theme/rc/checkbox_checked@2x.png +0 -0
- melage/resource/theme/rc/checkbox_checked@2x0.png +0 -0
- melage/resource/theme/rc/checkbox_checked@2x000.png.png +0 -0
- melage/resource/theme/rc/checkbox_checked_disabled.png +0 -0
- melage/resource/theme/rc/checkbox_checked_disabled0.png +0 -0
- melage/resource/theme/rc/checkbox_checked_disabled@2x.png +0 -0
- melage/resource/theme/rc/checkbox_checked_disabled@2x0.png +0 -0
- melage/resource/theme/rc/checkbox_checked_focus.png +0 -0
- melage/resource/theme/rc/checkbox_checked_focus0.png +0 -0
- melage/resource/theme/rc/checkbox_checked_focus@2x.png +0 -0
- melage/resource/theme/rc/checkbox_checked_focus@2x0.png +0 -0
- melage/resource/theme/rc/checkbox_checked_pressed.png +0 -0
- melage/resource/theme/rc/checkbox_checked_pressed0.png +0 -0
- melage/resource/theme/rc/checkbox_checked_pressed@2x.png +0 -0
- melage/resource/theme/rc/checkbox_checked_pressed@2x0.png +0 -0
- melage/resource/theme/rc/checkbox_indeterminate.png +0 -0
- melage/resource/theme/rc/checkbox_indeterminate@2x.png +0 -0
- melage/resource/theme/rc/checkbox_indeterminate_disabled.png +0 -0
- melage/resource/theme/rc/checkbox_indeterminate_disabled@2x.png +0 -0
- melage/resource/theme/rc/checkbox_indeterminate_focus.png +0 -0
- melage/resource/theme/rc/checkbox_indeterminate_focus@2x.png +0 -0
- melage/resource/theme/rc/checkbox_indeterminate_pressed.png +0 -0
- melage/resource/theme/rc/checkbox_indeterminate_pressed@2x.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked0.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked00.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked@2x.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked@2x0.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked@2x00.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_disabled.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_disabled0.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_disabled00.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_disabled@2x.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_disabled@2x0.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_disabled@2x00.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_focus.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_focus0.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_focus00.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_focus@2x.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_focus@2x0.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_focus@2x00.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_pressed.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_pressed0.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_pressed00.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_pressed@2x.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_pressed@2x0.png +0 -0
- melage/resource/theme/rc/checkbox_unchecked_pressed@2x00.png +0 -0
- melage/resource/theme/rc/line_horizontal.png +0 -0
- melage/resource/theme/rc/line_horizontal@2x.png +0 -0
- melage/resource/theme/rc/line_horizontal_disabled.png +0 -0
- melage/resource/theme/rc/line_horizontal_disabled@2x.png +0 -0
- melage/resource/theme/rc/line_horizontal_focus.png +0 -0
- melage/resource/theme/rc/line_horizontal_focus@2x.png +0 -0
- melage/resource/theme/rc/line_horizontal_pressed.png +0 -0
- melage/resource/theme/rc/line_horizontal_pressed@2x.png +0 -0
- melage/resource/theme/rc/line_vertical.png +0 -0
- melage/resource/theme/rc/line_vertical@2x.png +0 -0
- melage/resource/theme/rc/line_vertical_disabled.png +0 -0
- melage/resource/theme/rc/line_vertical_disabled@2x.png +0 -0
- melage/resource/theme/rc/line_vertical_focus.png +0 -0
- melage/resource/theme/rc/line_vertical_focus@2x.png +0 -0
- melage/resource/theme/rc/line_vertical_pressed.png +0 -0
- melage/resource/theme/rc/line_vertical_pressed@2x.png +0 -0
- melage/resource/theme/rc/radio_checked.png +0 -0
- melage/resource/theme/rc/radio_checked@2x.png +0 -0
- melage/resource/theme/rc/radio_checked_disabled.png +0 -0
- melage/resource/theme/rc/radio_checked_disabled@2x.png +0 -0
- melage/resource/theme/rc/radio_checked_focus.png +0 -0
- melage/resource/theme/rc/radio_checked_focus@2x.png +0 -0
- melage/resource/theme/rc/radio_checked_pressed.png +0 -0
- melage/resource/theme/rc/radio_checked_pressed@2x.png +0 -0
- melage/resource/theme/rc/radio_unchecked.png +0 -0
- melage/resource/theme/rc/radio_unchecked@2x.png +0 -0
- melage/resource/theme/rc/radio_unchecked_disabled.png +0 -0
- melage/resource/theme/rc/radio_unchecked_disabled@2x.png +0 -0
- melage/resource/theme/rc/radio_unchecked_focus.png +0 -0
- melage/resource/theme/rc/radio_unchecked_focus@2x.png +0 -0
- melage/resource/theme/rc/radio_unchecked_pressed.png +0 -0
- melage/resource/theme/rc/radio_unchecked_pressed@2x.png +0 -0
- melage/resource/theme/rc/toolbar_move_horizontal.png +0 -0
- melage/resource/theme/rc/toolbar_move_horizontal@2x.png +0 -0
- melage/resource/theme/rc/toolbar_move_horizontal_disabled.png +0 -0
- melage/resource/theme/rc/toolbar_move_horizontal_disabled@2x.png +0 -0
- melage/resource/theme/rc/toolbar_move_horizontal_focus.png +0 -0
- melage/resource/theme/rc/toolbar_move_horizontal_focus@2x.png +0 -0
- melage/resource/theme/rc/toolbar_move_horizontal_pressed.png +0 -0
- melage/resource/theme/rc/toolbar_move_horizontal_pressed@2x.png +0 -0
- melage/resource/theme/rc/toolbar_move_vertical.png +0 -0
- melage/resource/theme/rc/toolbar_move_vertical@2x.png +0 -0
- melage/resource/theme/rc/toolbar_move_vertical_disabled.png +0 -0
- melage/resource/theme/rc/toolbar_move_vertical_disabled@2x.png +0 -0
- melage/resource/theme/rc/toolbar_move_vertical_focus.png +0 -0
- melage/resource/theme/rc/toolbar_move_vertical_focus@2x.png +0 -0
- melage/resource/theme/rc/toolbar_move_vertical_pressed.png +0 -0
- melage/resource/theme/rc/toolbar_move_vertical_pressed@2x.png +0 -0
- melage/resource/theme/rc/toolbar_separator_horizontal.png +0 -0
- melage/resource/theme/rc/toolbar_separator_horizontal@2x.png +0 -0
- melage/resource/theme/rc/toolbar_separator_horizontal_disabled.png +0 -0
- melage/resource/theme/rc/toolbar_separator_horizontal_disabled@2x.png +0 -0
- melage/resource/theme/rc/toolbar_separator_horizontal_focus.png +0 -0
- melage/resource/theme/rc/toolbar_separator_horizontal_focus@2x.png +0 -0
- melage/resource/theme/rc/toolbar_separator_horizontal_pressed.png +0 -0
- melage/resource/theme/rc/toolbar_separator_horizontal_pressed@2x.png +0 -0
- melage/resource/theme/rc/toolbar_separator_vertical.png +0 -0
- melage/resource/theme/rc/toolbar_separator_vertical@2x.png +0 -0
- melage/resource/theme/rc/toolbar_separator_vertical_disabled.png +0 -0
- melage/resource/theme/rc/toolbar_separator_vertical_disabled@2x.png +0 -0
- melage/resource/theme/rc/toolbar_separator_vertical_focus.png +0 -0
- melage/resource/theme/rc/toolbar_separator_vertical_focus@2x.png +0 -0
- melage/resource/theme/rc/toolbar_separator_vertical_pressed.png +0 -0
- melage/resource/theme/rc/toolbar_separator_vertical_pressed@2x.png +0 -0
- melage/resource/theme/rc/transparent.png +0 -0
- melage/resource/theme/rc/transparent@2x.png +0 -0
- melage/resource/theme/rc/transparent_disabled.png +0 -0
- melage/resource/theme/rc/transparent_disabled@2x.png +0 -0
- melage/resource/theme/rc/transparent_focus.png +0 -0
- melage/resource/theme/rc/transparent_focus@2x.png +0 -0
- melage/resource/theme/rc/transparent_pressed.png +0 -0
- melage/resource/theme/rc/transparent_pressed@2x.png +0 -0
- melage/resource/theme/rc/window_close.png +0 -0
- melage/resource/theme/rc/window_close@2x.png +0 -0
- melage/resource/theme/rc/window_close_disabled.png +0 -0
- melage/resource/theme/rc/window_close_disabled@2x.png +0 -0
- melage/resource/theme/rc/window_close_focus.png +0 -0
- melage/resource/theme/rc/window_close_focus@2x.png +0 -0
- melage/resource/theme/rc/window_close_pressed.png +0 -0
- melage/resource/theme/rc/window_close_pressed@2x.png +0 -0
- melage/resource/theme/rc/window_grip.png +0 -0
- melage/resource/theme/rc/window_grip@2x.png +0 -0
- melage/resource/theme/rc/window_grip_disabled.png +0 -0
- melage/resource/theme/rc/window_grip_disabled@2x.png +0 -0
- melage/resource/theme/rc/window_grip_focus.png +0 -0
- melage/resource/theme/rc/window_grip_focus@2x.png +0 -0
- melage/resource/theme/rc/window_grip_pressed.png +0 -0
- melage/resource/theme/rc/window_grip_pressed@2x.png +0 -0
- melage/resource/theme/rc/window_minimize.png +0 -0
- melage/resource/theme/rc/window_minimize@2x.png +0 -0
- melage/resource/theme/rc/window_minimize_disabled.png +0 -0
- melage/resource/theme/rc/window_minimize_disabled@2x.png +0 -0
- melage/resource/theme/rc/window_minimize_focus.png +0 -0
- melage/resource/theme/rc/window_minimize_focus@2x.png +0 -0
- melage/resource/theme/rc/window_minimize_pressed.png +0 -0
- melage/resource/theme/rc/window_minimize_pressed@2x.png +0 -0
- melage/resource/theme/rc/window_undock.png +0 -0
- melage/resource/theme/rc/window_undock@2x.png +0 -0
- melage/resource/theme/rc/window_undock_disabled.png +0 -0
- melage/resource/theme/rc/window_undock_disabled@2x.png +0 -0
- melage/resource/theme/rc/window_undock_focus.png +0 -0
- melage/resource/theme/rc/window_undock_focus@2x.png +0 -0
- melage/resource/theme/rc/window_undock_pressed.png +0 -0
- melage/resource/theme/rc/window_undock_pressed@2x.png +0 -0
- melage/resource/theme/style.qss +2223 -0
- melage/resource/tract.png +0 -0
- melage/resource/view1.png +0 -0
- melage/resource/view1_eco.png +0 -0
- melage/resource/view1_mri.png +0 -0
- melage/resource/view1_seg.png +0 -0
- melage/resource/view2.png +0 -0
- melage/resource/view2_seg.png +0 -0
- melage/resource/w.png +0 -0
- melage/resource/zoom_in.png +0 -0
- melage/resource/zoom_inFaded.png +0 -0
- melage/resource/zoom_out.png +0 -0
- melage/resource/zoom_outFaded.png +0 -0
- melage/some_notes.txt +3 -0
- melage/utils/DispalyIm.py +2788 -0
- melage/utils/GMM.py +720 -0
- melage/utils/Shaders_120.py +257 -0
- melage/utils/Shaders_330.py +314 -0
- melage/utils/Shaders_bu.py +314 -0
- melage/utils/__init__0.py +7 -0
- melage/utils/brain_extraction_helper.py +234 -0
- melage/utils/custom_QScrollBar.py +61 -0
- melage/utils/glScientific.py +1554 -0
- melage/utils/glScientific_bc.py +1585 -0
- melage/utils/readData.py +1061 -0
- melage/utils/registration.py +512 -0
- melage/utils/source_folder.py +18 -0
- melage/utils/utils.py +3808 -0
- melage/version.txt +1 -0
- melage/widgets/ApplyMask.py +212 -0
- melage/widgets/ChangeSystem.py +152 -0
- melage/widgets/DeepLModels/InfantSegment/Unet.py +464 -0
- melage/widgets/DeepLModels/NPP/dataset/mri_dataset_affine.py +149 -0
- melage/widgets/DeepLModels/NPP/models/checkpoints/npp_v1.pth.py +0 -0
- melage/widgets/DeepLModels/NPP/models/losses.py +146 -0
- melage/widgets/DeepLModels/NPP/models/model.py +272 -0
- melage/widgets/DeepLModels/NPP/models/utils.py +303 -0
- melage/widgets/DeepLModels/NPP/npp.py +116 -0
- melage/widgets/DeepLModels/NPP/requirements.txt +8 -0
- melage/widgets/DeepLModels/NPP/train/train.py +116 -0
- melage/widgets/DeepLModels/Unet3DAtt.py +657 -0
- melage/widgets/DeepLModels/Unet3D_basic.py +648 -0
- melage/widgets/DeepLModels/new_unet.py +652 -0
- melage/widgets/DeepLModels/new_unet_old.py +639 -0
- melage/widgets/DeepLModels/new_unet_old2.py +658 -0
- melage/widgets/HistImage.py +153 -0
- melage/widgets/ImageThresholding.py +222 -0
- melage/widgets/MaskOperations.py +147 -0
- melage/widgets/N4Dialog.py +241 -0
- melage/widgets/Segmentation/FCM.py +1553 -0
- melage/widgets/Segmentation/__init__.py +588 -0
- melage/widgets/Segmentation/utils.py +417 -0
- melage/widgets/SemiAutoSeg.py +666 -0
- melage/widgets/Synthstrip.py +141 -0
- melage/widgets/__init__0.py +5 -0
- melage/widgets/about.py +246 -0
- melage/widgets/activation.py +437 -0
- melage/widgets/activator.py +147 -0
- melage/widgets/be_dl.py +409 -0
- melage/widgets/be_dl_unet3d.py +441 -0
- melage/widgets/brain_extraction.py +855 -0
- melage/widgets/brain_extraction_dl.py +887 -0
- melage/widgets/brain_extraction_dl_bu.py +869 -0
- melage/widgets/colorwidget.py +100 -0
- melage/widgets/dockWidgets.py +2005 -0
- melage/widgets/enhanceImWidget.py +109 -0
- melage/widgets/fileDialog_widget.py +275 -0
- melage/widgets/iminfo.py +346 -0
- melage/widgets/mainwindow_widget.py +6775 -0
- melage/widgets/melageAbout.py +123 -0
- melage/widgets/openglWidgets.py +556 -0
- melage/widgets/registrationWidget.py +342 -0
- melage/widgets/repeat_widget.py +74 -0
- melage/widgets/screenshot_widget.py +138 -0
- melage/widgets/settings_widget.py +77 -0
- melage/widgets/tranformationWidget.py +275 -0
- melage-0.0.65.dist-info/METADATA +742 -0
- melage-0.0.65.dist-info/RECORD +501 -0
- melage-0.0.65.dist-info/WHEEL +5 -0
- melage-0.0.65.dist-info/entry_points.txt +2 -0
- melage-0.0.65.dist-info/top_level.txt +1 -0
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
__AUTHOR__ = 'Bahram Jafrasteh'
|
|
2
|
+
|
|
3
|
+
import sys
|
|
4
|
+
from PyQt5.QtWidgets import QDialog, QApplication, QPushButton, QVBoxLayout
|
|
5
|
+
from PyQt5.QtCore import Qt
|
|
6
|
+
|
|
7
|
+
from matplotlib.backends.backend_qt5agg import FigureCanvasQTAgg, FigureCanvasQT
|
|
8
|
+
from matplotlib.backends.backend_qt5agg import NavigationToolbar2QT as NavigationToolbar
|
|
9
|
+
import matplotlib.pyplot as plt
|
|
10
|
+
from PyQt5 import QtCore, QtGui, QtWidgets
|
|
11
|
+
from PyQt5.QtCore import Qt
|
|
12
|
+
from PyQt5.QtCore import pyqtSignal
|
|
13
|
+
import random
|
|
14
|
+
import matplotlib
|
|
15
|
+
matplotlib.use('Agg')
|
|
16
|
+
|
|
17
|
+
from matplotlib.figure import Figure
|
|
18
|
+
|
|
19
|
+
class FigureCanvas(FigureCanvasQTAgg):
|
|
20
|
+
"""
|
|
21
|
+
Class implemented to show figures
|
|
22
|
+
"""
|
|
23
|
+
def __init__(self, parent=None, width=5, height=4, dpi=1000):
|
|
24
|
+
super(FigureCanvas, self).__init__(parent)
|
|
25
|
+
fig = Figure(figsize=(width, height), dpi=dpi)
|
|
26
|
+
self.axes = fig.add_subplot(111)
|
|
27
|
+
self._canvas = FigureCanvasQT(parent)
|
|
28
|
+
|
|
29
|
+
def mousePressEvent(self, a0) -> None:
|
|
30
|
+
x, y = a0.x(), a0.y()
|
|
31
|
+
inaxes = self._canvas.inaxes((x, y))
|
|
32
|
+
if inaxes is not None:
|
|
33
|
+
try:
|
|
34
|
+
trans = inaxes.transData.inverted()
|
|
35
|
+
xdata, ydata = trans.transform((x, y))
|
|
36
|
+
except ValueError:
|
|
37
|
+
pass
|
|
38
|
+
else:
|
|
39
|
+
print(xdata, ydata)
|
|
40
|
+
super(FigureCanvas, self).mousePressEvent(a0)
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
class HistImage(QDialog):
|
|
44
|
+
"""
|
|
45
|
+
Histogram images
|
|
46
|
+
"""
|
|
47
|
+
closeSig = pyqtSignal()
|
|
48
|
+
def __init__(self, parent=None):
|
|
49
|
+
super(HistImage, self).__init__(parent)
|
|
50
|
+
|
|
51
|
+
Form = self.window()
|
|
52
|
+
Form.setObjectName("N4")
|
|
53
|
+
Form.resize(600, 600)
|
|
54
|
+
self.grid_main = QtWidgets.QGridLayout(self)
|
|
55
|
+
self.grid_main.setContentsMargins(0,0,0,0)
|
|
56
|
+
self.grid_main.setObjectName("gridLayout")
|
|
57
|
+
self.tabWidget = QtWidgets.QTabWidget()
|
|
58
|
+
self.tabWidget.setGeometry(QtCore.QRect(50, 50, 500, 500))
|
|
59
|
+
self.tabWidget.setObjectName("tabWidget")
|
|
60
|
+
sizePolicy = QtWidgets.QSizePolicy(QtWidgets.QSizePolicy.MinimumExpanding, QtWidgets.QSizePolicy.MinimumExpanding)
|
|
61
|
+
sizePolicy.setHorizontalStretch(0)
|
|
62
|
+
sizePolicy.setVerticalStretch(0)
|
|
63
|
+
sizePolicy.setHeightForWidth(self.tabWidget.sizePolicy().hasHeightForWidth())
|
|
64
|
+
self.tabWidget.setSizePolicy(sizePolicy)
|
|
65
|
+
self.tabWidget.setMinimumSize(QtCore.QSize(100, 100))
|
|
66
|
+
#self.tabWidget.setObjectName("tabWidget")
|
|
67
|
+
self.widget = QtWidgets.QWidget(self)
|
|
68
|
+
self.widget.setGeometry(QtCore.QRect(20, 20, 400, 400))
|
|
69
|
+
self.widget.setObjectName("widget")
|
|
70
|
+
self.gridLayout = QtWidgets.QGridLayout(self.widget)
|
|
71
|
+
self.gridLayout.setContentsMargins(0, 0, 0, 0)
|
|
72
|
+
self.gridLayout.setObjectName("gridLayout")
|
|
73
|
+
|
|
74
|
+
# a figure instance to plot on
|
|
75
|
+
self.figure = plt.figure()
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
self.canvas = FigureCanvas(self.figure)
|
|
79
|
+
|
|
80
|
+
self.canvas.setParent(self)
|
|
81
|
+
|
|
82
|
+
self.gridLayout.addWidget(self.canvas, 0, 0, 2, 2)
|
|
83
|
+
|
|
84
|
+
self.figure2 = plt.figure()
|
|
85
|
+
|
|
86
|
+
self.widget2 = QtWidgets.QWidget()
|
|
87
|
+
self.widget2.setGeometry(QtCore.QRect(20, 20, 400, 400))
|
|
88
|
+
self.widget2.setObjectName("widget")
|
|
89
|
+
|
|
90
|
+
self.gridLayout2 = QtWidgets.QGridLayout(self.widget2)
|
|
91
|
+
self.canvas2 = FigureCanvas(self.figure2)
|
|
92
|
+
|
|
93
|
+
self.gridLayout2.addWidget(self.canvas2, 0, 0, 2, 2)
|
|
94
|
+
self.gridLayout2.setContentsMargins(0, 0, 0, 0)
|
|
95
|
+
self.gridLayout2.setObjectName("gridLayout")
|
|
96
|
+
self.tabWidget.addTab(self.widget2,"")
|
|
97
|
+
self.tabWidget.addTab(self.widget, "")
|
|
98
|
+
_translate = QtCore.QCoreApplication.translate
|
|
99
|
+
self.tabWidget.setTabText(self.tabWidget.indexOf(self.widget), _translate("Dialog", "View 2"))
|
|
100
|
+
self.tabWidget.setTabText(self.tabWidget.indexOf(self.widget2), _translate("Dialog", "View 1"))
|
|
101
|
+
|
|
102
|
+
self.grid_main.addWidget(self.tabWidget)
|
|
103
|
+
|
|
104
|
+
Form.setWindowTitle(_translate("Form", "Image Histogram"))
|
|
105
|
+
|
|
106
|
+
def closeEvent(self, a0: QtGui.QCloseEvent) -> None:
|
|
107
|
+
self.closeSig.emit()
|
|
108
|
+
super(HistImage, self).closeEvent(a0)
|
|
109
|
+
|
|
110
|
+
def UpdateName(self, a, b):
|
|
111
|
+
_translate = QtCore.QCoreApplication.translate
|
|
112
|
+
if a is not None:
|
|
113
|
+
self.tabWidget.setTabText(self.tabWidget.indexOf(self.widget), _translate("Dialog", a))
|
|
114
|
+
if b is not None:
|
|
115
|
+
self.tabWidget.setTabText(self.tabWidget.indexOf(self.widget2), _translate("Dialog", b))
|
|
116
|
+
def plot(self, data, id):
|
|
117
|
+
if data is None:
|
|
118
|
+
return #data = [random.random() for i in range(10)]
|
|
119
|
+
if id == 1:
|
|
120
|
+
figure, canvas = self.figure, self.canvas
|
|
121
|
+
elif id == 2:
|
|
122
|
+
figure, canvas = self.figure2, self.canvas2
|
|
123
|
+
else:
|
|
124
|
+
return
|
|
125
|
+
|
|
126
|
+
|
|
127
|
+
figure.clear()
|
|
128
|
+
|
|
129
|
+
ax = figure.add_subplot(111)
|
|
130
|
+
|
|
131
|
+
a = data.mean(axis=2).flatten()
|
|
132
|
+
a = a[a>0]
|
|
133
|
+
|
|
134
|
+
ax.hist(a, 25)
|
|
135
|
+
ax.grid('on')
|
|
136
|
+
ax.tick_params(axis='both', which='major', labelsize=10)
|
|
137
|
+
ax.tick_params(axis='both', which='minor', labelsize=10)
|
|
138
|
+
ax.set_title('Image histogram', fontsize=6 * 1.7, weight='bold')
|
|
139
|
+
ax.set_xlabel('Range', fontsize=6 * 1.5, weight='bold')
|
|
140
|
+
|
|
141
|
+
ax.set_ylabel('Frequency', fontsize=6 * 1.5, weight='bold')
|
|
142
|
+
ax.set_xlim([0,a.max()+1])
|
|
143
|
+
figure.tight_layout(pad=2)
|
|
144
|
+
|
|
145
|
+
canvas.draw()
|
|
146
|
+
|
|
147
|
+
if __name__ == '__main__':
|
|
148
|
+
app = QApplication(sys.argv)
|
|
149
|
+
|
|
150
|
+
main = HistImage()
|
|
151
|
+
main.show()
|
|
152
|
+
|
|
153
|
+
sys.exit(app.exec_())
|
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
__AUTHOR__ = 'Bahram Jafrasteh'
|
|
2
|
+
|
|
3
|
+
from PyQt5.QtWidgets import QDialog, QApplication, QPushButton, QVBoxLayout
|
|
4
|
+
import matplotlib.pyplot as plt
|
|
5
|
+
from PyQt5 import QtCore, QtGui, QtWidgets
|
|
6
|
+
from PyQt5.QtCore import Qt
|
|
7
|
+
from PyQt5.QtCore import pyqtSignal
|
|
8
|
+
import random
|
|
9
|
+
import matplotlib
|
|
10
|
+
from melage.widgets.HistImage import FigureCanvas
|
|
11
|
+
matplotlib.use('Agg')
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class ThresholdingImage(QDialog):
|
|
15
|
+
"""
|
|
16
|
+
Image thresholding
|
|
17
|
+
"""
|
|
18
|
+
closeSig = pyqtSignal()
|
|
19
|
+
applySig = pyqtSignal()
|
|
20
|
+
repltSig = pyqtSignal()
|
|
21
|
+
histeqSig = pyqtSignal(int)
|
|
22
|
+
|
|
23
|
+
def __init__(self, parent=None):
|
|
24
|
+
super(ThresholdingImage, self).__init__(parent)
|
|
25
|
+
|
|
26
|
+
Form = self.window()
|
|
27
|
+
Form.setObjectName("N4")
|
|
28
|
+
Form.resize(600, 600)
|
|
29
|
+
#self.tabWidget = QtWidgets.QTabWidget(Form)
|
|
30
|
+
#self.tabWidget.setGeometry(QtCore.QRect(50, 50, 500, 500))
|
|
31
|
+
#self.tabWidget.setObjectName("tabWidget")
|
|
32
|
+
sizePolicy = QtWidgets.QSizePolicy(QtWidgets.QSizePolicy.MinimumExpanding,
|
|
33
|
+
QtWidgets.QSizePolicy.MinimumExpanding)
|
|
34
|
+
sizePolicy.setHorizontalStretch(0)
|
|
35
|
+
sizePolicy.setVerticalStretch(0)
|
|
36
|
+
#sizePolicy.setHeightForWidth(self.tabWidget.sizePolicy().hasHeightForWidth())
|
|
37
|
+
|
|
38
|
+
# self.tabWidget.setObjectName("tabWidget")
|
|
39
|
+
self.widget = QtWidgets.QWidget(self)
|
|
40
|
+
#self.widget.setGeometry(QtCore.QRect(20, 20, 400, 400))
|
|
41
|
+
self.widget.setObjectName("widget")
|
|
42
|
+
self.gridLayout_main = QtWidgets.QVBoxLayout(self)
|
|
43
|
+
self.gridLayout = QtWidgets.QGridLayout()
|
|
44
|
+
self.gridLayout.setContentsMargins(0, 0, 0, 0)
|
|
45
|
+
self.gridLayout.setObjectName("gridLayout")
|
|
46
|
+
|
|
47
|
+
# a figure instance to plot on
|
|
48
|
+
self.figure = plt.figure()
|
|
49
|
+
|
|
50
|
+
# this is the Canvas Widget that displays the `figure`
|
|
51
|
+
# it takes the `figure` instance as a parameter to __init__
|
|
52
|
+
self.canvas = FigureCanvas(self.figure)
|
|
53
|
+
# self.toolbar = NavigationToolbar(self.canvas, self)
|
|
54
|
+
self.canvas.setParent(self)
|
|
55
|
+
|
|
56
|
+
self.gridLayout.addWidget(self.canvas, 5, 5, 2, 2)
|
|
57
|
+
# this is the Navigation widget
|
|
58
|
+
# it takes the Canvas widget and a parent
|
|
59
|
+
self.gridLayout2 = QtWidgets.QGridLayout()
|
|
60
|
+
|
|
61
|
+
# Just some button connected to `plot` method
|
|
62
|
+
self.button = QPushButton('Plot')
|
|
63
|
+
self.button.clicked.connect(self.applySig)
|
|
64
|
+
# self.gridLayout.addWidget(self.button, 7, 0, 1, 1)
|
|
65
|
+
self._number_class = QtWidgets.QComboBox(self.widget)
|
|
66
|
+
|
|
67
|
+
sizePolicy = QtWidgets.QSizePolicy(QtWidgets.QSizePolicy.Minimum, QtWidgets.QSizePolicy.Minimum)
|
|
68
|
+
sizePolicy.setHorizontalStretch(0)
|
|
69
|
+
sizePolicy.setVerticalStretch(0)
|
|
70
|
+
self._number_class.setMaximumSize(50,50)
|
|
71
|
+
sizePolicy.setHeightForWidth(self._number_class.sizePolicy().hasWidthForHeight())
|
|
72
|
+
self._number_class.setSizePolicy(sizePolicy)
|
|
73
|
+
self._number_class.setObjectName("+")
|
|
74
|
+
self.gridLayout2.addWidget(self._number_class, 0, 2, 1, 2)
|
|
75
|
+
self._label_numberClasses = QtWidgets.QLabel(self.widget)
|
|
76
|
+
self._label_numberClasses.setObjectName("_label_numberClasses")
|
|
77
|
+
|
|
78
|
+
self._histeq = QtWidgets.QCheckBox(self.widget)
|
|
79
|
+
self._histeq.setObjectName("check box")
|
|
80
|
+
self._histeq.setChecked(False)
|
|
81
|
+
self._histeq.clicked.connect(self.histEQ)
|
|
82
|
+
|
|
83
|
+
self.gridLayout2.addWidget(self.button, 0, 4, 1, 1)
|
|
84
|
+
self.gridLayout2.addWidget(self._histeq, 0,3, 1, 1)
|
|
85
|
+
self.gridLayout2.addWidget(self._label_numberClasses, 0,1, 1, 1)
|
|
86
|
+
|
|
87
|
+
# self.toolbar2 = NavigationToolbar(self.canvas2, self)
|
|
88
|
+
# self.canvas2.setParent(self)
|
|
89
|
+
for i in range(9):
|
|
90
|
+
self._number_class.setItemData(i, Qt.AlignCenter, Qt.TextAlignmentRole)
|
|
91
|
+
self._number_class.addItem(" {} ".format(i+1))
|
|
92
|
+
_translate = QtCore.QCoreApplication.translate
|
|
93
|
+
self._label_numberClasses.setText(_translate("Form", "No. classes"))
|
|
94
|
+
self._histeq.setText(_translate("Form", "Hist EQ."))
|
|
95
|
+
self.button.setText(_translate("Form", "Apply"))
|
|
96
|
+
self.comboBox_image = QtWidgets.QComboBox(self.widget)
|
|
97
|
+
self.comboBox_image.setObjectName("comboBox_image")
|
|
98
|
+
self.comboBox_image.addItem("")
|
|
99
|
+
self.comboBox_image.addItem("")
|
|
100
|
+
self.gridLayout2.addWidget(self.comboBox_image,0, 0, 1, 1)
|
|
101
|
+
Form.setWindowTitle(_translate("Form", "Image Thresholding"))
|
|
102
|
+
self.comboBox_image.setItemText(0, _translate("Form", " View 1 "))
|
|
103
|
+
self.comboBox_image.setItemText(1, _translate("Form", " View 2 "))
|
|
104
|
+
#self._number_class.currentIndexChanged.connect(self.plot)
|
|
105
|
+
|
|
106
|
+
self.gridLayout_main.addLayout(self.gridLayout, 0)
|
|
107
|
+
self.gridLayout_main.addLayout(self.gridLayout2, 1)
|
|
108
|
+
|
|
109
|
+
self.comboBox_image.currentIndexChanged.connect(self.repltSig)
|
|
110
|
+
self.button.clicked.connect(self.applySig)
|
|
111
|
+
self._number_class.currentIndexChanged.connect(self.repltSig)
|
|
112
|
+
|
|
113
|
+
#self.plot([])
|
|
114
|
+
|
|
115
|
+
def histEQ(self):
|
|
116
|
+
if not hasattr(self, '_a'):
|
|
117
|
+
return
|
|
118
|
+
if self._histeq.isChecked():
|
|
119
|
+
a = self._a
|
|
120
|
+
from melage.utils.utils import histogram_equalization
|
|
121
|
+
self.im_rec = histogram_equalization(a)
|
|
122
|
+
self.plot(self.im_rec)
|
|
123
|
+
self.histeqSig.emit(True)
|
|
124
|
+
else:
|
|
125
|
+
self.histeqSig.emit(0)
|
|
126
|
+
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
def new_thresholds(self, a):
|
|
130
|
+
|
|
131
|
+
self._a = a
|
|
132
|
+
numc = self._number_class.currentIndex()+2
|
|
133
|
+
from utils.utils import Threshold_MultiOtsu
|
|
134
|
+
thresholds = Threshold_MultiOtsu(a, numc)
|
|
135
|
+
return thresholds
|
|
136
|
+
|
|
137
|
+
|
|
138
|
+
def closeEvent(self, a0: QtGui.QCloseEvent) -> None:
|
|
139
|
+
self.closeSig.emit()
|
|
140
|
+
if hasattr(self, '_a'):
|
|
141
|
+
delattr(self,'_a')
|
|
142
|
+
self._number_class.setCurrentIndex(0)
|
|
143
|
+
self._histeq.setChecked(False)
|
|
144
|
+
super(ThresholdingImage, self).closeEvent(a0)
|
|
145
|
+
|
|
146
|
+
|
|
147
|
+
|
|
148
|
+
def emptyPlot(self):
|
|
149
|
+
|
|
150
|
+
|
|
151
|
+
figure, canvas = self.figure, self.canvas
|
|
152
|
+
|
|
153
|
+
''' plot some random stuff '''
|
|
154
|
+
# random data
|
|
155
|
+
|
|
156
|
+
# instead of ax.hold(False)
|
|
157
|
+
figure.clear()
|
|
158
|
+
#import numpy as np
|
|
159
|
+
#data = np.random.rand(40,40,40)*255
|
|
160
|
+
# create an axis
|
|
161
|
+
ax = figure.add_subplot(111)
|
|
162
|
+
|
|
163
|
+
# ax.axis('off')
|
|
164
|
+
#ax.grid('on')
|
|
165
|
+
ax.tick_params(axis='both', which='major', labelsize=10)
|
|
166
|
+
ax.tick_params(axis='both', which='minor', labelsize=10)
|
|
167
|
+
ax.set_title('Image histogram', fontsize=6 * 1.7, weight='bold')
|
|
168
|
+
ax.set_xlabel('Range', fontsize=6 * 1.5, weight='bold')
|
|
169
|
+
|
|
170
|
+
ax.set_ylabel('Frequency', fontsize=6 * 1.5, weight='bold')
|
|
171
|
+
#ax.set_xlim([0, a.max() + 1])
|
|
172
|
+
figure.tight_layout(pad=2)
|
|
173
|
+
|
|
174
|
+
# ax.legend(loc="upper right", prop={'size': 8 * 2})
|
|
175
|
+
# refresh canvas
|
|
176
|
+
canvas.draw()
|
|
177
|
+
|
|
178
|
+
|
|
179
|
+
|
|
180
|
+
def plot(self, data):
|
|
181
|
+
if data is None:
|
|
182
|
+
return # data = [random.random() for i in range(10)]
|
|
183
|
+
|
|
184
|
+
figure, canvas = self.figure, self.canvas
|
|
185
|
+
|
|
186
|
+
|
|
187
|
+
figure.clear()
|
|
188
|
+
|
|
189
|
+
# create an axis
|
|
190
|
+
ax = figure.add_subplot(111)
|
|
191
|
+
|
|
192
|
+
a = data.flatten()
|
|
193
|
+
a = a[a > 0]
|
|
194
|
+
|
|
195
|
+
ax.hist(a, 25)
|
|
196
|
+
self._currentThresholds = self.new_thresholds(data)
|
|
197
|
+
yl = ax.get_ylim()[1]
|
|
198
|
+
for el in self._currentThresholds:
|
|
199
|
+
ax.plot([el,el], [0, yl], )
|
|
200
|
+
# ax.axis('off')
|
|
201
|
+
#ax.grid('on')
|
|
202
|
+
ax.tick_params(axis='both', which='major', labelsize=10)
|
|
203
|
+
ax.tick_params(axis='both', which='minor', labelsize=10)
|
|
204
|
+
ax.set_title('Image histogram', fontsize=6 * 1.7, weight='bold')
|
|
205
|
+
ax.set_xlabel('Range', fontsize=6 * 1.5, weight='bold')
|
|
206
|
+
|
|
207
|
+
ax.set_ylabel('Frequency', fontsize=6 * 1.5, weight='bold')
|
|
208
|
+
#ax.set_xlim([0, a.max() + 1])
|
|
209
|
+
figure.tight_layout(pad=2)
|
|
210
|
+
|
|
211
|
+
|
|
212
|
+
canvas.draw()
|
|
213
|
+
|
|
214
|
+
|
|
215
|
+
def run():
|
|
216
|
+
import sys
|
|
217
|
+
app = QtWidgets.QApplication(sys.argv)
|
|
218
|
+
window = ThresholdingImage()
|
|
219
|
+
window.show()
|
|
220
|
+
sys.exit(app.exec_())
|
|
221
|
+
if __name__ == '__main__':
|
|
222
|
+
run()
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
__AUTHOR__ = 'Bahram Jafrasteh'
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
from PyQt5 import QtCore, QtGui, QtWidgets
|
|
5
|
+
from PyQt5.QtCore import Qt
|
|
6
|
+
from PyQt5.QtCore import pyqtSignal
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
class MaskOperations(QtWidgets.QDialog):
|
|
11
|
+
"""
|
|
12
|
+
Image MASKING OPERATION
|
|
13
|
+
"""
|
|
14
|
+
buttonpressed = pyqtSignal(object)
|
|
15
|
+
closeSig = pyqtSignal()
|
|
16
|
+
|
|
17
|
+
def __init__(self, parent=None):
|
|
18
|
+
QtWidgets.QDialog.__init__(self, parent)
|
|
19
|
+
self.setWindowTitle("Child Window!")
|
|
20
|
+
self.inputimage = None
|
|
21
|
+
|
|
22
|
+
self.MessageBox = QtWidgets.QMessageBox(self)
|
|
23
|
+
self.setupUi()
|
|
24
|
+
|
|
25
|
+
def setupUi(self):
|
|
26
|
+
Form = self.window()
|
|
27
|
+
Form.setObjectName("N4")
|
|
28
|
+
Form.resize(759, 140)
|
|
29
|
+
self.widget = QtWidgets.QWidget(Form)
|
|
30
|
+
self.widget.setGeometry(QtCore.QRect(43, 20, 644, 89))
|
|
31
|
+
self.widget.setObjectName("widget")
|
|
32
|
+
self.gridLayout = QtWidgets.QGridLayout(self.widget)
|
|
33
|
+
self.gridLayout.setContentsMargins(0, 0, 0, 0)
|
|
34
|
+
self.gridLayout.setObjectName("gridLayout")
|
|
35
|
+
|
|
36
|
+
self.splitter = QtWidgets.QSplitter(self.widget)
|
|
37
|
+
self.splitter.setOrientation(QtCore.Qt.Horizontal)
|
|
38
|
+
self.splitter.setObjectName("splitter")
|
|
39
|
+
|
|
40
|
+
#self.gridLayout.addWidget(self.splitter, 0, 1, 1, 1)
|
|
41
|
+
|
|
42
|
+
self.mask_operation = QtWidgets.QComboBox(self.widget)
|
|
43
|
+
|
|
44
|
+
sizePolicy = QtWidgets.QSizePolicy(QtWidgets.QSizePolicy.Minimum, QtWidgets.QSizePolicy.Minimum)
|
|
45
|
+
sizePolicy.setHorizontalStretch(0)
|
|
46
|
+
sizePolicy.setVerticalStretch(0)
|
|
47
|
+
self.mask_operation.setMaximumSize(50,50)
|
|
48
|
+
sizePolicy.setHeightForWidth(self.mask_operation.sizePolicy().hasWidthForHeight())
|
|
49
|
+
#self.mask_operation.setSizePolicy(sizePolicy)
|
|
50
|
+
self.mask_operation.setObjectName("+")
|
|
51
|
+
self.gridLayout.addWidget(self.mask_operation, 0, 2, 1, 1)
|
|
52
|
+
self._combobox_colors = QtWidgets.QComboBox(self.widget)
|
|
53
|
+
self._combobox_colors.setObjectName("_combobox_colors")
|
|
54
|
+
|
|
55
|
+
self._combobox_colors2 = QtWidgets.QComboBox(self.widget)
|
|
56
|
+
self._combobox_colors2.setObjectName("_combobox_colors")
|
|
57
|
+
self.gridLayout.addWidget(self._combobox_colors2, 0, 0, 1, 2)
|
|
58
|
+
self.gridLayout.addWidget(self._combobox_colors, 0,5, 1, 2)
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
|
|
62
|
+
#self.pushButton_2 = QtWidgets.QPushButton(self.widget)
|
|
63
|
+
#self.pushButton_2.setObjectName("pushButton")
|
|
64
|
+
#self.gridLayout.addWidget(self.pushButton_2, 0, 6, 1, 1)
|
|
65
|
+
self.pushButton = QtWidgets.QPushButton(self.widget)
|
|
66
|
+
self.pushButton.setObjectName("pushButton_2")
|
|
67
|
+
self.gridLayout.addWidget(self.pushButton, 2, 7, 1, 1)
|
|
68
|
+
|
|
69
|
+
#self.gridLayout.addWidget(self.progressBar, 1, 0, 1, 5)
|
|
70
|
+
#spacerItem = QtWidgets.QSpacerItem(40, 20, QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Minimum)
|
|
71
|
+
#self.gridLayout.addItem(spacerItem, 0, 1, 1, 4)
|
|
72
|
+
self.comboBox_image = QtWidgets.QComboBox(self.widget)
|
|
73
|
+
self.comboBox_image.setObjectName("comboBox_image")
|
|
74
|
+
self.comboBox_image.addItem("")
|
|
75
|
+
self.comboBox_image.addItem("")
|
|
76
|
+
self.gridLayout.addWidget(self.comboBox_image, 1, 0, 1, 1)
|
|
77
|
+
|
|
78
|
+
|
|
79
|
+
self.retranslateUi(Form)
|
|
80
|
+
QtCore.QMetaObject.connectSlotsByName(Form)
|
|
81
|
+
|
|
82
|
+
for i, operation in enumerate(['+', '-']):
|
|
83
|
+
self.mask_operation.setItemData(i, Qt.AlignCenter, Qt.TextAlignmentRole)
|
|
84
|
+
self.mask_operation.addItem(" {} ".format(operation))
|
|
85
|
+
|
|
86
|
+
self.pushButton.clicked.connect(self.accepted_emit)
|
|
87
|
+
|
|
88
|
+
def closeEvent(self, a0: QtGui.QCloseEvent) -> None:
|
|
89
|
+
self.closeSig.emit()
|
|
90
|
+
super(MaskOperations, self).closeEvent(a0)
|
|
91
|
+
|
|
92
|
+
def accept_emit(self):
|
|
93
|
+
self.mask_operation.text()
|
|
94
|
+
num = self.mask_operation.text()
|
|
95
|
+
if num not in ['+', '-', '']:
|
|
96
|
+
self.message()
|
|
97
|
+
return False
|
|
98
|
+
return True
|
|
99
|
+
|
|
100
|
+
def setComboBoxColors(self, color_name):
|
|
101
|
+
self._combobox_colors.clear()
|
|
102
|
+
self._combobox_colors2.clear()
|
|
103
|
+
for colr in color_name:
|
|
104
|
+
#self._combobox_colors.setItemData(i, Qt.AlignCenter, Qt.TextAlignmentRole)
|
|
105
|
+
self._combobox_colors.addItem(" {} ".format(colr))
|
|
106
|
+
self._combobox_colors2.addItem(" {} ".format(colr))
|
|
107
|
+
|
|
108
|
+
def retranslateUi(self, Form):
|
|
109
|
+
_translate = QtCore.QCoreApplication.translate
|
|
110
|
+
Form.setWindowTitle(_translate("Form", "Mask Operations"))
|
|
111
|
+
|
|
112
|
+
self.comboBox_image.setItemText(0, _translate("Form", " View 1 "))
|
|
113
|
+
self.comboBox_image.setItemText(1, _translate("Form", " View 2 "))
|
|
114
|
+
#self.label_timer.setText(_translate("Form", "00:00"))
|
|
115
|
+
self.pushButton.setText(_translate("Form", "Apply"))
|
|
116
|
+
self.pushButton.setVisible(True)
|
|
117
|
+
|
|
118
|
+
def message(self):
|
|
119
|
+
|
|
120
|
+
self.MessageBox.setText('Please fill with +,-')
|
|
121
|
+
self.mask_operation.setText('+')
|
|
122
|
+
self.MessageBox.setWindowTitle('Warning')
|
|
123
|
+
self.MessageBox.show()
|
|
124
|
+
|
|
125
|
+
def accepted_emit(self):
|
|
126
|
+
|
|
127
|
+
#self._selectedColor = int(float(self._combobox_colors.currentText()))
|
|
128
|
+
|
|
129
|
+
index_image = self.comboBox_image.currentIndex()
|
|
130
|
+
|
|
131
|
+
index_color = self._combobox_colors.currentIndex()
|
|
132
|
+
index_color2 = self._combobox_colors2.currentIndex()
|
|
133
|
+
if index_color2==index_color:
|
|
134
|
+
return
|
|
135
|
+
operation = self.mask_operation.currentText().strip(' ')
|
|
136
|
+
self.buttonpressed.emit([index_image, index_color2, index_color, operation])
|
|
137
|
+
|
|
138
|
+
|
|
139
|
+
|
|
140
|
+
def run():
|
|
141
|
+
import sys
|
|
142
|
+
app = QtWidgets.QApplication(sys.argv)
|
|
143
|
+
window = MaskOperations()
|
|
144
|
+
window.show()
|
|
145
|
+
sys.exit(app.exec_())
|
|
146
|
+
if __name__ == '__main__':
|
|
147
|
+
run()
|