本文整理汇总了C#中Image.Equals方法的典型用法代码示例。如果您正苦于以下问题:C# Image.Equals方法的具体用法?C# Image.Equals怎么用?C# Image.Equals使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Image
的用法示例。
在下文中一共展示了Image.Equals方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Save
public static void Save(Image image, int maxWidth, int maxHeight, int quality, string filePath)
{
if (image != null || !image.Equals(0))
{
int originalWidth = image.Width;
int originalHeight = image.Height;
float ratioX = maxWidth / (float)originalWidth;
float ratioY = maxHeight / (float)originalHeight;
float ratio = Math.Min(ratioX, ratioY);
int newWidth = (int)(originalWidth * ratio);
int newHeight = (int)(originalHeight * ratio);
newImage = new Bitmap(newWidth, newHeight, PixelFormat.Format24bppRgb);
using (Graphics graphics = Graphics.FromImage(newImage))
{
graphics.CompositingQuality = CompositingQuality.HighQuality;
graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;
graphics.SmoothingMode = SmoothingMode.HighQuality;
graphics.DrawImage(image, 0, 0, newWidth, newHeight);
}
ImageCodecInfo imageCodecInfo = GetEncoderInfo(ImageFormat.Jpeg);
System.Drawing.Imaging.Encoder encoder = System.Drawing.Imaging.Encoder.Quality;
encoderParameters = new EncoderParameters(1);
EncoderParameter encoderParameter = new EncoderParameter(encoder, quality);
encoderParameters.Param[0] = encoderParameter;
newImage.Save(filePath, imageCodecInfo, encoderParameters);
}
}
示例2: GetImage
internal static Image GetImage(Uri imageURL, Image image, out byte[] imageBytes)
{
imageBytes = ConvertImageToBytes(Resources.missingPicture);
if (image.Equals(Resources.missingPicture))
{
imageBytes = GetBytesFromWeb(imageURL);
return ConvertBytesToImage(imageBytes);
}
return image;
}
示例3: ImageToBytes
/// <summary>
/// 圖片轉換成Byte[]
/// </summary>
/// <param name="img">要轉換的圖標</param>
/// <param name="format">圖片的寫入格式</param>
/// <returns></returns>
public static byte[] ImageToBytes(Image img, System.Drawing.Imaging.ImageFormat format)
{
byte[] bt = null;
if (!img.Equals(null))
{
using (MemoryStream mostream = new MemoryStream())
{
Bitmap bmp = new Bitmap(img);
bmp.Save(mostream, format);
bt = new byte[mostream.Length];
mostream.Position = 0;
mostream.Read(bt, 0, Convert.ToInt32(bt.Length));
}
}
return bt;
}
示例4: PerformanceComparison
public void PerformanceComparison()
{
Image<Gray, Byte> img1 = new Image<Gray, byte>(1920, 1080);
Image<Gray, Byte> img2 = new Image<Gray, byte>(img1.Size);
img1.SetRandUniform(new MCvScalar(0), new MCvScalar(50));
img2.SetRandUniform(new MCvScalar(0), new MCvScalar(50));
Stopwatch w = Stopwatch.StartNew();
Image<Gray, Byte> sum1 = img1 + img2;
w.Stop();
Trace.WriteLine(String.Format("OpenCV Time:\t\t\t\t\t\t{0} ms", w.ElapsedMilliseconds));
w.Reset(); w.Start();
Image<Gray, Byte> sum2 = new Image<Gray, byte>(img1.Size);
Byte[, ,] data1 = img1.Data;
Byte[, ,] data2 = img2.Data;
Byte[, ,] dataSum = sum2.Data;
int rows = img1.Rows;
int cols = img1.Cols;
for (int i = 0; i < rows; i++)
for (int j = 0; j < cols; j++)
dataSum[i, j, 0] = (Byte) (data1[i, j, 0] + data2[i, j, 0]);
w.Stop();
Trace.WriteLine(String.Format(".NET array manipulation Time:\t\t{0} ms", w.ElapsedMilliseconds));
Assert.IsTrue(sum2.Equals(sum1));
w.Reset(); w.Start();
Func<Byte, Byte, Byte> convertor = delegate(Byte b1, Byte b2) { return (Byte)(b1 + b2); };
Image<Gray, Byte> sum3 = img1.Convert<Byte, Byte>(img2, convertor);
w.Stop();
Trace.WriteLine(String.Format("Generic image manipulation Time:\t{0} ms", w.ElapsedMilliseconds));
Assert.IsTrue(sum3.Equals(sum1));
}
示例5: TestBitmapConstructor
public void TestBitmapConstructor()
{
using (Bitmap bmp0 = new Bitmap(1200, 1080, System.Drawing.Imaging.PixelFormat.Format32bppRgb))
using (Graphics g = Graphics.FromImage(bmp0))
{
g.Clear(Color.Blue);
Stopwatch watch = Stopwatch.StartNew();
Image<Bgr, Byte> image0 = new Image<Bgr, byte>(bmp0);
watch.Stop();
Trace.WriteLine(String.Format("Convertsion Time: {0} milliseconds", watch.ElapsedMilliseconds));
Image<Bgr, Byte> imageCmp0 = new Image<Bgr, byte>(image0.Size);
imageCmp0.SetValue(new Bgr(255, 0, 0));
Assert.IsTrue(image0.Equals(imageCmp0));
}
#region test byte images
Image<Bgr, Byte> image1 = new Image<Bgr, byte>(201, 401);
image1.SetRandUniform(new MCvScalar(), new MCvScalar(255.0, 255.0, 255.0));
Assert.IsTrue(image1.Equals(new Image<Bgr, byte>(image1.ToBitmap())));
Assert.IsTrue(image1.Equals(new Image<Bgr, byte>(image1.Bitmap)));
Image<Gray, Byte> image3 = new Image<Gray, byte>(11, 7);
image3.SetRandUniform(new MCvScalar(), new MCvScalar(255.0, 255.0, 255.0));
Assert.IsTrue(image3.Equals(new Image<Gray, byte>(image3.ToBitmap())));
Assert.IsTrue(image3.Equals(new Image<Gray, byte>(image3.Bitmap)));
Image<Bgra, Byte> image5 = new Image<Bgra, byte>(201, 401);
image5.SetRandUniform(new MCvScalar(), new MCvScalar(255.0, 255.0, 255.0, 255.0));
Assert.IsTrue(image5.Equals(new Image<Bgra, byte>(image5.ToBitmap())));
Assert.IsTrue(image5.Equals(new Image<Bgra, byte>(image5.Bitmap)));
#endregion
#region test single images
Image<Bgr, Single> image7 = new Image<Bgr, Single>(201, 401);
image7.SetRandUniform(new MCvScalar(), new MCvScalar(255.0, 255.0, 255.0));
Bitmap bmp = image7.ToBitmap();
#endregion
}
示例6: TestBitmapConstructor
public void TestBitmapConstructor()
{
#region test byte images
Image<Bgr, Byte> image1 = new Image<Bgr, byte>(201, 401);
image1.SetRandUniform(new MCvScalar(), new MCvScalar(255.0, 255.0, 255.0));
Assert.IsTrue(image1.Equals(new Image<Bgr, byte>(image1.ToBitmap())));
Assert.IsTrue(image1.Equals(new Image<Bgr, byte>(image1.Bitmap)));
Image<Gray, Byte> image3 = new Image<Gray, byte>(11, 7);
image3.SetRandUniform(new MCvScalar(), new MCvScalar(255.0, 255.0, 255.0));
Assert.IsTrue(image3.Equals(new Image<Gray, byte>(image3.ToBitmap())));
Assert.IsTrue(image3.Equals(new Image<Gray, byte>(image3.Bitmap)));
Image<Bgra, Byte> image5 = new Image<Bgra, byte>(201, 401);
image5.SetRandUniform(new MCvScalar(), new MCvScalar(255.0, 255.0, 255.0, 255.0));
Assert.IsTrue(image5.Equals(new Image<Bgra, byte>(image5.ToBitmap())));
Assert.IsTrue(image5.Equals(new Image<Bgra, byte>(image5.Bitmap)));
#endregion
#region test single images
Image<Bgr, Single> image7 = new Image<Bgr, Single>(201, 401);
image7.SetRandUniform(new MCvScalar(), new MCvScalar(255.0, 255.0, 255.0));
Bitmap bmp = image7.ToBitmap();
#endregion
}
示例7: TestGrayscaleBitmapConstructor
public void TestGrayscaleBitmapConstructor()
{
Image<Bgra, Byte> img = new Image<Bgra, byte>(320, 240);
img.SetRandUniform(new MCvScalar(), new MCvScalar(255, 255, 255, 255));
img.Save("tmp.png");
Stopwatch stopwatch = Stopwatch.StartNew();
Image<Bgra, Byte> img2 = new Image<Bgra, byte>("tmp.png");
stopwatch.Stop();
Trace.WriteLine(string.Format("Time: {0} milliseconds", stopwatch.ElapsedMilliseconds));
Assert.IsTrue(img.Equals(img2));
stopwatch.Reset(); stopwatch.Start();
using (Bitmap bmp = new Bitmap("tmp.png"))
using (Image bmpImage = Bitmap.FromFile("tmp.png"))
{
Assert.AreEqual(System.Drawing.Imaging.PixelFormat.Format32bppArgb, bmpImage.PixelFormat);
Image<Gray, Byte> img3 = new Image<Gray, byte>(bmp);
stopwatch.Stop();
Trace.WriteLine(string.Format("Time: {0} milliseconds", stopwatch.ElapsedMilliseconds));
Image<Gray, Byte> diff = img.Convert<Gray, Byte>().AbsDiff(img3);
Assert.AreEqual(0, CvInvoke.cvCountNonZero(diff));
Assert.IsTrue(img.Convert<Gray, Byte>().Equals(img3));
}
}
示例8: GetBytesByImage
//将Image转化为二进制数据
private byte[] GetBytesByImage(Image img)
{
byte[] bytes = null;
if (!img.Equals(null))
{
Bitmap bmp = new Bitmap(img);
MemoryStream mostream = new MemoryStream();
bmp.Save(mostream, System.Drawing.Imaging.ImageFormat.Jpeg); //将图像以指定的格式存入缓存内存流
bytes = new byte[mostream.Length];
mostream.Position = 0; //设置留的初始位置
mostream.Read(bytes, 0, Convert.ToInt32(bytes.Length));
}
return bytes;
}
示例9: button2_Click
private void button2_Click(object sender, EventArgs e)
{
string dateTemp = dateTimePicker1.Value.ToString("s");
if (mydb.checkUserProfile(textBox1.Text, textBox2.Text))
{
mydb.InsertUserData(textBox1.Text, textBox2.Text, dateTemp, comboBox1.Text, comboBox2.Text);
}
newid = mydb.getUserId(textBox1.Text, textBox2.Text, dateTemp, comboBox1.Text);
if (newid != 0)
{
Image<Gray, byte> darkimage = new Image<Gray, byte>(ROIwidth, ROIheight);
Image<Gray, byte> cropimage;
Image<Gray, byte> plainimage = new Image<Gray, byte>(ROIwidth, ROIheight);
for (int i = 1;i<71 ;i++ )
{
//cropimage = new Image<Gray, byte>(@"E:\ImageTestSet2\" + textBox1.Text + i + ".jpg");
cropimage = new Image<Gray, byte>(@"E:\ImageTestSet2\Perapat" + i + ".jpg");
if (!cropimage.Equals(darkimage))
{
plainimage = cropimage.Copy();
Point[] pL = new Point[3];
Point[] pR = new Point[3];
int y0 = 105;
int y1 = 174;
int x0 = 0;
int x1 = 34;
int x2 = 105;
int x3 = 139;
pL[0] = new Point(x0, y0);
pL[1] = new Point(x0, y1);
pL[2] = new Point(x1, y1);
pR[0] = new Point(x3, y0);
pR[1] = new Point(x3, y1);
pR[2] = new Point(x2, y1);
cropimage.FillConvexPoly(pL, new Gray(128));
cropimage.FillConvexPoly(pR, new Gray(128));
//cropimage = cropimage.SmoothMedian(3);
imageBox7.Image = cropimage; //line 2
cropimage.Save(folderPath + tempPath);
string dbPath = (folderPath + tempPath).Replace("\\", "/");
plainimage.Save(folderPath + tempPath2);
string dbPathPlain = (folderPath + tempPath2).Replace("\\", "/");
mydb.InsertImageTraining(newid, dbPathPlain, dbPath, true);
label6.ForeColor = Color.ForestGreen;
label6.Text = "Success";
//File.Delete(tempPath);
imageBox7.Image = cropimage;
}
else
{
label6.ForeColor = Color.Red;
label6.Text = "Fail";
}
}
//eigenRecog.reloadData();
}
}
示例10: imageMover
private void imageMover(Image racername)
{
//Eleganter: die letzte Stelle von racername, also die Nummer benutzten
if (racername.Equals(image_0))
{
mini = App._gameDaten.racersList[0].minSpeed;
maxi = App._gameDaten.racersList[0].maxSpeed;
}
else if (racername.Equals(image_1))
{
mini = App._gameDaten.racersList[1].minSpeed;
maxi = App._gameDaten.racersList[1].maxSpeed;
}
else if (racername.Equals(image_2)) {
mini = App._gameDaten.racersList[2].minSpeed;
maxi = App._gameDaten.racersList[2].maxSpeed;
}
else if (racername.Equals(image_3)) {
mini = App._gameDaten.racersList[3].minSpeed;
maxi = App._gameDaten.racersList[3].maxSpeed;
}
else if (racername.Equals(image_4)) {
mini = App._gameDaten.racersList[4].minSpeed;
maxi = App._gameDaten.racersList[4].maxSpeed;
}
//Generate Random numbers based on min and max skill values of racers
int rnd = RandomGenerator.rndGen(mini, maxi);
var rac = racername;
posX = (double)rac.GetValue(Canvas.LeftProperty) + 5 + rnd;
posFin = (double)rac.GetValue(Canvas.LeftProperty);
//Check auf: Racer im Ziel? ansonsten move racer und aktuellen racer zu liste hinzufügen
if (posFin < finishLine)
{
rac.SetValue(Canvas.LeftProperty, posX);
}
else
{
winningracers.Add(racername);
}
}
示例11: TestClone
public void TestClone()
{
if (CudaInvoke.HasCuda)
{
Image<Gray, Byte> img = new Image<Gray, byte>(300, 400);
img.SetRandUniform(new MCvScalar(0.0), new MCvScalar(255.0));
using (CudaImage<Gray, Byte> gImg1 = new CudaImage<Gray, byte>(img))
using (CudaImage<Gray, Byte> gImg2 = gImg1.Clone(null))
using (Image<Gray, Byte> img2 = gImg2.ToImage())
{
Assert.IsTrue(img.Equals(img2));
}
}
}
示例12: TestCudaFlip
public void TestCudaFlip()
{
if (CudaInvoke.HasCuda)
{
using (Image<Bgr, Byte> img1 = new Image<Bgr, byte>(1200, 640))
{
img1.SetRandUniform(new MCvScalar(0, 0, 0), new MCvScalar(255, 255, 255));
using (Image<Bgr, Byte> img1Flip = img1.Flip(CvEnum.FlipType.Horizontal | CvEnum.FlipType.Vertical))
using (CudaImage<Bgr, Byte> cudaImage = new CudaImage<Bgr, byte>(img1))
using (CudaImage<Bgr, Byte> cudaFlip = new CudaImage<Bgr,byte>(img1.Size))
{
CudaInvoke.Flip(cudaImage, cudaFlip, CvEnum.FlipType.Horizontal | CvEnum.FlipType.Vertical, null);
cudaFlip.Download(img1);
Assert.IsTrue(img1.Equals(img1Flip));
}
}
}
}
示例13: TestSplitMerge
public void TestSplitMerge()
{
if (CudaInvoke.HasCuda)
{
using (Image<Bgr, Byte> img1 = new Image<Bgr, byte>(1200, 640))
{
img1.SetRandUniform(new MCvScalar(0, 0, 0), new MCvScalar(255, 255, 255));
using (GpuMat gpuImg1 = new GpuMat(img1))
{
GpuMat[] channels = gpuImg1.Split(null);
for (int i = 0; i < channels.Length; i++)
{
Mat imgL = channels[i].ToMat();
Image<Gray, Byte> imgR = img1[i];
Assert.IsTrue(imgL.Equals(imgR.Mat), "failed split GpuMat");
}
using (GpuMat gpuImg2 = new GpuMat())
{
gpuImg2.MergeFrom(channels, null);
using (Image<Bgr, byte> img2 = new Image<Bgr, byte>(img1.Size))
{
gpuImg2.Download(img2);
Assert.IsTrue(img2.Equals(img1), "failed split and merge test");
}
}
for (int i = 0; i < channels.Length; i++)
{
channels[i].Dispose();
}
}
}
}
}
示例14: TestGpuMatAdd
public void TestGpuMatAdd()
{
if (CudaInvoke.HasCuda)
{
int repeat = 1000;
Image<Gray, Byte> img1 = new Image<Gray, byte>(1200, 640);
Image<Gray, Byte> img2 = new Image<Gray, byte>(img1.Size);
img1.SetRandUniform(new MCvScalar(0, 0, 0), new MCvScalar(255, 255, 255));
img2.SetRandUniform(new MCvScalar(0, 0, 0), new MCvScalar(255, 255, 255));
Image<Gray, Byte> cpuImgSum = new Image<Gray, byte>(img1.Size);
Stopwatch watch = Stopwatch.StartNew();
for (int i = 0; i < repeat; i++)
CvInvoke.Add(img1, img2, cpuImgSum, null, CvEnum.DepthType.Cv8U);
watch.Stop();
Trace.WriteLine(String.Format("CPU processing time: {0}ms", (double)watch.ElapsedMilliseconds / repeat));
watch.Reset(); watch.Start();
CudaImage<Gray, Byte> gpuImg1 = new CudaImage<Gray, byte>(img1);
CudaImage<Gray, Byte> gpuImg2 = new CudaImage<Gray, byte>(img2);
CudaImage<Gray, Byte> gpuImgSum = new CudaImage<Gray, byte>(gpuImg1.Size);
Stopwatch watch2 = Stopwatch.StartNew();
for (int i = 0; i < repeat; i++)
CudaInvoke.Add(gpuImg1, gpuImg2, gpuImgSum);
watch2.Stop();
Image<Gray, Byte> cpuImgSumFromGpu = gpuImgSum.ToImage();
watch.Stop();
Trace.WriteLine(String.Format("Core GPU processing time: {0}ms", (double)watch2.ElapsedMilliseconds / repeat));
//Trace.WriteLine(String.Format("Total GPU processing time: {0}ms", (double)watch.ElapsedMilliseconds/repeat));
Assert.IsTrue(cpuImgSum.Equals(cpuImgSumFromGpu));
}
}
示例15: TestBitmapSharedDataWithImage
public void TestBitmapSharedDataWithImage()
{
Image<Bgr, Byte> img = new Image<Bgr, byte>(480, 320);
Bitmap bmp = img.Bitmap;
bmp.SetPixel(0, 0, Color.Red);
Image<Bgr, Byte> img2 = new Image<Bgr, byte>(bmp);
Assert.IsTrue(img.Equals(img2));
}