From 1fd49a571338b6c946bb05dcdf59ec1468df5c50 Mon Sep 17 00:00:00 2001 From: SWK <sungwk82@diteam.co.kr> Date: 목, 22 12월 2022 12:31:43 +0900 Subject: [PATCH] ongoing50 #4403 CF AOI Reveiw TACT 지연 개선 1. 일정 시간 유지 신호 처리 시 동기화로 인한 불합리 개선 - 일정 시간 유지 필요 시 스래드풀 작업큐를 이용하여 루프처리 방식으로 변경 - 유지 신호 처리 중 출력 신호 발생 시 작업큐에 등록하여 유지 신호와 결합하여 출력 처리 2. FDC 보고 항목 중 SW 버전 체크 루프 불합리 개선 - 프로그램 시작 시 연동 프로그램 버전 체크 간 실행되지 않는 프로그램이 있는 경우 무한 루프 발생 - 무한 루프로 인한 CPU 점유 상승->루프 중간 Sleep추가 및 코드 간소화 3. 로그 메시지에 시간 ms단위 추가(황만수SM 작업 내역 병합) --- ReviewHistory/include/akSTL/akRect.h | 117 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 117 insertions(+), 0 deletions(-) diff --git a/ReviewHistory/include/akSTL/akRect.h b/ReviewHistory/include/akSTL/akRect.h new file mode 100644 index 0000000..22a9119 --- /dev/null +++ b/ReviewHistory/include/akSTL/akRect.h @@ -0,0 +1,117 @@ +#pragma once + +#include "akSTLLinker.h" +#include "akRectT.h" +#include "akPoint.h" + +#define CakRectToCRect(akRect) CRect(akRect.left, akRect.top, akRect.right, akRect.bottom) +#define CRectToCakRect(rect) CakRect(rect.left, rect.top, rect.right, rect.bottom) +#define CakRectSet(rectDes, rectSrc) rectDes.SetRect(rectSrc.left, rectSrc.top, rectSrc.right, rectSrc.bottom) + +class AKSTL_DLLSPEC CakRect : public CakRectT<long> +{ +public: + + CakRect(){}; + CakRect(const long l, const long t, const long r, const long b){ + left=l,top=t,right=r,bottom=b; + }; + virtual ~CakRect(){}; + +public: + + // reference to the top-left point + CakPoint TopLeft() throw(); + // reference to the bottom-right point + CakPoint BottomRight() throw(); + // const reference to the top-left point + const CakPoint TopLeft() const throw(); + // const reference to the bottom-right point + const CakPoint BottomRight() const throw(); + // the geometric center point of the rectangle + CakPoint CenterPoint() const throw(); + + bool PtInRect(CakPoint point) const throw(); + +}; + +class AKSTL_DLLSPEC CakRectn : public CakRectT<int> +{ +public: + + CakRectn(){}; + CakRectn(int l, int t, int r, int b){ + left=l,top=t,right=r,bottom=b; + }; + virtual ~CakRectn(){}; + +public: + + // reference to the top-left point + CakPoint TopLeft() throw(); + // reference to the bottom-right point + CakPoint BottomRight() throw(); + // const reference to the top-left point + const CakPoint TopLeft() const throw(); + // const reference to the bottom-right point + const CakPoint BottomRight() const throw(); + // the geometric center point of the rectangle + CakPoint CenterPoint() const throw(); + + bool PtInRect(CakPoint point) const throw(); + +}; + +class AKSTL_DLLSPEC CakRectf : public CakRectT<float> +{ +public: + + CakRectf(){}; + CakRectf(float l, float t, float r, float b){ + left=l,top=t,right=r,bottom=b; + }; + virtual ~CakRectf(){}; + +public: + + // reference to the top-left point + CakPointf& TopLeft() throw(); + // reference to the bottom-right point + CakPointf& BottomRight() throw(); + // const reference to the top-left point + const CakPointf& TopLeft() const throw(); + // const reference to the bottom-right point + const CakPointf& BottomRight() const throw(); + // the geometric center point of the rectangle + CakPointf CenterPoint() const throw(); + + bool PtInRect(CakPointf point) const throw(); + +}; + +class AKSTL_DLLSPEC CakRectd : public CakRectT<double> +{ +public: + + CakRectd(){}; + CakRectd(double l, double t, double r, double b){ + left=l,top=t,right=r,bottom=b; + }; + virtual ~CakRectd(){}; + +public: + + // reference to the top-left point + CakPointd TopLeft() throw(); + // reference to the bottom-right point + CakPointd BottomRight() throw(); + // const reference to the top-left point + const CakPointd TopLeft() const throw(); + // const reference to the bottom-right point + const CakPointd BottomRight() const throw(); + // the geometric center point of the rectangle + CakPointd CenterPoint() const throw(); + + bool PtInRect(CakPointd point) const throw(); + +}; \ No newline at end of file -- Gitblit v1.9.3