diff --git a/MMVII/src/CodedTarget/CodedTarget.h b/MMVII/src/CodedTarget/CodedTarget.h index e9325bf8a6..a63657c8ca 100755 --- a/MMVII/src/CodedTarget/CodedTarget.h +++ b/MMVII/src/CodedTarget/CodedTarget.h @@ -386,7 +386,7 @@ class cFullSpecifTarget : public cMemCheck // ----------- Creation of images ----------------- /// Generate the image of one encoding - tIm OneImTarget(const cOneEncoding & aCode); + tIm OneImTarget(const cOneEncoding & aCode,bool ForTest=false); /// get the pattern for generating all image tIm ImagePattern(); diff --git a/MMVII/src/CodedTarget/cGenerateTarget.cpp b/MMVII/src/CodedTarget/cGenerateTarget.cpp index 2349f37346..33165d0597 100755 --- a/MMVII/src/CodedTarget/cGenerateTarget.cpp +++ b/MMVII/src/CodedTarget/cGenerateTarget.cpp @@ -643,7 +643,7 @@ enum class eLPT // Label Pattern Target { eBackGround, eForeGround, - eChar, + eCircleSepCar, eNumB0 // num first bit }; @@ -658,7 +658,7 @@ class cCodedTargetPatternIm tIm ImCoding() const; - tIm MakeOneImTarget(const cOneEncoding & aCode,bool doMarkC = false); + tIm MakeOneImTarget(const cOneEncoding & aCode,bool is4Test = false); private : cCodedTargetPatternIm(const cCodedTargetPatternIm &) = delete; cPt2di PDiag(tREAL8 aRhoNorm) const; @@ -720,9 +720,12 @@ cCodedTargetPatternIm::cCodedTargetPatternIm(cFullSpecifTarget & aSpec) : // structure specifying bits location std::unique_ptr aP2B (cNormPix2Bit::Alloc(aSpec)); + tREAL8 aR2Sq = Square(mRender.mRho_2_EndCode); + tREAL8 aR3Sq = Square(mRender.mRho_3_BeginCar); for (const auto & aPix : mDIC) { cPt2dr aPN = mSpec.Render().Pix2Norm(aPix); + tREAL8 aR2N = SqN2(aPN); // ============ 1 Generate the bit coding ======================= if (aP2B->PNormIsCoding(aPN)) // if point belong to bit-coding space { @@ -733,7 +736,7 @@ cCodedTargetPatternIm::cCodedTargetPatternIm(cFullSpecifTarget & aSpec) : aVCenters.at(aNumB) += ToR(aPix); // accumulate for centroid } // ============ 2 Generate the central circle ======================= - else if (SqN2(aPN) aR2Sq) && ( aR2N<=aR3Sq)) + { + mDIC.SetV(aPix,int(eLPT::eCircleSepCar)); + } } // compute and memorize the center @@ -771,7 +778,7 @@ cCodedTargetPatternIm::cCodedTargetPatternIm(cFullSpecifTarget & aSpec) : cCodedTargetPatternIm::tIm cCodedTargetPatternIm::ImCoding() const {return mImCoding;} -cCodedTargetPatternIm::tIm cCodedTargetPatternIm::MakeOneImTarget(const cOneEncoding & anEnCode,bool doMarkC) +cCodedTargetPatternIm::tIm cCodedTargetPatternIm::MakeOneImTarget(const cOneEncoding & anEnCode,bool is4Test) { // compute gray level for background & foreground int aBG_Coul = mSpec.Render().mWhiteBackGround ? 255 : 0; @@ -795,13 +802,21 @@ cCodedTargetPatternIm::tIm cCodedTargetPatternIm::MakeOneImTarget(const cOneEnco else if (aLab>=eLPT::eNumB0) { bool BitIs_1 = (aCode & (size_t(1)<<(int(aLab)-int(eLPT::eNumB0)))) != 0; - isBG = BitIs_1 != BGIs_0; + isBG = BitIs_1 != BGIs_0; } if (!isBG) { mDIT.SetV(aPix,aFG_Coul); } + +/* + if (is4Test) + { + cPt2dr aPixN = mRender.Norm2PixR(ToR( + } +*/ + } } @@ -850,15 +865,17 @@ cCodedTargetPatternIm::tIm cCodedTargetPatternIm::MakeOneImTarget(const cOneEnco for (const auto & aPixStr : aDImStr) { - if (aDImStr.GetV(aPixStr)) + bool isCar = aDImStr.GetV(aPixStr); + if (isCar || is4Test) { + int aCoul = isCar ? aFG_StrCoul : 128; cPt2di aP0 = aPOri+ToI(ToR(aPixStr)*aSzPixStr); cPt2di aP1 = aPOri+ToI(ToR(aPixStr+cPt2di(1,1))*aSzPixStr); for (const auto& aPixIm : cRect2(aP0,aP1)) { - mDIT.SetVTruncIfInside(aPixIm,aFG_StrCoul); - mDIT.SetVTruncIfInside(aP4Sym-aPixIm,aFG_StrCoul); + mDIT.SetVTruncIfInside(aPixIm,aCoul); + mDIT.SetVTruncIfInside(aP4Sym-aPixIm,aCoul); } } } @@ -870,11 +887,12 @@ cCodedTargetPatternIm::tIm cCodedTargetPatternIm::MakeOneImTarget(const cOneEnco tIm aRes = mImTarget.GaussDeZoom(mSpec.DeZoomIm()); // in debug mode, marq with one pixel the center - if (doMarkC) + if (is4Test) { for (const auto & aC : mSpec.BitsCenters()) { - aRes.DIm().SetV(ToI(aC),128); + for (const auto aP : cRect2::BoxWindow(2)) + aRes.DIm().SetV(ToI(aC)+aP,128); } } @@ -927,9 +945,10 @@ cFullSpecifTarget::tIm cFullSpecifTarget::ImagePattern() { return AllocCTPI()->ImCoding(); } -cFullSpecifTarget::tIm cFullSpecifTarget::OneImTarget(const cOneEncoding & aCode) + +cFullSpecifTarget::tIm cFullSpecifTarget::OneImTarget(const cOneEncoding & aCode,bool ForTest) { - return AllocCTPI()->MakeOneImTarget(aCode); + return AllocCTPI()->MakeOneImTarget(aCode,ForTest); } @@ -1093,6 +1112,7 @@ class cAppliGenCodedTarget : public cMMVII_Appli std::string mPatternDoImage; int mNbPixBin; std::string mNameOut; + bool mIm4Test; ///< Do we generate image for inspection (and not for printing) }; eTyCodeTarget cAppliGenCodedTarget::Type() {return mBE.Specs().mType ;} @@ -1103,7 +1123,8 @@ cAppliGenCodedTarget::cAppliGenCodedTarget(const std::vector & aVAr mPhgrPr (*this), mPerGen (10), mDoMarkC (false), - mNbPixBin (1800) + mNbPixBin (1800), + mIm4Test (false) { } @@ -1122,6 +1143,7 @@ cCollecSpecArg2007 & cAppliGenCodedTarget::ArgOpt(cCollecSpecArg2007 & anArgOpt) { return anArgOpt << AOpt2007(mPatternDoImage,"PatIm","Pattern for generating image (def no generation)") + << AOpt2007(mIm4Test,"I4T","Generate image for test/inspection, not for use",{eTA2007::HDV}) << AOpt2007(mPCT.mRadiusCenterMiniTarget,"RayMCT","Rayon \"mini\" center target (for topo)",{eTA2007::HDV}) // << AOpt2007(mPCT.mNbBit,"NbBit","Nb Bit printed",{eTA2007::HDV}) // << AOpt2007(mPCT.mWithParity,"WPar","With parity bit",{eTA2007::HDV}) @@ -1172,7 +1194,7 @@ int cAppliGenCodedTarget::Exe() { if (MatchRegex(anEncode.Name(),mPatternDoImage)) { - cCodedTargetPatternIm::tIm anIm = aFullSpec.OneImTarget(anEncode); + cCodedTargetPatternIm::tIm anIm = aFullSpec.OneImTarget(anEncode,mIm4Test); std::string aName = aFullSpec.NameOfEncode(anEncode); anIm.DIm().ToFile(aDirVisu+aName);