本文整理汇总了C#中Image.GetAverage方法的典型用法代码示例。如果您正苦于以下问题:C# Image.GetAverage方法的具体用法?C# Image.GetAverage怎么用?C# Image.GetAverage使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Image
的用法示例。
在下文中一共展示了Image.GetAverage方法的9个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: getThreshold
//use two pass threshold to avoid much noise point
private Image<Gray, float> getThreshold(Image<Gray,float> toBeThreshold)
{
Gray avg = toBeThreshold.GetAverage(null);
Image<Gray, float> mask = toBeThreshold.ThresholdBinary(avg, new Gray(255));
Gray avg2 = toBeThreshold.GetAverage(mask.Convert<Gray,byte>());
return toBeThreshold.ThresholdBinary(avg2, new Gray(255));
}
示例2: btnAvgHS_Click
private void btnAvgHS_Click(object sender, EventArgs e)
{
Image<Hsv, byte> HsvROI = new Image<Hsv, byte>(roiImg.Width, roiImg.Height);
CvInvoke.cvCvtColor(roiImg,HsvROI,COLOR_CONVERSION.CV_BGR2HSV);
textBoxHue.Text=HsvROI.GetAverage().Hue.ToString();
textBoxSat.Text=HsvROI.GetAverage().Satuation.ToString();
}
示例3: AdjWP
public void AdjWP(Image<Bgr, byte> roiImg, Xyz WP, double[] AdjXYZ)
{
//Image<Bgr, byte> roiImg = (Image<Bgr, byte>)roi;
Image<Xyz, byte> XYZROI = new Image<Xyz, byte>(roiImg.Width, roiImg.Height);
CvInvoke.cvCvtColor(roiImg, XYZROI, COLOR_CONVERSION.CV_BGR2XYZ);
double AvgX = XYZROI.GetAverage().X;
double AvgY = XYZROI.GetAverage().Y;
double AvgZ = XYZROI.GetAverage().Z;
double AdjX = Math.Abs(WP.X / AvgX);
double AdjY = Math.Abs(WP.Y / AvgY);
double AdjZ = Math.Abs(WP.Z / AvgZ);
AdjXYZ[0] = AdjX;
AdjXYZ[1] = AdjY;
AdjXYZ[2] = AdjZ;
}
示例4: IsAreaColorMousable
public static bool IsAreaColorMousable(MCvConnectedComp comp, Image<Bgr, byte> source, Image<Gray, byte> sourcemask)
{
var newRect = new Rectangle(comp.rect.Left, comp.rect.Top, comp.rect.Width, comp.rect.Height);
newRect.Inflate(-4, -4);
var mask = sourcemask.SmoothGaussian(7).Dilate(7).Erode(7).Copy();
var oldRoi = source.ROI;
var oldMaskRoi = mask.ROI;
source.ROI = newRect;
mask.ROI = newRect;
var hlscolor = source.Convert<Hls, byte>().GetAverage(mask);
var rgbcolor = source.GetAverage(mask);
using (var file = new System.IO.StreamWriter("output.html", true))
{
file.Write(
"<p><div style=\"background-color: #{3:X2}{4:X2}{5:X2}; width: 24px; height: 24px; float: left;\"></div>{0}, {1}, {2}</p>",
hlscolor.Hue, hlscolor.Lightness, hlscolor.Satuation, (int) rgbcolor.Red, (int) rgbcolor.Green, (int) rgbcolor.Blue);
}
//mask.Convert<Bgr, byte>().Copy(source, mask);
source.ROI = oldRoi;
mask.ROI = oldMaskRoi;
//source.Draw(comp.rect, rgbcolor, -1);
return hlscolor.Lightness > 102 && hlscolor.Hue < 160 && hlscolor.Satuation < 80;
}
示例5: GrayColorSubstraction
//simple background substraction with gray image
private Image<Gray, byte> GrayColorSubstraction(Image<Gray,byte> bkImg, Image<Gray,byte> frame)
{
Gray gray = frame.GetAverage(null);
Image<Gray, byte> dif = frame.AbsDiff(bkImg);
Image<Gray,byte> threshold = dif.ThresholdBinary(gray, new Gray(255));
return threshold;
}
示例6: detectPolysFromContures
/// <summary>
/// Method detects polys from contoures, claculates poly's convex hull and triangulates it.
/// </summary>
/// <param name="refImg">Image</param>
/// <param name="maxVertices">Max. vertices in poly</param>
/// <param name="minArea">Minimal area for poly</param>
/// <param name="maxArea">Max. area for poly</param>
/// <param name="threshold">Threshold for segmentation</param>
/// <param name="imageBox">Imagebox (for dumping a result)</param>
/// <returns></returns>
public List<PolyFromTris> detectPolysFromContures(Image<Bgr, Byte> refImg, int maxVertices, double minArea, double maxArea, float threshold, bool filter, int dilate, bool back, ref ImageBox imageBox)
{
// Lists, for storing data
List<Point[]> polys = new List<Point[]>(); // Polys list
List<Point[]> chull = new List<Point[]>(); // CONV HULL
avgClrs = new List<Bgr>();
List<PolyFromTris> polysTriang = new List<PolyFromTris>();
try
{
Bgr backc = new Bgr(threshold, threshold, threshold);
if (back)
{
Image<Gray, Byte> maskImg = refImg.Convert<Gray, Byte>().PyrDown().PyrUp().ThresholdBinaryInv(new Gray(128.0f), new Gray(255.0f));
backc = refImg.GetAverage(maskImg);
}
// Image<Bgr, Byte> clrSeg = refImg.ThresholdBinary (back, new Bgr(120.0f, 120.0f, 120.0f));
// imageBox.Image = clrSeg;
// Canny
Image<Bgr, Byte> cannyEdges = refImg.PyrUp().PyrDown().Canny(backc, new Bgr(120.0f, 120.0f, 120.0f));
cannyEdges = cannyEdges.Dilate(dilate); // To stress borders, improves contoures detection
// Conture detection & Triangulation
using (MemStorage shramba = new MemStorage())
for (Contour<Point> konture = cannyEdges.Convert<Gray, Byte>().FindContours(Emgu.CV.CvEnum.CHAIN_APPROX_METHOD.CV_CHAIN_APPROX_TC89_L1, Emgu.CV.CvEnum.RETR_TYPE.CV_RETR_LIST, new MemStorage()); konture != null; konture = konture.HNext)
{
// Contour<Point> trenutna = konture.ApproxPoly(konture.Perimeter * 0.005, shramba);
Seq<Point> convexHull = konture.ApproxPoly(konture.Perimeter * 0.005, shramba).GetConvexHull(Emgu.CV.CvEnum.ORIENTATION.CV_CLOCKWISE); //konture.GetConvexHull(Emgu.CV.CvEnum.ORIENTATION.CV_CLOCKWISE);
// Calculate max. nad min. area of valid polys (holds)
float min = 0.0f, max = 0.0f, perim = 0.0f;
calcMinMaxArea(refImg, ref min, ref max, ref perim);
// if (konture.Area > minArea && konture.Area < maxArea && trenutna.Total < maxVertices)
if ( (convexHull.Area > min && convexHull.Area < max && convexHull.Perimeter < perim && convexHull.Total < maxVertices) || !filter)
{
// if ((convexHull.Area / convexHull.Perimeter) >5.5)
// {
Point[] conHull = convexHull.ToArray(); //Array.ConvertAll(convexHull.ToArray(), new Converter<Point, PointF>(PointToPointF));
chull.Add(conHull);
polysTriang.Add( triangulator.triangulatePoly(convexHull, 4, refImg.Width, refImg.Height));
avgClrs.Add(calcPolyBgrAvrege(refImg, convexHull.BoundingRectangle));
// Draw detected holds and triangulation
imageBox.Image = drawPolys(refImg, chull, Color.DarkRed);
triangulator.drawTris(refImg, polysTriang[polysTriang.Count - 1].tris, ref imageBox);
// }
}
}
}
catch (NullReferenceException)
{
MessageBox.Show("Error, please, input an image.");
}
// Return triangulated polys
return polysTriang;
}
示例7: GetBackproject
private Image<Gray, Byte> GetBackproject(Image<Gray, Byte> hue, DenseHistogram _hist,Image<Gray,Byte> mask,Rectangle hide)
{
Image<Gray, Byte> backproject = new Image<Gray, byte>(hue.Width, hue.Height);
var imgs = new IntPtr[1] { hue };
Emgu.CV.CvInvoke.cvCalcBackProject(imgs, backproject, _hist);
Emgu.CV.CvInvoke.cvAnd(backproject, mask, backproject, IntPtr.Zero);
if (th_check)
{
backproject.ROI = face_rect;
if (backproject.GetAverage().Intensity < backproj_threshold/2)
{
isTracked = false;
}
th_check = false;
Emgu.CV.CvInvoke.cvResetImageROI(backproject);
}
hide.Height += 50;
Emgu.CV.CvInvoke.cvSetImageROI(backproject, hide);
try
{
Emgu.CV.CvInvoke.cvZero(backproject);
}
catch { }
Emgu.CV.CvInvoke.cvResetImageROI(backproject);
return backproject;
}
示例8: Calculate
public short Calculate(string imageFilePath, Polygon polygon, Media.PointCollection pointCollection)
{
// Maskiertes Bild laden
// Drawing.Bitmap maskedBitmap = GetMaskedBitmap(imageFilePath, pointCollection);
Image<Bgr, byte> cvImage = new Image<Bgr, byte>(imageFilePath);
// Maske generieren aus Polygon
Mat matMask = new Mat(new Drawing.Size(cvImage.Cols, cvImage.Rows), DepthType.Cv8U, 3);
// Polygone skalieren und generieren
List<Point> scaledPoints = GetScaledPoints(pointCollection, cvImage.Rows, cvImage.Cols);
List<Drawing.Point> scaledDrawingPoints = GetPolygonPoints(scaledPoints, cvImage.Rows, cvImage.Cols);
// Polygon weiss zeichnen
using (VectorOfPoint vPoint = new VectorOfPoint(scaledDrawingPoints.ToArray()))
using (VectorOfVectorOfPoint vvPoint = new VectorOfVectorOfPoint(vPoint))
{
CvInvoke.FillPoly(matMask, vvPoint, new Bgr(255, 255, 255).MCvScalar);
}
Image<Gray, byte> imageMask = new Image<Gray, byte>(matMask.Bitmap);
// Durchschnittsfarbe rechnen mit Maske
Bgr result = cvImage.GetAverage(imageMask);
// Vergleichen mit Referenzbildern
Bgr snow = JsonConvert.DeserializeObject<Bgr>(polygon.BgrSnow);
Bgr normal = JsonConvert.DeserializeObject<Bgr>(polygon.BgrNormal);
double resultSnow = Math.Abs(snow.Blue - result.Blue) + Math.Abs(snow.Green - result.Green) + Math.Abs(snow.Red - result.Red);
double resultNormal = Math.Abs(normal.Blue - result.Blue) + Math.Abs(normal.Green - result.Green) + Math.Abs(normal.Red - result.Red);
if (Math.Abs(resultSnow - resultNormal) < 10)
{
return 0;
}
else if (resultSnow < resultNormal)
{
return 1;
}
else
{
return -1;
}
}
示例9: CalculateAverageBrightessForArea
public void CalculateAverageBrightessForArea(string reference0, string reference1, StrassenbilderMetaDataContext dataContext)
{
// Image-Meta-Daten laden
string name0 = Path.GetFileNameWithoutExtension(reference0);
string name1 = Path.GetFileNameWithoutExtension(reference1);
Image image0 = dataContext.Images.Where(i => i.Name == name0).FirstOrDefault();
Image image1 = dataContext.Images.Where(i => i.Name == name1).FirstOrDefault();
// Polygone Laden
IEnumerable<Polygon> polygons = dataContext.Polygons.Where(p => p.CameraName == image0.Place);
// Pro Maske anwenden
foreach (var polygon in polygons)
{
IList<Point> polygonPoints = JsonConvert.DeserializeObject<Media.PointCollection>(polygon.PolygonPointCollection);
// Maskiertes Bild laden
Drawing.Bitmap bitmap0 = GetMaskedBitmap(reference0, polygonPoints);
Drawing.Bitmap bitmap1 = GetMaskedBitmap(reference1, polygonPoints);
Image<Bgr, byte> cvImage0 = new Image<Bgr, byte>(bitmap0);
Image<Bgr, byte> cvImage1 = new Image<Bgr, byte>(bitmap1);
// Maske generieren aus Polygon
Mat matMask = new Mat(new Drawing.Size(cvImage0.Cols, cvImage0.Rows), DepthType.Cv8U, 3);
// Polygone skalieren und generieren
List<Point> scaledPoints = GetScaledPoints(polygonPoints, cvImage0.Rows, cvImage0.Cols);
List<Drawing.Point> scaledDrawingPoints = GetPolygonPoints(scaledPoints, cvImage0.Rows, cvImage0.Cols);
// Polygon weiss zeichnen
using (VectorOfPoint vPoint = new VectorOfPoint(scaledDrawingPoints.ToArray()))
using (VectorOfVectorOfPoint vvPoint = new VectorOfVectorOfPoint(vPoint))
{
CvInvoke.FillPoly(matMask, vvPoint, new Bgr(255, 255, 255).MCvScalar);
}
Image<Gray, byte> imageMask = new Image<Gray, byte>(matMask.Bitmap);
// Durchschnittsfarbe rechnen mit Maske
Bgr result0 = cvImage0.GetAverage(imageMask);
Bgr result1 = cvImage1.GetAverage(imageMask);
// Resultat abspeichern
polygon.BgrSnow = JsonConvert.SerializeObject(result0);
polygon.BgrNormal = JsonConvert.SerializeObject(result1);
dataContext.SubmitChanges();
}
}