From e04a6b85d348072a96b58563c6c43ffd84ad143d Mon Sep 17 00:00:00 2001 From: Edwin Supple Date: Fri, 12 Jul 2024 14:19:29 -0600 Subject: [PATCH] Adjust scalebar logic to combine any specified parameters with defaults. --- py4DSTEM/visualize/show.py | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/py4DSTEM/visualize/show.py b/py4DSTEM/visualize/show.py index dcb1cf285..d5a50cb33 100644 --- a/py4DSTEM/visualize/show.py +++ b/py4DSTEM/visualize/show.py @@ -186,7 +186,7 @@ def show( and >>> show(dp, calibration=calibration, scalebar={'length':0.5,'width':2, - 'position':'ul','label':True'}) + 'position':'ul','label':True}) will display a more customized scalebar. @@ -316,7 +316,7 @@ def show( if returnfig==False (default), the figure is plotted and nothing is returned. if returnfig==True, return the figure and the axis. """ - if scalebar is True: + if scalebar is True or scalebar is None: scalebar = {} # Alias dep @@ -428,7 +428,7 @@ def show( er = ".calibration attribute must be a Calibration instance" assert isinstance(cal, Calibration), er if isinstance(ar, DiffractionSlice): - scalebar = { + defaultscalebar = { "Nx": ar.data.shape[0], "Ny": ar.data.shape[1], "pixelsize": cal.get_Q_pixel_size(), @@ -436,10 +436,13 @@ def show( "space": "Q", "position": "br", } + for key, value in defaultscalebar.items(): + if key not in scalebar.keys(): + scalebar[key] = value pixelsize = cal.get_Q_pixel_size() pixelunits = cal.get_Q_pixel_units() elif isinstance(ar, RealSlice): - scalebar = { + defaultscalebar = { "Nx": ar.data.shape[0], "Ny": ar.data.shape[1], "pixelsize": cal.get_R_pixel_size(), @@ -447,6 +450,9 @@ def show( "space": "Q", "position": "br", } + for key, value in defaultscalebar.items(): + if key not in scalebar.keys(): + scalebar[key] = value pixelsize = cal.get_R_pixel_size() pixelunits = cal.get_R_pixel_units() # get the data