C++与C#创建位图,是否需要区分RGB和BGR模式

17 篇文章 1 订阅

在处理位图时,确实需要区分RGB和BGR模式,因为不同的库和API对颜色通道的排序有不同的约定。具体到C++与C#,这一点也是需要注意的。

C++ 创建位图

  • 使用GDI+或WIC (Windows Imaging Component): 当你在C++中使用这些Windows API创建或操作位图时,通常会指定像素格式,比如PixelFormat24bppRGBPixelFormat24bppBGR。这意味着你需要根据API的要求明确指定是RGB还是BGR。例如,GUID_WICPixelFormat24bppBGR明确指定了BGR顺序。

  • OpenCV: 如果你使用OpenCV处理图像,其默认的颜色顺序是BGR,所以即使你处理的是RGB图像,也需要考虑颜色通道的转换。

C++中创建位图的方法更加多样化,取决于你是否使用托管代码(如C++/CLI)或原生代码。

使用C++/CLI(托管代码)

类似于C#,在C++/CLI中也可以使用.NET FrameworkSystem.Drawing命名空间来创建位图,语法非常接近C#,如之前所示。

使用原生C++库(非托管代码)

  1. GDI+: 如之前示例,使用Windows的GDI+库创建位图。这种方法提供了跨平台之外的替代方案,但仍然主要适用于Windows平台。

  2. Direct2D/DirectWrite: 对于性能要求较高的应用,可以使用Direct2D或DirectWrite,这是更现代且高效的图形API,支持硬件加速。创建位图的代码会更加复杂,涉及到更多的底层细节。

示例代码 

#include <d2d1.h> // Direct2D头文件
#include <wincodec.h> // Windows Imaging Component (WIC)

HRESULT CreateRgbBitmap(ID2D1Factory* pFactory, int width, int height, ID2D1Bitmap** ppBitmap)
{
    IWICBitmap* pWicBitmap = nullptr;
    IWICImagingFactory* pWicFactory = nullptr;
    CoCreateInstance(CLSID_WICImagingFactory, nullptr, CLSCTX_INPROC_SERVER, IID_IWICImagingFactory, (LPVOID*)&pWicFactory);

    HRESULT hr = pWicFactory->CreateBitmap(width, height, GUID_WICPixelFormat24bppBGR, WICBitmapCacheOnDemand, &pWicBitmap);
    
    if (SUCCEEDED(hr))
    {
        D2D1_BITMAP_PROPERTIES props = D2D1::BitmapProperties(D2D1::PixelFormat(DXGI_FORMAT_B8G8R8A8_UNORM, D2D1_ALPHA_MODE_PREMULTIPLIED));
        hr = pFactory->CreateWicBitmapRenderTarget(pWicBitmap, &props, reinterpret_cast<ID2D1RenderTarget**>(ppBitmap));
    }

    SafeRelease(pWicBitmap);
    SafeRelease(pWicFactory);
    return hr;
}
  • 优点:更高的性能,尤其是在游戏和图形密集型应用中。提供了更多控制和灵活性。
  • 缺点:实现相对复杂,需要更多了解底层图形API,且代码不如C#中的简洁。

总结来说,C#创建位图更倾向于快速开发和易于维护,而C++提供了从高层级(使用托管代码)到低层级(使用原生API)的多种选择,后者更适合性能敏感或需要高度定制的场景。

 

C# 创建位图

在C#中,通常使用.NET Framework.NET Core/.NET 5+中的System.Drawing命名空间来创建位图。这是一个高层级的抽象,简化了图形处理的任务。

  • System.Drawing: 在C#中使用System.Drawing.Bitmap类时,通常处理的是RGB顺序。当你创建位图时,指定PixelFormat.Format24bppRgb意味着颜色通道按照红绿蓝的顺序排列。C#的Bitmap类默认预期数据是以RGB格式组织的,尽管实际内存布局可能因系统和图形硬件而异。

  • WPF或UWP: 在这些框架中,颜色通常也是以RGB形式处理,尽管具体的实现细节和API可能与System.Drawing有所不同。

示例代码 

using System.Drawing;
using System.Drawing.Imaging;

public Bitmap CreateRgbBitmap(int width, int height)
{
    // 使用指定宽度、高度和像素格式(24位RGB)创建位图
    Bitmap bitmap = new Bitmap(width, height, PixelFormat.Format24bppRgb);
    return bitmap;
}
  • 优点:易于使用,提供了丰富的图像处理功能。
  • 缺点:依赖于.NET Framework,限制了跨平台能力(尽管.NET Core开始支持跨平台,但System.Drawing在非Windows平台上功能有限)。

 

读取dicom

在读取dicom后即可区分是灰度图像还是彩色图像。

C# 使用fo-dicom操作dicom文件-CSDN博客

 

总结

因此,当你从DICOM数据创建RGB位图并保存到内存时,确实需要根据你使用的编程语言、库以及最终目标(如显示设备的期望)来确定是否需要在RGB和BGR之间转换。在C++和C#中,确保你清楚地知道所使用的API或库的预期颜色格式,并相应地调整数据。

 

  • 30
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wangnaisheng

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值