Как читать анимированный gif с альфа-каналом

Выполняя некоторые тесты с анимацией .gif в MATLAB, я понял, что каким-то образом я не могу прочитать прозрачность gif.

Пример:

введите описание изображения здесь

(Исходный источник gif)

Если я делаю

[img,cmap]=imread('Finnandjake.gif');

img - 4D с избыточным 3-м измерением (странно). После сжатия (img=squeeze(img);), если я покажу его (imshow(img(:,:,30),cmap)):

введите описание изображения здесь

Прозрачность исчезает, используя другой цвет из изображения в качестве фона, тем самым удаляя функции. Однако

[img,cmap,alpha]=imread('Finnandjake.gif');

возвращает пустой alpha. Очевидно, что информация о альфе находится где-то в изображении, как я могу ее прочитать в MATLAB?

Ответы

Ответ 1

/Обновление: я сделал код доступным в обмен файлами MATLAB. Опубликованная версия совместима с OCTAVE и поставляется с некоторой документацией.


Я придумал это решение. Возвращаемые аргументы - это стоп-кадры, цветовая палитра и индекс, соответствующие прозрачности.

%do not use, instead use: http://www.mathworks.com/matlabcentral/fileexchange/55693-transparentgifread-filename-
function [stack,map,transparent]=transparentGifRead(filename)
if ~exist(filename,'file')
    error('file %s does not exist',filename);
end
info=imfinfo(filename);
%Check if color map for all frames is the same
if any(any(any(diff(cat(3,info.ColorTable),[],3))))
    error('inconsistent color map')
else
    map=info(1).ColorTable;
end
%Check if transparent color for all frames is the same
if any(diff([info.TransparentColor]))
    error('inconsistent transparency information')
else
    transparent=info(1).TransparentColor-1;
end
import java.io.*
str = javax.imageio.ImageIO.createImageInputStream(java.io.File(filename));
t = javax.imageio.ImageIO.getImageReaders(str);
reader = t.next();
reader.setInput(str);
numframes = reader.getNumImages(true);
for imageix = 1:numframes
    data = reader.read(imageix-1).getData();
    height = data.getHeight();
    width = data.getWidth();
    data2 = reader.read(imageix-1).getData().getPixels(0,0,width,height,[]);
    if imageix == 1
        stack=zeros(height,width,1,numframes,'uint8');
    end
    %row major vs column major fix
    stack(:,:,1,imageix) = reshape(data2,[width height]).';%'
end
str.close();
end

Некоторые демонстрационные коды для окрашивания прозрачных зеленых пикселей:

[stack,map,transparent]=transparentGifRead('tr.gif');
map(transparent+1,:)=[0,1,0] %offset 1 because uint8 starts at 0 but indices at 1
for frame=1:size(stack,ndims(stack))
    imshow(stack(:,:,frame),map);
    pause(1/25);
end