2011-05-12 3 views
4

OpenCV에서 이미지 픽셀의 빛과 색상으로 놀고있었습니다. 나는 빨간 스케일 효과를 보았습니다. OpenCV에서이를 구현하는 방법은 무엇입니까? 나는 픽셀 RGB 값을 조작하는 몇 가지 방법을 시도했다. 하지만 나는 HSV 색상 공간을 사용해야 할 수도 있다는 느낌이 들었습니다 ... pls 도움.이미지를 Redscale로 변환하는 방법?

+0

디지털 이미지의 경우이 기술에 대한 정보를 찾지 못했습니다 (지금까지). – karlphillip

+0

redscale 효과가 매우 흥미롭게 보입니다. 황색의 홍수는 일부 이미지에서 놀라운 것처럼 보입니다. 하지만 구현하는 방법에 대한 아이디어를 얻지 못하고 .. : ( – Sayak

답변

1

이미지를 redscale effect과 비슷한 모드로 변환하는 자바 스크립트를 만들 수있었습니다. 파일에 HTML 아래에 저장하고 HTML5 캔버스 요소를 지원하는 브라우저에서 엽니 다 (예 : 파이어 폭스/크롬 ... 등) 포함 된 이미지 :

편집 : 나는 스케일 효과 코드를 단순화하고 모든 사진 노란색 홍수를 만든
, - 이제 효과가 '실제'효과에 더 가깝게 보인다.

<html> 
<body> 

<script type='text/javascript'> 
function AppyRedscale(img) { 
    width = 200; 
    height = 150; 
    canvas = document.getElementById("canvas"); 
    cnt = canvas.getContext("2d"); 
    cnt.drawImage(img,0,0); 
    imageData = cnt.getImageData(0,0,width, height); 
    imageDataNew = cnt.createImageData(width, height); 

    for (x = 0; x < width; x++) { 
    for (y = 0; y < height; y++) { 
     rgb = getPixel(imageData,x,y); 
     k = rgb[2]/255; 
     rgb[0] = Mix(k,rgb[0],255); 
     rgb[1] = Mix((1-k)*(1-k),rgb[1],0); 
     rgb[2] = Mix(k,rgb[2],0); 
     setPixel(imageDataNew, x, y, rgb, 0xff); 
    } 
    } 

    cnt.putImageData(imageDataNew, 0, 0); 

}; 

function Mix(k,x,y) { 
    return (1-k)*x + k*y; 
}; 

function setPixel(imageData, x, y, rgb, a) { 
    index = (x + y * imageData.width) * 4; 
    imageData.data[index+0] = rgb[0]; 
    imageData.data[index+1] = rgb[1]; 
    imageData.data[index+2] = rgb[2]; 
    imageData.data[index+3] = a; 
}; 

function getPixel(imageData, x, y) { 
    index = (x + y * imageData.width) * 4; 
    return [imageData.data[index+0], 
      imageData.data[index+1], 
      imageData.data[index+2] 
      ]; 
}; 
</script> 

<canvas id="canvas" width="400" height="300" 
      style="position: absolute; left: 8; top: 170; z-index: 1;"><br /> 
    Sorry, canvas not supported!<br /> 
</canvas> 

<img id="img" src="%3D%3D" width="200" height="150" onload="AppyRedscale(this)"/> 

</body> 
</html> 

이 HTML은 (제 1 화상 일본어 - redscale'd) 등의 출력을 생성 할 것이다 : enter image description here

HTH를!

+1

흥미 롭습니다.당신의 노력에 +1. – karlphillip

+0

정말 대단합니다 ... 노력에 찬사 ... – Sayak

-1

나는 매우 간단한 방법으로이 코드를 opencv로 변환했습니다. opencv는 색상을 bgr로 간주하고 rgb가 아니라고 생각하기 때문에 약간의 변경을가했습니다. 코드가 제대로 작동합니다 ... 실수가 있으면 편집하십시오.

int main(int argc, char** argv) 
{ 
    IplImage* img = cvLoadImage("D:/test.jpg"); 
    cvShowImage("Input", img); 
    int x,y; 
    double k; 
    CvScalar s; 

    for (x = 0; x < img->width; x++) 
    { 
     for(y = 0; y < img->height; y++) 
     { 

      s = cvGet2D(img, y, x); 
      k = s.val[0]/255; 

      s.val[0] = (1-k) * (1-k) * s.val[0]; 
      s.val[1] = k * s.val[1]; 
      s.val[2] = (1-k) * s.val[2] + k * 255; 

      cvSet2D(img, y, x, s); 

     } 
    } 
    cvShowImage("Output", img); 
    cvWaitKey(0); 

    cvReleaseImage(&img); 
    return 0; 
} 
+0

-1. 왜 ? 네가 네 자신의 대답을 받아 들였기 때문에 나는 정말로 ... 네가 양심이 없다. –

+0

당신이 나를 완전히 오해 한 것에 대해 유감입니다. 물론 나는 당신에게 큰 대답을 주셨습니다. 하지만 OpenCV에서이 코드를 구현했기 때문에 OpenCV에서 코드를 변환하려고 시도했는데 잘못된 코드가 있으면 여기에 게시했습니다. "Add Comment"에서 코드를 게시 할 수 없었기 때문에 답변으로 게시했습니다 ... 오해하지 마십시오. 나는 아픈 의도가 없었다. 너의 대답은 나를 대단히 도왔다. – Sayak

+0

아니요. 내 대답에 대해 적립하지 않았습니다. 내 대답에 신용을 쓰고 싶다면 그것을 해결 된 것으로 표시하십시오. 정말 귀하의 대답은 표절 (내 복사 알고리즘) 때문입니다. –

2

처리가 쉽습니다.

void redscale() { 

    loadPixels();  

    for (int i = 0; i < pixels.length; i++) { 
    int r = (int) red(pixels[i]); 
    int g = (int) red(pixels[i]); 
    int b = (int) red(pixels[i]);  
    int average= (r+g+b)/3; 

    pixels[i]= color (255, average, 0); 

    updatePixels() 

} 
} 
0

답변에 대한 신용 점수는 0x69입니다. 나는 그가 실제로 OpenCV를 언급하는 질문에 대답하지 않았다고 말하고 싶다.

Anyhoot ... StackOverFlow에 대한 나의 첫 번째 시도. 그리고 예, 나는 그 질문이 '늙었다'는 것을 알고 있습니다. 그러나 나는 주제에 대해 밝힐 수 있음을 발견했습니다. 내 대답에 포함 된 것은 채널을 분리하는 방법에 대한 접근 방식이며 서로를 뺍니다. (알고리즘은 그러나 차이가 없습니다 OpenCV의 2.1 정상적인 C로 코딩되어 있기 때문에 버전이 매우 중요합니다.)

내 프로젝트 그룹과 나는 프로젝트의 중간 C를 포함 ++과 OpenCV의 2.3 에

우리 우리가 어떻게했는지 분리 녹색이었다 수행 한 후 빨간색과 파란색 채널을 빼기 위해 필요한이 있었다 : 나는 당신이이었다 사용할 수 있습니다 생각

void IsolateGreen(Mat mIn, Mat& mOut) 

{ 

Mat inImg (mIn.rows, mIn.cols, CV_8UC3, Scalar(1,2,3)); 
inImg.data = mIn.data; 
Mat channelRed (inImg.rows, inImg.cols, CV_8UC1); 
Mat channelGreen (inImg.rows, inImg.cols, CV_8UC1); 
Mat channelBlue (inImg.rows, inImg.cols, CV_8UC1); 
Mat outImg[] = {channelRed, channelGreen, channelBlue}; 

int fromTo[] = { 0,2, 1,1, 2,0}; 
mixChannels(&inImg, 1, outImg, 3, fromTo, 3); 

mOut = (channelGreen) - (channelRed + channelBlue); 

threshold(mOut, mOut, 10, 255, THRESH_BINARY); 

erode(mOut, mOut, Mat(), Point (-1,-1), 1); 
dilate(mOut, mOut, Mat(), Point(-1,-1), 3); 

} 

즉, 그것의이 부분

void IsolateGreen(Mat mIn, Mat& mOut) 
{ 
    Mat inImg (mIn.rows, mIn.cols, CV_8UC3, Scalar(1,2,3)); 
inImg.data = mIn.data; 
Mat channelRed (inImg.rows, inImg.cols, CV_8UC1); 
Mat channelGreen (inImg.rows, inImg.cols, CV_8UC1); 
Mat channelBlue (inImg.rows, inImg.cols, CV_8UC1); 
Mat outImg[] = {channelRed, channelGreen, channelBlue}; 

int fromTo[] = { 0,2, 1,1, 2,0}; 
mixChannels(&inImg, 1, outImg, 3, fromTo, 3); 

mOut = channelGreen; 
} 

여기에서 중요한 부분 (3210)은 mixChannels 기능입니다 더 http://opencv.itseez.com/modules/core/doc/operations_on_arrays.html?highlight=mixchannels#mixchannels

에 이해하기가 약간의 시간이 걸렸습니다 읽어 보시기 바랍니다. 결과는 개별 채널을 나타내는 하나 이상의 회색 음영 이미지를 제공합니다. (RGB 사진의 단일 채널과 혼합하여 원하는 채널로 전환 할 수 있습니다. 빨간색으로 볼 수 있기를 바랍니다.) 3)

관련 문제