From 3ce48f6dbeb537e252edb0d62c88a28796e36674 Mon Sep 17 00:00:00 2001
From: SWK <sungwk82@diteam.co.kr>
Date: 월, 26 12월 2022 15:04:42 +0900
Subject: [PATCH] ongoing60 #4403 CF AOI Review TACT 지연 개선 1. 신호 출력 방식 재개선  - 유지 시간이 없는 신호는 바로 출력 진행하도록 변경 2. 불필요 Delay 제거 및 시퀀스 변경  - 얼라인 측정 종료 처리 간 제어 신호 먼저 출력 후 카메라 Stop으로 변경  - 물류 정보 읽기 처리 후 1000ms Delay 삭제  - 얼라인 측정 시작(카메라 Live Start) 후 Delay 300ms -> 100ms(이미지 들어오는 시간 확보 필요)  - ReadRawFile 처리 시작 전 500ms Delay 삭제  - Path Scheduling 완료 후 Review Ready 신호 출력 전 1000ms Delay 삭제 3. 버그 수정  - 이미지 저장 경로 생성 간 예외 처리 부분 버그 수정 4. 로그 시간 출력 불합리 개선  - 로그 시간이 파일 출력 시점으로 작성되어 로그 스래드 지연 시 시간이 맞지 않는 불합리 있음  - 로그 시간은 로그 발생 시점에 시간 저장, 해당 시간 이용하여 파일에 기록하도록 변경

---
 ReviewHistory/include/akGraph/akMemDC.h |   90 +++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 90 insertions(+), 0 deletions(-)

diff --git a/ReviewHistory/include/akGraph/akMemDC.h b/ReviewHistory/include/akGraph/akMemDC.h
new file mode 100644
index 0000000..ff23d8e
--- /dev/null
+++ b/ReviewHistory/include/akGraph/akMemDC.h
@@ -0,0 +1,90 @@
+
+#pragma once
+
+
+class CakMemDC : public CDC
+{
+public:
+
+	CakMemDC(CDC* pDC, CRect rectDC) : CDC()
+	{
+		ASSERT(pDC != NULL);
+
+		m_pDC = pDC;
+		m_pOldBitmap = NULL;
+		m_bMemDC = false;
+		m_hDC = NULL;
+		if(pDC == NULL)
+		{
+			CreateCompatibleDC(pDC);
+			return;
+		}
+
+#ifndef WCE_NO_PRINTING
+		m_bMemDC = !pDC->IsPrinting();
+#else
+		m_bMemDC = FALSE;
+#endif
+
+		if (m_bMemDC)    
+		{
+			//pDC->GetClipBox(&m_rect);
+			m_rect = rectDC;
+			CreateCompatibleDC(pDC);
+			m_bitmap.CreateCompatibleBitmap(pDC, m_rect.Width(), m_rect.Height());
+			m_pOldBitmap = SelectObject(&m_bitmap);
+#ifndef _WIN32_WCE
+			//SetWindowOrg(m_rect.left, m_rect.top);
+			SetWindowOrg(0,0);
+#endif
+			FillSolidRect(m_rect, pDC->GetBkColor());
+		}
+		else   
+		{
+#ifndef WCE_NO_PRINTING
+			m_bPrinting = pDC->m_bPrinting;
+#endif
+			m_hDC       = pDC->m_hDC;
+			m_hAttribDC = pDC->m_hAttribDC;
+		}
+
+	}
+
+	virtual ~CakMemDC()
+	{
+		if (m_bMemDC)
+		{
+			m_pDC->BitBlt(m_rect.left, m_rect.top, m_rect.right, m_rect.bottom,
+				this, m_rect.left, m_rect.top, SRCCOPY);
+			
+
+			SelectObject(m_pOldBitmap);
+			//DeleteDC(); 
+			//m_bitmap.DeleteObject();
+			
+		}
+		else
+		{
+			m_hDC = m_hAttribDC = NULL;
+		}
+	}
+
+	CakMemDC* operator->()
+	{
+		return this;
+	}
+
+	operator CakMemDC*()
+	{
+		return this;
+	}
+
+private:
+	CBitmap  m_bitmap;      // Offscreen bitmap
+	CBitmap* m_pOldBitmap;  // bitmap originally found in CakMemDC
+	CDC*     m_pDC;         // Saves CDC passed in constructor
+	BOOL     m_bMemDC;      // TRUE if CDC really is a Memory DC.
+public:
+	CRect    m_rect;        // Rectangle of drawing area.
+}
+;

--
Gitblit v1.9.3