private bool RegisterImage() { //Zonal 2 try { regProcessor = new RegistrationProcessor(formFix1); regResult = regProcessor.RegisterToImage(frmFilledImage, frmTemplateImage); if (regResult.State == RegistrationState.Failure) { MessageBox.Show(regResult.State.ToString()); } frmAlignedImage = regResult.AlignImage(frmFilledImage); /* * ImageX FieldImage = new ImageX(imagXpress1); * DropOutProcessor oDrop = new DropOutProcessor(formFix1); * oDrop.DropOutMethod = DropOutMethod.DropOut; * //oDrop.Area = new Rectangle(0, 0, Field.Width, Field.Height); * DropOutResult oDropOutResult = oDrop.CreateImageOfField(frmFilledImage, regResult); */ //InputImg.Image = ImageX.FromHdib(imagXpress1, oDropOutResult.Image.ToHdib(true), true); //ImageX.FromHdib(imagXpress1, frmAlignedImage.ToHdib(false), true); InputImg.Image = ImageX.FromHdib(imagXpress1, frmAlignedImage.ToHdib(false), true); // oDrop.Dispose(); OutputImg.Image = InputImg.Image.Copy(); OnPictureChanged(ICRType.ImageMatched); // MessageBox.Show("Aligned Image"); } catch (Exception ex) { MessageBox.Show("Error: " + ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); } return(true); }
public void Test() { #region Load Template try { InputImg.Image = ImageX.FromFile(imagXpress1, @"I:\Templates\ICRTemplate.tif"); frmTemplateImage = FormImage.FromHdib(InputImg.Image.ToHdib(false), true, formFix1); InputImg.Image = ImageX.FromHdib(imagXpress1, (System.IntPtr) 0, true); OutputImg.Image = ImageX.FromHdib(imagXpress1, (System.IntPtr) 0, true); } catch (Exception ex) { MessageBox.Show("Error: " + ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); } #endregion #region Load Image String ImageName = @"I:\Images\Order-0000000153.TIFF"; try { InputImg.Image = ImageX.FromFile(imagXpress1, ImageName); frmFilledImage = FormImage.FromHdib(InputImg.Image.ToHdib(false), true, formFix1); OutputImg.Image = ImageX.FromHdib(imagXpress1, (System.IntPtr) 0, true); } catch (Exception ex) { MessageBox.Show("Error: " + ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); } //it's all looking good, so we load our image into an ImageX object //imageXView1.Image = ImageX.FromFile(imagXpress1, strFileName); Processor prc = new Processor(imagXpress1, InputImg.Image); if (InputImg.Image.ImageXData.BitsPerPixel != 1) { prc.ColorDepth(1, PaletteType.Optimized, DitherType.NoDither); InputImg.Image = prc.Image; } #endregion #region Register Image try { regProcessor = new RegistrationProcessor(formFix1); regResult = regProcessor.RegisterToImage(frmFilledImage, frmTemplateImage); frmAlignedImage = regResult.AlignImage(frmFilledImage); InputImg.Image = ImageX.FromHdib(imagXpress1, frmAlignedImage.ToHdib(false), true); OutputImg.Image = InputImg.Image.Copy(); OnPictureChanged(ICRType.ImageMatched); } catch (Exception ex) { MessageBox.Show("Error: " + ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); } #endregion #region Preprocessing Image Processor proc = new Processor(imagXpress1, InputImg.Image); if (InputImg.Image.ImageXData.BitsPerPixel != 0) { proc.ColorDepth(1, 0, 0); } scanFix1.FromHdib(InputImg.Image.ToHdib(false)); //Remove Lines LineRemovalOptions LineOpts = new LineRemovalOptions(); LineOpts.MinimumLength = 20; scanFix1.RemoveLines(LineOpts); //Despeckle DespeckleOptions DespeckOpts = new DespeckleOptions(); DespeckOpts.SpeckWidth = 10; DespeckOpts.SpeckHeight = 14; scanFix1.Despeckle(DespeckOpts); //Deskew scanFix1.Deskew(); //Comb options /* * comb = new PegasusImaging.WinForms.ScanFix5.CombRemovalOptions(); * * comb.Area = new System.Drawing.Rectangle(AreaXBar.Value, AreaYBar.Value, AreaWBar.Value, AreaHBar.Value); * comb.CombHeight = CombHBar.Value; * comb.CombSpacing = SpaceBar.Value; * comb.HorizontalLineThickness = HBar.Value; * comb.VerticalLineThickness = VBar.Value; * comb.MinimumCombLength = LengthBar.Value; * comb.MinimumConfidence = ConfidenceBar.Value; * * scanFix1.RemoveCombs(comb); */ //Smooth Options //scanFix1.SmoothObjects(SmoothBar.Value); //Blob Options /* * blob = new PegasusImaging.WinForms.ScanFix5.BlobRemovalOptions(); * * blob.Area = new System.Drawing.Rectangle(BlobAreaXBar.Value, BlobAreaYBar.Value, AreaWidthBar.Value, AreaHeightBar.Value); * blob.MaximumPixelCount = MaxCountBar.Value; * blob.MinimumPixelCount = MinCountBar.Value; * blob.MinimumDensity = DensityBar.Value; * * scanFix1.RemoveBlobs(blob); */ //Remove Dot Shading /* * dot = new PegasusImaging.WinForms.ScanFix5.DotShadingRemovalOptions(); * * dot.DensityAdjustment = DotDensityBar.Value; * dot.MaximumDotSize = DotSizeBar.Value; * dot.HorizontalSizeAdjustment = HAdjBar.Value; * dot.VerticalSizeAdjustment = VAdjBar.Value; * dot.MinimumAreaHeight = DotHBar.Value; * dot.MinimumAreaWidth = DotWBar.Value; * * scanFix1.RemoveDotShading(dot); */ //Remove Border Options /* * border = new PegasusImaging.WinForms.ScanFix5.BorderRemovalOptions(); * * border.BorderSpeckSize = BSpeckBar.Value; * border.CropBorder = chkcrop.Checked; * border.DeskewBorder = chkdeskew.Checked; * border.MaximumPageHeight = MaxHeightBar.Value; * border.MaximumPageWidth = MaxWidthBar.Value; * border.MinimumConfidence = MinConBar.Value; * border.MinimumPageHeight = MinHeightBar.Value; * border.MinimumPageWidth = SpeckWidthBar.Value; * border.PageSpeckSize = PSpeckBar.Value; * border.Quality = SpeckQualityBar.Value; * border.ReplaceBorder = chkreplace.Checked; * * if (true) * { * border.PadColor = System.Drawing.Color.FromArgb(0, 0, 0); * } * else * { * border.PadColor = System.Drawing.Color.FromArgb(255, 255, 255); * } * scanFix1.RemoveBorder(border); */ #endregion #region Read Fields InputImg.Image = ImageX.FromHdib(imagXpress1, scanFix1.ToHdib(false)); // Set area and analyze field DIB SmartZone2.Reader.CharacterSet = CharacterSet.AllAlphas; Rectangle currentArea = new Rectangle(85, 170, 603, 79); SmartZone2.Reader.Area = currentArea; myTextBlockRes = SmartZone2.Reader.AnalyzeField(InputImg.Image.ToHdib(false)); if (myTextBlockRes.NumberTextLines > 0) { Boolean hasResult = true; LineResult = myTextBlockRes.TextLine(0); // showBlockResult(); // showLineResult(0); // showCharacterResult(0); } else { Boolean hasResult = false; } MessageBox.Show(myTextBlockRes.TextLine(0).Text); #endregion return; }