Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> DICOM->OpenCV, Конвертирование пикселей 
V
    Опции темы
gendalf7771
Дата 28.4.2014, 13:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 31
Регистрация: 19.7.2012
Где: Архангельск

Репутация: нет
Всего: нет



Доброго времени суток!

Есть файл DICOM с одним изображением КТ брюшной полости. По факту - изображение в градациях серого по два байта на пиксель (-32768 - чёрный, 32767 - белый), то бишь signed short. Вот само изображение:
user posted image

Надо его отдать OpenCV на "хирургический стол" для всяких злодеяний типа распознавания контуров. Для препарирования DICOM использую GDCM.

Как я это делаю.
Код

char *dcmBuffer = new char[dcmImage.GetBufferLength()];
dcmImage.GetBuffer(dcmBuffer);
short *shdcmBuffer=reinterpret_cast<short*>(dcmBuffer);
//shdcmBuffer указывает на short исходного изображения

IplImage* cvImage = cvCreateImage(cvSize(gdcmImage.GetRows(),gdcmImage.GetColumns()),IPL_DEPTH_16S,1);
//IPL_DEPTH_16S - новое изображение тоже signed short

for(int y=0;y<gdcmImage.GetRows();++y)
{
    short *cvBuffer = reinterpret_cast<short*>(cvImage->imageData+y*cvImage->widthStep),
        *pcvBuffer=cvBuffer;//cvBuffer указывает на начало y-ой строки cvImage
    for(int x=0;x<gdcmImage.GetColumns();++x)
        *pcvBuffer++ = *shdcmBuffer++;
}


После этих махинаций получаю вот это:
user posted image

Подскажите, что я делаю не так?
PM MAIL   Вверх
gendalf7771
Дата 7.5.2014, 18:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 31
Регистрация: 19.7.2012
Где: Архангельск

Репутация: нет
Всего: нет



Уже не актуально, можно удалять.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1016 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.