C# OpenCV 학습 노트 2 이미지 읽기와 쓰기 두 가지 방법

2926 단어 imageC#nullbyte
컨트롤 loadPictureBox에 이미지 표시
방법 1
//이미지 읽기 001.jpg
IntPtr img = CvInvoke.cvLoadImage("001.jpg", Emgu.CV.CvEnum.LOAD_IMAGE_TYPE.CV_LOAD_IMAGE_COLOR);
//IntPtr에서 Image로 변환, IntPtr2Image 메서드 자세히 보기
loadPictureBox.Image = IntPtr2Image(img);
//이미지 창 표시
CvInvoke.cvShowImage("view", img);
//창은 2초 CvInvoke로 2000ms를 유지합니다.cvWaitKey(2000);
//창 닫기 CvInvoke.cvDestroyWindow("view");
//이미지 저장 CvInvoke.cvSaveImage("002.jpg", img);
//CvInvoke 해제.cvReleaseImage(ref img);
 

private Image IntPtr2Image(IntPtr src)
        {
            MIplImage img = (MIplImage)Marshal.PtrToStructure(src, typeof(MIplImage));
            Bitmap disp = new Bitmap(img.width, img.height, PixelFormat.Format24bppRgb);
            BitmapData bmp = disp.LockBits(new Rectangle(0, 0, img.width, img.height), ImageLockMode.WriteOnly, PixelFormat.Format24bppRgb);
            long linebytes = (img.width * 24 + 31) / 32 * 4;

            unsafe
            {
                byte* pixel = (byte*)bmp.Scan0.ToPointer();
                if (img.nChannels == 3)
                {
                    for (int i = 0; i < img.height; i++)
                    {
                        for (int j = 0, n = 0; j < img.width; j++, n++)
                        {
                            byte b = ((byte*)img.imageData + img.widthStep * i)[3 * j];
                            byte g = ((byte*)img.imageData + img.widthStep * i)[3 * j + 1];
                            byte r = ((byte*)img.imageData + img.widthStep * i)[3 * j + 2];
                            *(pixel + linebytes * (i) + n) = b;
                            n++;
                            *(pixel + linebytes * (i) + n) = g;
                            n++;
                            *(pixel + linebytes * (i) + n) = r;
                        }
                    }
                }
                else if (img.nChannels == 1)
                {
                    for (int i = 0; i < img.height; i++)
                    {
                        for (int j = 0, n = 0; j < img.width; j++, n++)
                        {
                            byte g = ((byte*)img.imageData + img.widthStep * i)[j];
                            *(pixel + linebytes * (i) + n) = g;
                            n++;
                            *(pixel + linebytes * (i) + n) = g;
                            n++;
                            *(pixel + linebytes * (i) + n) = g;
                        }
                    }
                }
                else
                {
                    return null;
                }
            }
            disp.UnlockBits(bmp);
            return (Image)disp;
        }

 
방법 2
Image img = new Image("001.jpg");
loadPictureBox.Image = img.ToBitmap();

좋은 웹페이지 즐겨찾기