Guest User

Untitled

a guest
Jul 15th, 2018
93
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.88 KB | None | 0 0
  1. int main( int argc, char** argv )
  2. {
  3. int col_1, row_1;
  4. uchar b_1, g_1, r_1, b_2, g_2, r_2, b_d, g_d, r_d;
  5.  
  6. IplImage* img = cvLoadImage( "input file");
  7. IplImage* img1 = cvCreateImage( cvSize( img->width,img->height ), img->depth, img->nChannels);
  8. IplImage* img2 = cvCreateImage( cvSize( img->width,img->height ), img->depth, img->nChannels);
  9. IplImage* dst = cvCreateImage( cvSize( img->width,img->height ), img->depth, img->nChannels);
  10. IplImage* gray= cvCreateImage(cvGetSize(img), img->depth, 1);
  11.  
  12. cvNamedWindow("Input", CV_WINDOW_AUTOSIZE );
  13. cvNamedWindow("Output", CV_WINDOW_AUTOSIZE );
  14.  
  15. cvShowImage("Input", img );
  16. cvNot(img, img1);
  17. cvSmooth( img1, img2, CV_BLUR, 25,25,0,0);
  18.  
  19. for( row_1 = 0; row_1 < img1->height; row_1++ )
  20. {
  21. for ( col_1 = 0; col_1 < img1->width; col_1++ )
  22. {
  23. b_1 = CV_IMAGE_ELEM( img1, uchar, row_1, col_1 * 3 );
  24. g_1 = CV_IMAGE_ELEM( img1, uchar, row_1, col_1 * 3 + 1 );
  25. r_1 = CV_IMAGE_ELEM( img1, uchar, row_1, col_1 * 3 + 2 );
  26.  
  27. b_2 = CV_IMAGE_ELEM( img2, uchar, row_1, col_1 * 3 );
  28. g_2 = CV_IMAGE_ELEM( img2, uchar, row_1, col_1 * 3 + 1 );
  29. r_2 = CV_IMAGE_ELEM( img2, uchar, row_1, col_1 * 3 + 2 );
  30.  
  31. b_d = b_1 + b_2;
  32. g_d = g_1 + g_2;
  33. r_d = r_1 + r_2;
  34.  
  35. dst->imageData[img1->widthStep * row_1 + col_1* 3] = b_d;
  36. dst->imageData[img1->widthStep * row_1 + col_1 * 3 + 1] = g_d;
  37. dst->imageData[img1->widthStep * row_1 + col_1 * 3 + 2] = r_d;
  38. }
  39. }
  40. cvCvtColor(dst, gray, CV_BGR2GRAY);
  41. cvShowImage("Output", gray );
  42.  
  43. cvWaitKey(0);
  44. cvReleaseImage( &img );
  45. cvReleaseImage( &gray);
  46. cvDestroyWindow("Input");
  47. cvDestroyWindow("Output");
  48. }
  49.  
  50. #include <cv.h>
  51. #include <highgui.h>
  52.  
  53. int main( int argc, char** argv )
  54. {
  55. int col_1, row_1;
  56. uchar b_1, g_1, r_1, b_2, g_2, r_2, b_d, g_d, r_d;
  57.  
  58. IplImage* img = cvLoadImage("test.png");
  59. IplImage* img1 = cvCreateImage( cvSize( img->width,img->height ), img->depth, img->nChannels);
  60. IplImage* img2 = cvCreateImage( cvSize( img->width,img->height ), img->depth, img->nChannels);
  61. IplImage* dst = cvCreateImage( cvSize( img->width,img->height ), img->depth, img->nChannels);
  62. IplImage* gray= cvCreateImage(cvGetSize(img), img->depth, 1);
  63.  
  64. cvNamedWindow("Input", CV_WINDOW_AUTOSIZE );
  65. cvNamedWindow("Output", CV_WINDOW_AUTOSIZE );
  66.  
  67. cvShowImage("Input", img );
  68. cvNot(img, img1);
  69. // cvSmooth(img1, img2, CV_BLUR, 25,25,0,0);
  70. cvSmooth(img, img2, CV_GAUSSIAN, 7, 7, 0, 0); // last fix :)
  71.  
  72. for( row_1 = 0; row_1 < img1->height; row_1++ )
  73. {
  74. for ( col_1 = 0; col_1 < img1->width; col_1++ )
  75. {
  76. b_1 = CV_IMAGE_ELEM( img1, uchar, row_1, col_1 * 3 );
  77. g_1 = CV_IMAGE_ELEM( img1, uchar, row_1, col_1 * 3 + 1 );
  78. r_1 = CV_IMAGE_ELEM( img1, uchar, row_1, col_1 * 3 + 2 );
  79.  
  80. b_2 = CV_IMAGE_ELEM( img2, uchar, row_1, col_1 * 3 );
  81. g_2 = CV_IMAGE_ELEM( img2, uchar, row_1, col_1 * 3 + 1 );
  82. r_2 = CV_IMAGE_ELEM( img2, uchar, row_1, col_1 * 3 + 2 );
  83.  
  84. // b_d = b_1 + b_2;
  85. // g_d = g_1 + g_2;
  86. // r_d = r_1 + r_2;
  87.  
  88. b_d = std::min(255, b_1 + b_2);
  89. g_d = std::min(255, g_1 + g_2);
  90. r_d = std::min(255, r_1 + r_2);
  91.  
  92. dst->imageData[img1->widthStep * row_1 + col_1* 3] = b_d;
  93. dst->imageData[img1->widthStep * row_1 + col_1 * 3 + 1] = g_d;
  94. dst->imageData[img1->widthStep * row_1 + col_1 * 3 + 2] = r_d;
  95. }
  96. }
  97. cvCvtColor(dst, gray, CV_BGR2GRAY);
  98. cvShowImage("Output", gray );
  99.  
  100. cvWaitKey(0);
  101. cvReleaseImage( &img );
  102. cvReleaseImage( &img1 ); // Yes, you must release all the allocated memory.
  103. cvReleaseImage( &img2 );
  104. cvReleaseImage( &dst );
  105. cvReleaseImage( &gray);
  106. cvDestroyWindow("Input");
  107. cvDestroyWindow("Output");
  108. }
Add Comment
Please, Sign In to add comment