本文整理汇总了C#中Mat.ToBitmap方法的典型用法代码示例。如果您正苦于以下问题:C# Mat.ToBitmap方法的具体用法?C# Mat.ToBitmap怎么用?C# Mat.ToBitmap使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Mat
的用法示例。
在下文中一共展示了Mat.ToBitmap方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: CppTest
public CppTest()
{
//PixelAccess();
using (Mat mat = new Mat(Const.ImageLenna, LoadMode.Color))
{
//CvSize s;
//CvPoint p;
//mat.LocateROI(out s, out p);
// CvMatへの変換
CvMat m = mat.ToCvMat();
Console.WriteLine(m);
// 行を一部分切り出し
Mat row = mat.RowRange(100, 200);
// IplImageへ変換し、highguiにより描画
IplImage img = row.ToIplImage();
using (new CvWindow("highgui", img))
{
Cv.WaitKey();
}
// Bitmapに変換して、WindowsFormで描画する
using (Bitmap bitmap = mat.ToBitmap())
using (Form form = new Form() { Text = "WindowsForms", ClientSize = new System.Drawing.Size(bitmap.Width, bitmap.Height) })
using (PictureBox pb = new PictureBox() { Image = bitmap, Dock = DockStyle.Fill })
{
form.Controls.Add(pb);
Application.Run(form);
}
// cv::imshowによる表示
CvCpp.NamedWindow("imshow", WindowMode.AutoSize);
CvCpp.ImShow("imshow", mat);
CvCpp.WaitKey(0);
Cv.DestroyAllWindows();
}
}
示例2: timer1_Tick
private void timer1_Tick(object sender, EventArgs e)
{
Mat mat1 = new Mat(_webCam1.QueryFrame());
CvPoint webCamPos1 = GetMaxLoc(mat1);
webCameraImage1.Image = mat1.ToBitmap();
g = Graphics.FromImage(webCameraImage1.Image);
g.DrawLine(new Pen(Color.Gold), webCamPos1.X + _temp.Width / 2, 0, webCamPos1.X + _temp.Width / 2, 480);
g.DrawLine(new Pen(Color.Gold), 0, webCamPos1.Y + _temp.Height / 2, 640, webCamPos1.Y + _temp.Height / 2);
Mat mat2 = new Mat(_webCam2.QueryFrame());
CvPoint webCamPos2 = GetMaxLoc(mat2);
webCameraImage2.Image = mat2.ToBitmap();
g = Graphics.FromImage(webCameraImage2.Image);
g.DrawLine(new Pen(Color.Gold), webCamPos2.X + _temp.Width / 2, 0, webCamPos2.X + _temp.Width / 2, 480);
g.DrawLine(new Pen(Color.Gold), 0, webCamPos2.Y + _temp.Height / 2, 640, webCamPos2.Y + _temp.Height / 2);
var d = RoboService.GetDistance(webCamPos1, webCamPos2);
distance.Text = d.ToString(CultureInfo.InvariantCulture);
var a = RoboService.GetAngle(webCamPos1);
}
示例3: SetOutputImage
void SetOutputImage(Mat outputImage_0, Mat outputImage_1, Mat Image)
{
this.Dispatcher.BeginInvoke(new Action(() =>
{
//this.DrawLine(this.GetEllipsePosition(InOutPutMode.output), InOutPutMode.output);
//windowの画像設定 ここから
#region
if (this.caliblationMode == CaliblationMode.back) this.wscs2.SetImage(outputImage_0.ToBitmap());
else if (this.caliblationMode == CaliblationMode.floor) this.wscs2.SetImage(outputImage_1.ToBitmap());
else this.wscs2.SetImage(this._sumMat(outputImage_0,outputImage_1,true).ToBitmap());
this.wscs3_0.SetImage(outputImage_0.ToBitmap());
this.wscs3_1.SetImage(outputImage_1.ToBitmap());
#endregion
switch (this.caliblationMode)
{
case CaliblationMode.back:
this.OutputImage.Source = WriteableBitmapConverter.ToWriteableBitmap(outputImage_0); break;
case CaliblationMode.floor:
this.OutputImage.Source = WriteableBitmapConverter.ToWriteableBitmap(outputImage_1); break;
case CaliblationMode.calibration:
this.OutputImage.Source = WriteableBitmapConverter.ToWriteableBitmap(Image); break;
}
}));
}
示例4: ToMatGrayScale
public void ToMatGrayScale()
{
Mat img = new Mat(FilePath.Lenna511, LoadMode.GrayScale);
Bitmap bitmap = img.ToBitmap();
Mat converted = BitmapConverter2.ToMat(bitmap);
//Mat converted = Mat.FromBitmap(bitmap);
using (new Window("Grayscale Bitmap to Mat test", converted))
{
Cv2.WaitKey();
}
}
示例5: usingCppInterface2
private static void usingCppInterface2()
{
// Cv2.ImRead
using (var src = new Mat(@"..\..\Images\Penguin.Png", LoadMode.AnyDepth | LoadMode.AnyColor))
using (var dst = new Mat())
{
Cv2.CvtColor(src, dst, ColorConversion.BgrToGray);
// How to export
using (var bitmap = dst.ToBitmap()) // => OpenCvSharp.Extensions.BitmapConverter.ToBitmap(dst)
{
bitmap.Save("gray.png", ImageFormat.Png);
}
using (new Window("BgrToGray C++: src", image: src))
using (new Window("BgrToGray C++: dst", image: dst))
{
Cv2.WaitKey();
}
}
}
示例6: getBarcodeText
private static string getBarcodeText(Mat barcode)
{
// `ZXing.Net` needs a white space around the barcode
var barcodeWithWhiteSpace = new Mat(new Size(barcode.Width + 30, barcode.Height + 30), MatType.CV_8U, Scalar.White);
var drawingRect = new Rect(new Point(15, 15), new Size(barcode.Width, barcode.Height));
var roi = barcodeWithWhiteSpace[drawingRect];
barcode.CopyTo(roi);
Cv2.ImShow("Enhanced Barcode", barcodeWithWhiteSpace);
Cv2.WaitKey(1); // do events
return decodeBarcodeText(barcodeWithWhiteSpace.ToBitmap());
}