Как создать наложение в Fo-Dicom, нужен пример кода для создания и отображения слоя наложения с помощью fo-dicom
Наложение создано с использованием приведенного ниже кода, но при импорте dicom он ничего не показывает, не знаю, в чем ошибка.< /p>
DicomFile dicomFile = DicomFile.Open(sourceDicomFileName, FileReadOption.ReadAll);
ushort width = dicomFile.Dataset.GetSingleValue(DicomTag.Columns);
ushort height = dicomFile.Dataset.GetSingleValue(DicomTag.Rows);
byte[] packedbitarray = Array.Empty();
Application.Current.Dispatcher.Invoke(() =>
{
var grid = new Grid { Width = width, Height = height };
var text = new TextBlock
{
Text = "OVERLAY",
FontSize = 32,
FontWeight = FontWeights.Bold,
HorizontalAlignment = HorizontalAlignment.Center
};
grid.Children.Add(text);
grid.Measure(new Size(grid.Width, grid.Height));
grid.Arrange(new Rect(new Size(grid.Width, grid.Height)));
var rtb = new RenderTargetBitmap(
(int)grid.Width,
(int)grid.Height,
96,
96,
PixelFormats.Pbgra32);
rtb.Render(grid);
int stride = rtb.PixelWidth * 4;
int size = rtb.PixelHeight * stride;
byte[] coloredPixels = new byte[size];
rtb.CopyPixels(coloredPixels, stride, 0);
BitArray bits = new BitArray(width * height);
for (int i = 0; i < size / 4; i++)
{
bits = coloredPixels[4 * i + 3] == 0 ? false : true;
}
packedbitarray = new byte[Math.Max(1, bits.Length / 8)];
bits.CopyTo(packedbitarray, 0);
});
dicomFile.Dataset.Add(new DicomUnsignedShort(new DicomTag(0x6000, 0x0010), width));
dicomFile.Dataset.Add(new DicomUnsignedShort(new DicomTag(0x6000, 0x0011), height));
dicomFile.Dataset.Add(new DicomCodeString(new DicomTag(0x6000, 0x0040), "G"));
dicomFile.Dataset.Add(new DicomSignedShort(new DicomTag(0x6000, 0x0050), new short[] { 1, 1 }));
dicomFile.Dataset.Add(new DicomUnsignedShort(new DicomTag(0x6000, 0x0100), 1));
dicomFile.Dataset.Add(new DicomUnsignedShort(new DicomTag(0x6000, 0x0102), 0));
MemoryByteBuffer buffer = new MemoryByteBuffer(packedbitarray);
dicomFile.Dataset.Add(new DicomOtherByte(new DicomTag(0x6000, 0x3000), buffer));
dicomFile.Save(destDicomFileName);
Подробнее здесь: https://stackoverflow.com/questions/792 ... ow-overlay
Как создать наложение в Fo-Dicom, нужен пример кода для создания и отображения слоя наложения с помощью fo-dicom ⇐ C#
Место общения программистов C#
1734419044
Anonymous
Как создать наложение в Fo-Dicom, нужен пример кода для создания и отображения слоя наложения с помощью fo-dicom
Наложение создано с использованием приведенного ниже кода, но при импорте dicom он ничего не показывает, не знаю, в чем ошибка.< /p>
DicomFile dicomFile = DicomFile.Open(sourceDicomFileName, FileReadOption.ReadAll);
ushort width = dicomFile.Dataset.GetSingleValue(DicomTag.Columns);
ushort height = dicomFile.Dataset.GetSingleValue(DicomTag.Rows);
byte[] packedbitarray = Array.Empty();
Application.Current.Dispatcher.Invoke(() =>
{
var grid = new Grid { Width = width, Height = height };
var text = new TextBlock
{
Text = "OVERLAY",
FontSize = 32,
FontWeight = FontWeights.Bold,
HorizontalAlignment = HorizontalAlignment.Center
};
grid.Children.Add(text);
grid.Measure(new Size(grid.Width, grid.Height));
grid.Arrange(new Rect(new Size(grid.Width, grid.Height)));
var rtb = new RenderTargetBitmap(
(int)grid.Width,
(int)grid.Height,
96,
96,
PixelFormats.Pbgra32);
rtb.Render(grid);
int stride = rtb.PixelWidth * 4;
int size = rtb.PixelHeight * stride;
byte[] coloredPixels = new byte[size];
rtb.CopyPixels(coloredPixels, stride, 0);
BitArray bits = new BitArray(width * height);
for (int i = 0; i < size / 4; i++)
{
bits[i] = coloredPixels[4 * i + 3] == 0 ? false : true;
}
packedbitarray = new byte[Math.Max(1, bits.Length / 8)];
bits.CopyTo(packedbitarray, 0);
});
dicomFile.Dataset.Add(new DicomUnsignedShort(new DicomTag(0x6000, 0x0010), width));
dicomFile.Dataset.Add(new DicomUnsignedShort(new DicomTag(0x6000, 0x0011), height));
dicomFile.Dataset.Add(new DicomCodeString(new DicomTag(0x6000, 0x0040), "G"));
dicomFile.Dataset.Add(new DicomSignedShort(new DicomTag(0x6000, 0x0050), new short[] { 1, 1 }));
dicomFile.Dataset.Add(new DicomUnsignedShort(new DicomTag(0x6000, 0x0100), 1));
dicomFile.Dataset.Add(new DicomUnsignedShort(new DicomTag(0x6000, 0x0102), 0));
MemoryByteBuffer buffer = new MemoryByteBuffer(packedbitarray);
dicomFile.Dataset.Add(new DicomOtherByte(new DicomTag(0x6000, 0x3000), buffer));
dicomFile.Save(destDicomFileName);
Подробнее здесь: [url]https://stackoverflow.com/questions/79286915/how-to-create-overlay-in-fo-dicom-need-code-example-to-create-and-show-overlay[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия