SDC C-Project CF Review 프로그램
LYW
2021-08-17 572aebd50409d2f11183d6ebbb9d12fe9041e7a5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
// MosisPitch.h: interface for the CMosisPitch class.
//
//////////////////////////////////////////////////////////////////////
 
#if !defined(AFX_MOSISPITCH_H__CA80B4A7_F0BD_4AEA_A81B_CF86C09EC7C1__INCLUDED_)
#define AFX_MOSISPITCH_H__CA80B4A7_F0BD_4AEA_A81B_CF86C09EC7C1__INCLUDED_
 
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
 
 
#include "MosisBuffer.h"
 
 
// type T¿¡ ´ëÇÑ ÀúÀå¼Ò °³³ä(hive=¹úÅë) ¿øº» : MosisRecipe ¿¡ Á¸Àç.
// ¹è¿­ Çü½ÄÀ¸·Î instance T¸¦ ÀúÀåÇϸç SetSize¸¦ ÅëÇØ Size¸¦ ´Ã¸± ¼ö ÀÖ´Ù.
// ÀæÀº ¸Þ¸ð¸® ÀÛ¾÷À» ÃÖ¼ÒÈ­ ¹× Mem free ¾ÈÁ¤¼ºÀ» È®º¸ Çϱâ À§ÇØ »ç¿ëÇÑ´Ù.
typedef __int64 int64;
 
template<typename T>
class CMosisHive1B
{
protected:
    int        m_Size;
    int        m_Space;
    T*        m_Pointers;
public:
    CMosisHive1B()
    {
        m_Pointers= NULL;
        m_Space= m_Size= 0;
    }
    ~CMosisHive1B()
    {
        if(m_Pointers)
            delete[] m_Pointers;
    }
 
    CMosisHive1B& operator =(CMosisHive1B& Hive)
    {
        if( SetSize(Hive.m_Size, FALSE))
            memcpy(m_Pointers, Hive.m_Pointers, sizeof(T)*Hive.GetSize());
        return *this;
    }
 
    int        GetSize(){return m_Size;}
    BOOL    SetSize(int size, BOOL bAppend)
    {
        ASSERT(size > 0);
        
        if(m_Pointers == NULL)
        {
            m_Pointers= new T[size];
            if(m_Pointers == NULL)
                return FALSE;
            m_Space= m_Size= size;
            return TRUE;
        }
        if(m_Space < size)
        {
            T *pOld= m_Pointers;
            m_Pointers= new T[size];
            if(m_Pointers == NULL)
            {
                m_Pointers= pOld;
                m_Size= 0;
                return FALSE;
            }
            
            if(bAppend)
                memcpy(m_Pointers, pOld, sizeof(T)*m_Size);
            
            delete[] pOld;
            
            m_Space= m_Size= size;
            return TRUE;
        }
        m_Size= size;
        return TRUE;
    }
 
    void    Delete(int i)
    {
        T* pData= GetData(i);
        if(pData == NULL)
            return;
        int size= GetSize()- 1- i;
        if(size > 0)
            memcpy(GetData(i), GetData(i+1), sizeof(T)*size);
        SetSize(GetSize()- 1, FALSE);
    }
 
    T*        Add()
    {
        int iAdd= m_Size;
        SetSize(m_Size+ 1, TRUE);
        return GetData(iAdd);
    }
 
    BOOL    Swap(int a, int b)
    {
        T* pa= GetData(a);
        T* pb= GetData(b);
        if(pa == NULL || pb == NULL)
            return FALSE;
 
        T temp= *pa;
        *pa= *pb;
        *pb= temp;
        return TRUE;
    }
 
    T*        GetData(int i)
    {
        if(i < 0 || i > GetSize()- 1)
            return NULL;
        return m_Pointers+ i;
    }
};
 
 
 
 
class AFX_EXT_CLASS CMosisPitch
{
public:
    double    m_xPitch;            // °è»êµÈ ÇÇÄ¡.
    double    m_yPitch;
 
    CRect    m_Rect;                // °Ë»ç ¿µ¿ª.
    
    double    m_xPitchOrigin;        // ±âÁØ ÇÇÄ¡ - ÁÖ¾îÁø ÇÇÄ¡. 
    double    m_yPitchOrigin;
    long    m_CheckWidth;        // ÇÇÄ¡ Æò°¡ÇÒ ¿µ¿ª width
    long    m_CheckHeight;
    long    m_xSearchRange;        // ±âÁØ ÇÇÄ¡ +- Range ¿µ¿ª ¸¸Å­ °Ë»ç.
    long    m_ySearchRange;
    
//    CMosisHive1B<int64>    m_DifferenceHive;
    
    CMosisPitch(double xPitch, double yPitch, long CheckWidth, long CheckHeight, long xSearchRange= 4, long ySearchRange= 4)
    {
        m_xPitchOrigin= xPitch;
        m_yPitchOrigin= yPitch;
        m_CheckWidth= CheckWidth;
        m_CheckHeight= CheckHeight;
        m_xSearchRange= xSearchRange;
        m_ySearchRange= ySearchRange;
        m_xPitch= 0;
        m_yPitch= 0;
    }
    CMosisPitch()
    {
        m_xPitchOrigin= 100.0;// 100.0 += m_SearchRange ¸¸Å­ °ËÁõ.
        m_yPitchOrigin= 100.0;// 100.0 += m_SearchRange ¸¸Å­ °ËÁõ.
        m_CheckWidth= 100;// widht 100 ³Êºñ·Î ºñ±³ °ËÁõ.
        m_CheckHeight= 100;// Height 100 ³Êºñ·Î ºñ±³ °ËÁõ.
        m_xSearchRange= 4;// PITCH +- 4 ¿¡¼­ °ËÁõ.
        m_ySearchRange= 4;// PITCH +- 4 ¿¡¼­ °ËÁõ.
        m_xPitch= 0;
        m_yPitch= 0;
    }
    
    BOOL CheckPitch(CMosisBuffer buffer, CRect rect);
};
#endif // !defined(AFX_MOSISPITCH_H__CA80B4A7_F0BD_4AEA_A81B_CF86C09EC7C1__INCLUDED_)