logo

English

이곳의 프로그래밍관련 정보와 소스는 마음대로 활용하셔도 좋습니다. 다만 쓰시기 전에 통보 정도는 해주시는 것이 예의 일것 같습니다. 질문이나 오류 수정은 siseong@gmail.com 으로 주세요. 감사합니다.

[Win32] HBITMAP Contrast 조절하는 코드 - RGB 이미지 보정

by 엉뚱도마뱀 posted May 04, 2018
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print

GDI+를 사용하면 보다 편리한 방법이 있습니다만

전통적인 GDI를 사용하는 코드에서 HBITMAP으로 Contrast를 조절하는 방법입니다.

이 코드를 응용하면 RGB 형식으로 변환하여 여러가지 이미지 처리를 하는데 응용할 수 있습니다.

 

 

#include <windows.h>

#include <complex>

 

static unsigned char TransLut[256];

 

void build_lookup_table ( int contr )

{

    float step,step_value;

 

    for (int i=0; i < 256; i++)

        TransLut[i] = i;

 

    if (contr > 0)

    {

        unsigned int MinBin = contr;

        unsigned int MaxBin = 255 - contr;

 

        step = sqrt((double)contr)/contr;

        step_value = 0.0;

 

        for ( i = 0; i < MinBin; i++)

        {

            TransLut[i] = (unsigned char)step_value;

            step_value += step;

        }

 

        step = 256.0f / (float)(MaxBin-MinBin);

 

        for ( i = MinBin; i <= MaxBin; i++)

        {

 

        if (step_value > 255.0f)

        {

            step_value = 255.0f;

            step = 0.0f;

        }

 

        TransLut[i] = (unsigned char)step_value;

        step_value += step;

        }

 

        for ( i = MaxBin + 1; i < 256; i++)

            TransLut[i] = 255;

 

    }

    else

    {

        if (contr<0)

        {

            step = (256.0+(float)(contr*2))/256.0;

            step_value = (float)contr * -1.0;

 

            for (i = 0;i < 256; i++)

            {

                TransLut[i] = (unsigned char)step_value;

                step_value += step;

            }

        }

    }

}

 

BOOL ChangeBitmapContrast(HBITMAP * phBitmap, int iCount)

{

    BITMAP    bm;

    BYTE    * pBits;

    RGBQUAD * pRgb;

    WORD      wByteCount;

    int       i, iPixels, gray;

 

    build_lookup_table(iCount);

 

    // Take BITMAP structure from HBITMAP

 

    GetObject(*phBitmap, sizeof(BITMAP), &bm);

 

    // Calculate bytes to read

 

    wByteCount = bm.bmHeight * (2 * ((bm.bmWidth * bm.bmBitsPixel + 15) / 16));

 

    // Alocate momory for bits od pixels and get pointers

 

    pBits = (BYTE *) malloc(wByteCount);

    GetBitmapBits(*phBitmap, wByteCount, pBits);

 

    // Convert pointer to byte to pointer to RGBQUAD

 

    pRgb = (RGBQUAD *) pBits;

 

    // Operate on pixel's colors

 

    iPixels = wByteCount / (bm.bmBitsPixel / 8);

 

    for(i = 0; i < iPixels; i++, pRgb++)

    {

        gray = (pRgb->rgbRed + pRgb->rgbGreen + pRgb->rgbBlue) / 3;

        int k = TransLut[gray]-gray;

 

        pRgb->rgbRed   = min(pRgb->rgbRed   + k, 255);

        pRgb->rgbGreen = min(pRgb->rgbGreen + k, 255);

        pRgb->rgbBlue  = min(pRgb->rgbBlue  + k, 255);

    }

 

    SetBitmapBits(*phBitmap, wByteCount, pBits);

 

    return TRUE;

}

TAG •

List of Articles
No. Subject Author Date Views
45 VS2005 ConvertBSTRToString 에서 LNK2019 에러 대처법 digipine 2017.10.29 192
44 VS2003 이상에서 iostream 구현의 문제점 digipine 2017.10.29 256
43 [C#] Convert char[] to string digipine 2017.10.29 301
42 VC++ 에서 대소문자 변경하는 함수 digipine 2017.10.29 311
41 MS의 Hot Fix API의 유형 연구 digipine 2017.10.29 312
40 [WINCE] 메모리카드 상태 감시 digipine 2017.10.29 327
39 Mutex, Critical Section Class 만들기 digipine 2017.10.29 392
38 CreateSemaphore Semaphore Manager digipine 2017.10.29 447
37 Serialize를 이용한 객체 복사하기 (Copy constructor) digipine 2017.10.29 499
36 RPC에 대하여... (3) : RPC 작동을 위한 테스트 방법 digipine 2017.10.29 543
35 [WINCE] IAT Hooking 방법과 소스 코드 digipine 2017.10.29 659
34 Windows API 멀티 쓰레드 구현법 digipine 2017.10.29 697
33 [WINCE] MulDiv 함수 구현 digipine 2017.10.29 702
» [Win32] HBITMAP Contrast 조절하는 코드 - RGB 이미지 보정 엉뚱도마뱀 2018.05.04 738
31 RegEnumKeyEx 함수 사용법 digipine 2017.10.29 756
30 세마포어의 개념과 사용법 digipine 2017.10.29 765
29 [WINCE] 키보드 및 마우스 메시지 후킹하기 digipine 2017.10.29 809
28 DLL과 EXE간의 데이타 공유하기 digipine 2017.10.29 837
27 [MFC] Dialog에서 부모 윈도우 알아내기 digipine 2017.10.28 924
26 [WINCE] Process, Thread API 함수 사용법 digipine 2017.10.29 960
Board Pagination Prev 1 2 3 Next
/ 3