Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
284 views
in Technique[技术] by (71.8m points)

numpy - How to change cmap based on array value in python

Current code:

        # Mask array with mask pixels set to 1 and rest set to 0
        mask = nib.load(os.path.join(mask_path, f))
        # Grey scale MRI image slice
        image = nib.load(os.path.join(images_path, f))
        # Extracting pixel arrays
        mask_data = mask.get_fdata()
        image_data = image.get_fdata()
        # Setting image pixels to 0 where mask pixels are set to 1
        masked_image = np.where(mask_data == 0, image_data,0)
        # Transposing and flipping to fix visual orientation
        masked_image = masked_image.transpose((1,0))
        masked_image = np.flip(masked_image,axis=0)
        # Want something like this
        # colors = np.where(mask_data == 1, 'autumn','gray')
        fig,ax = plt.subplots()
        ax.imshow(masked_image,cmap="gray")

Output image: enter image description here

Currently my code takes in an image and a mask, I set the pixel values in the image_array to 0 based on the mask. I ideally want this to show up as red: enter image description here

The only way I can see how to do this is a different colormap for all pixels with a value of 0. I don't know how to write a custom colour map based on pixel value. Is there any way to do this?

question from:https://stackoverflow.com/questions/65924186/how-to-change-cmap-based-on-array-value-in-python

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

Completely forgot matplotlib draws on top of pre existing data if using the same figure. The below code works to do what I want without needing to create my own colormap.

        plt.clf()
        # Mask array with mask pixels set to 1 and rest set to 0
        mask = nib.load(os.path.join(mask_path, f))
        # Grey scale MRI image slice
        image = nib.load(os.path.join(images_path, f))
        # Extracting pixel arrays
        mask_data = mask.get_fdata()
        image_data = image.get_fdata()
        # Transposing and flipping to fix visual orientation
        image_data = image_data.transpose((1,0))
        image_data = np.flip(image_data,axis=0)
        mask_data = mask_data.transpose((1,0))
        mask_data = np.flip(mask_data,axis=0)
        mask_data[mask_data==0] = None
        plt.imshow(image_data,cmap='gray')
        plt.imshow(mask_data,cmap = 'autumn')

Result: enter image description here


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...