clc;clear;
src_img_path = '带转换的文件夹路径'; % input path
save_dir = '保存路径'; % output path
file_list = dir(fullfile(src_img_path, '*.*')); % get list of files in the source directory
for idx = 1:length(file_list)
if file_list(idx).isdir
continue; % skip directories
end
[~, file_name, file_ext] = fileparts(file_list(idx).name); % split file name and extension
if ~ismember(file_ext, {'.RAW', '.raw', '.png', '.jpg', '.bmp'})
continue; % skip files with unsupported extensions
end
original = readFile(fullfile(src_img_path, file_list(idx).name)); % read the original image
convertedImage = demosaic(original, 'bggr'); % convert Bayer pattern to RGB
if size(convertedImage, 1) ~= 480
convertedImage = imresize(convertedImage, [480, 480]); % resize if necessary
end
% Save the converted image
output_path = fullfile(save_dir, [file_name '.png']);
imwrite(convertedImage, output_path);
end
需要注意这段代码,如果是rggb则图像会偏青色;
convertedImage = demosaic(original, 'bggr'); % convert Bayer pattern to RGB