Why my image cannot dramical crop?
Hello. I want to ask. I want to crop my image data with specific area with a specific part of an image. And I want to use auto dynamic cropping method in matlab. I’m using ultrasound data. Why my crop image does not appear on the result? Here’s my codes and I attach with my image:
clc; % Clear the command window.
close all; % Close all figures (except those of imtool.)
clear; % Erase all existing variables. Or clearvars if you want.
workspace; % Make sure the workspace panel is showing.
format long g;
format compact;
fontSize = 20;
mypath = ‘/home/motmot/Documents/test/’;
dinfo = dir(fullfile(mypath,’*.jpg’));
filenames = fullfile({dinfo.folder}, {dinfo.name});
nfiles = length(filenames);
for K = 1 : nfiles
thisfile = filenames{K};
[folder, basename, ext] = fileparts(thisfile);
outfile = fullfile(folder, basename + "_crop" + ext);
I = imread(thisfile);
% Get the dimensions of the image. numberOfColorChannels should be = 3.
[rows, columns, numberOfColorChannels] = size(I);
% Display the original color image.
subplot(2, 3, 1);
imshow(I);
axis on;
hp = impixelinfo(); % Show x,y and RGB as you mouse around.
title(‘Original Color Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Take the red channel.
grayImage = I(:, :, 1);
% Erase the first 110 columns to get rid of the holes.
verticalProfile = mean(grayImage, 2);
for col = 1 : 110
grayImage(:, col) = verticalProfile;
end
% Run a texture filter on it.
stdImage = stdfilt(grayImage);
% Display the image.
subplot(2, 3, 2);
imshow(stdImage, []);
axis on;
title(‘Filtered Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Enlarge figure
set(gcf, ‘Units’, ‘Normalized’, ‘Outerposition’, [0.05, 0.1, .9, .80]);
% Let’s compute and display the histogram.
subplot(2, 3, 3);
histogram(stdImage, 500); % 500 bins.
grid on;
title(‘Histogram of Filtered image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
xlabel(‘Gray Level’, ‘FontSize’, fontSize);
ylabel(‘Pixel Count’, ‘FontSize’, fontSize);
% Threshold the image.
binaryImage = stdImage > 5;
% Display the image.
subplot(2, 3, 4);
imshow(binaryImage);
axis on;
title(‘Binary Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% % Get areas of blobs
% labeledImage = bwlabel(binaryImage);
% props = regionprops(labeledImage, ‘Area’);
% allAreas = sort([props.Area])
% subplot(2, 3, 5);
% histogram(allAreas); % Show histogram of blob areas.
% title(‘Blob Areas’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Get rid of small blobs.
binaryImage = bwareafilt(binaryImage, [70, inf]); % Keep only if 70 pixels or larger.
% Display the image.
subplot(2, 3, 5);
imshow(binaryImage);
axis on;
title(‘Cleaned Binary Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Find the bounding box.
[blobRows, blobColumns] = find(binaryImage);
row1 = min(blobRows);
row2 = max(blobRows);
col1 = min(blobColumns);
col2 = max(blobColumns);
% Crop it.
croppedImage = rgbImage(row1:row2, col1:col2, :);
% Display the cropped, enhanced color image.
subplot(2, 3, 6);
imshow(croppedImage);
axis on;
title(‘Cropped Color Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
imwrite(croppedImage, outfile)
endHello. I want to ask. I want to crop my image data with specific area with a specific part of an image. And I want to use auto dynamic cropping method in matlab. I’m using ultrasound data. Why my crop image does not appear on the result? Here’s my codes and I attach with my image:
clc; % Clear the command window.
close all; % Close all figures (except those of imtool.)
clear; % Erase all existing variables. Or clearvars if you want.
workspace; % Make sure the workspace panel is showing.
format long g;
format compact;
fontSize = 20;
mypath = ‘/home/motmot/Documents/test/’;
dinfo = dir(fullfile(mypath,’*.jpg’));
filenames = fullfile({dinfo.folder}, {dinfo.name});
nfiles = length(filenames);
for K = 1 : nfiles
thisfile = filenames{K};
[folder, basename, ext] = fileparts(thisfile);
outfile = fullfile(folder, basename + "_crop" + ext);
I = imread(thisfile);
% Get the dimensions of the image. numberOfColorChannels should be = 3.
[rows, columns, numberOfColorChannels] = size(I);
% Display the original color image.
subplot(2, 3, 1);
imshow(I);
axis on;
hp = impixelinfo(); % Show x,y and RGB as you mouse around.
title(‘Original Color Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Take the red channel.
grayImage = I(:, :, 1);
% Erase the first 110 columns to get rid of the holes.
verticalProfile = mean(grayImage, 2);
for col = 1 : 110
grayImage(:, col) = verticalProfile;
end
% Run a texture filter on it.
stdImage = stdfilt(grayImage);
% Display the image.
subplot(2, 3, 2);
imshow(stdImage, []);
axis on;
title(‘Filtered Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Enlarge figure
set(gcf, ‘Units’, ‘Normalized’, ‘Outerposition’, [0.05, 0.1, .9, .80]);
% Let’s compute and display the histogram.
subplot(2, 3, 3);
histogram(stdImage, 500); % 500 bins.
grid on;
title(‘Histogram of Filtered image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
xlabel(‘Gray Level’, ‘FontSize’, fontSize);
ylabel(‘Pixel Count’, ‘FontSize’, fontSize);
% Threshold the image.
binaryImage = stdImage > 5;
% Display the image.
subplot(2, 3, 4);
imshow(binaryImage);
axis on;
title(‘Binary Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% % Get areas of blobs
% labeledImage = bwlabel(binaryImage);
% props = regionprops(labeledImage, ‘Area’);
% allAreas = sort([props.Area])
% subplot(2, 3, 5);
% histogram(allAreas); % Show histogram of blob areas.
% title(‘Blob Areas’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Get rid of small blobs.
binaryImage = bwareafilt(binaryImage, [70, inf]); % Keep only if 70 pixels or larger.
% Display the image.
subplot(2, 3, 5);
imshow(binaryImage);
axis on;
title(‘Cleaned Binary Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Find the bounding box.
[blobRows, blobColumns] = find(binaryImage);
row1 = min(blobRows);
row2 = max(blobRows);
col1 = min(blobColumns);
col2 = max(blobColumns);
% Crop it.
croppedImage = rgbImage(row1:row2, col1:col2, :);
% Display the cropped, enhanced color image.
subplot(2, 3, 6);
imshow(croppedImage);
axis on;
title(‘Cropped Color Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
imwrite(croppedImage, outfile)
end Hello. I want to ask. I want to crop my image data with specific area with a specific part of an image. And I want to use auto dynamic cropping method in matlab. I’m using ultrasound data. Why my crop image does not appear on the result? Here’s my codes and I attach with my image:
clc; % Clear the command window.
close all; % Close all figures (except those of imtool.)
clear; % Erase all existing variables. Or clearvars if you want.
workspace; % Make sure the workspace panel is showing.
format long g;
format compact;
fontSize = 20;
mypath = ‘/home/motmot/Documents/test/’;
dinfo = dir(fullfile(mypath,’*.jpg’));
filenames = fullfile({dinfo.folder}, {dinfo.name});
nfiles = length(filenames);
for K = 1 : nfiles
thisfile = filenames{K};
[folder, basename, ext] = fileparts(thisfile);
outfile = fullfile(folder, basename + "_crop" + ext);
I = imread(thisfile);
% Get the dimensions of the image. numberOfColorChannels should be = 3.
[rows, columns, numberOfColorChannels] = size(I);
% Display the original color image.
subplot(2, 3, 1);
imshow(I);
axis on;
hp = impixelinfo(); % Show x,y and RGB as you mouse around.
title(‘Original Color Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Take the red channel.
grayImage = I(:, :, 1);
% Erase the first 110 columns to get rid of the holes.
verticalProfile = mean(grayImage, 2);
for col = 1 : 110
grayImage(:, col) = verticalProfile;
end
% Run a texture filter on it.
stdImage = stdfilt(grayImage);
% Display the image.
subplot(2, 3, 2);
imshow(stdImage, []);
axis on;
title(‘Filtered Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Enlarge figure
set(gcf, ‘Units’, ‘Normalized’, ‘Outerposition’, [0.05, 0.1, .9, .80]);
% Let’s compute and display the histogram.
subplot(2, 3, 3);
histogram(stdImage, 500); % 500 bins.
grid on;
title(‘Histogram of Filtered image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
xlabel(‘Gray Level’, ‘FontSize’, fontSize);
ylabel(‘Pixel Count’, ‘FontSize’, fontSize);
% Threshold the image.
binaryImage = stdImage > 5;
% Display the image.
subplot(2, 3, 4);
imshow(binaryImage);
axis on;
title(‘Binary Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% % Get areas of blobs
% labeledImage = bwlabel(binaryImage);
% props = regionprops(labeledImage, ‘Area’);
% allAreas = sort([props.Area])
% subplot(2, 3, 5);
% histogram(allAreas); % Show histogram of blob areas.
% title(‘Blob Areas’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Get rid of small blobs.
binaryImage = bwareafilt(binaryImage, [70, inf]); % Keep only if 70 pixels or larger.
% Display the image.
subplot(2, 3, 5);
imshow(binaryImage);
axis on;
title(‘Cleaned Binary Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
% Find the bounding box.
[blobRows, blobColumns] = find(binaryImage);
row1 = min(blobRows);
row2 = max(blobRows);
col1 = min(blobColumns);
col2 = max(blobColumns);
% Crop it.
croppedImage = rgbImage(row1:row2, col1:col2, :);
% Display the cropped, enhanced color image.
subplot(2, 3, 6);
imshow(croppedImage);
axis on;
title(‘Cropped Color Image’, ‘FontSize’, fontSize, ‘Interpreter’, ‘None’);
imwrite(croppedImage, outfile)
end crop, dynamic MATLAB Answers — New Questions