void formModel_ReadFormImage(object sender, ReadFormImageEventArgs e) { FormModel formMode = (FormModel)sender; FormDefinitionFile fd = (FormDefinitionFile)formMode.UserTag; e.FormImage = FormImage.FromHdib(fd.TemplateImages[0].Hdib, true, formFix); }
private Boolean LoadImage(String ImageName) { if (!File.Exists(ImageName)) { MessageBox.Show("Image Doesn't exist : " + ImageName); return(false); } //Zonal 2 try { currentLayer.Elements.Clear(); InputImg.Image = ImageX.FromFile(imagXpress1, ImageName); Processor prc = new PegasusImaging.WinForms.ImagXpress9.Processor(imagXpress1, InputImg.Image); if (InputImg.Image.ImageXData.BitsPerPixel != 1) { prc.ColorDepth(1, PaletteType.Optimized, DitherType.NoDither); //InputImg.Image = prc.Image; } // prc.Rotate(270); prc.DocumentDeskew(0, 10, Color.White, true, 99); prc.DocumentDespeckle(10, 10); InputImg.Image = prc.Image.Copy(); //InputImg.Image = this.PreprocessImage(this.InputImg.Image); frmFilledImage = FormImage.FromHdib(InputImg.Image.ToHdib(false), true, formFix1); OutputImg.Image = ImageX.FromHdib(imagXpress1, frmFilledImage.ToHdib(false), true); //InputImg.Image.Copy(); OnPictureChanged(ICRType.Image); //MessageBox.Show("Load Image"); } catch (Exception ex) { MessageBox.Show("Error: " + ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); return(false); } return(true); }
private Boolean LoadTemplate(String TemplateImageName) { String TemplateName = TemplateImageName.Substring(TemplateImageName.LastIndexOf("\\") + 1).ToUpper().Replace(".TIF", ""); if (!File.Exists(TemplateImageName)) { MessageBox.Show("This Template Doecn't Exist!! : " + TemplateImageName); } // Zonal try { InputImg.Image = ImageX.FromFile(imagXpress1, this.TemplateFile); /* * Processor prc = new PegasusImaging.WinForms.ImagXpress9.Processor(imagXpress1, InputImg.Image); * prc.Rotate(270); * InputImg.Image = prc.Image.Copy(); */ InputImg.Image = PreprocessImage(InputImg.Image); frmTemplateImage = FormImage.FromHdib(InputImg.Image.ToHdib(false), true, formFix1); OutputImg.Image = ImageX.FromHdib(imagXpress1, frmTemplateImage.ToHdib(false), true); //InputImg.Image.Copy(); OnPictureChanged(ICRType.Template); // MessageBox.Show("Load Template"); } catch (Exception ex) { MessageBox.Show("Error: " + ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); IsTemplateLoaded = false; return(false); } IsTemplateLoaded = true; 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; }