fclose(outf);
}
CString CFingerAnalyserDlg::GetSAV(CString srcName)
{
CString fsav = srcName.Left(srcName.GetLength() - 3) + "sav";
while(fsav.Find("\\") != -1){ fsav = fsav.Right(fsav.GetLength() - fsav.Find("\\")-1); }
return sav_path + fsav;
void CFingerAnalyserDlg::OnBnClickedShowBase()
m_show_base =! m_show_base;
UpdateData(false);
if(m_show_base)
ShowBase(true, false);
else
OnPaint();
void CFingerAnalyserDlg::OnLButtonDown(UINT nFlags, CPoint point)
if(!m_show_base) return;
mouse_pos = point;
mouse_pos.x -= 110;
mouse_pos.y -= 45;
CDialog::OnLButtonDown(nFlags, point);
П.1.6 ТЕКСТ МОДУЛЯ fing.h
#pragma once
#include "stdafx.h"
using namespace std;
//Элемент "карты точек"
//"Карта точек" - список точек для обработки
class TMapElDot{
public:
CPoint coord; //координаты точки
bool pr1, pr2; //признаки точки
TMapElDot(CPoint dot){pr1 = true; pr2 = true; coord = dot;};
TMapElDot(){pr1 = true; pr2 = true;};
~TMapElDot(){};
};
class TMapDot{
list<TMapElDot> map; //карта точек на изображении
TMapDot(){};
~TMapDot(){map.clear();};
//сопроводительна информация
class TInfo{
short kol; //количество точек
short dpi; //качество исходного отпечатка (dot per inch)
CString src; //путь к образу из которого была получена информация
CTime date; //дата отпечатка
CString description; //описание
bool operator==(const TInfo &inf){return src == inf.src;}; //сравнение расположения изображений на диске
TInfo(){kol = -1; dpi = -1; /*src = ""; description = "";*/};
void Printf(FILE *fout) //запись данных в файл
fwrite((void *)(&kol), sizeof(kol), 1, fout);
fwrite((void *)(&dpi), sizeof(dpi), 1, fout);
int strlen = src.GetLength();
fwrite((void *)(&strlen), sizeof(int), 1, fout);
fwrite((void *)(src.GetBuffer()), strlen, 1, fout);
void Scanf(FILE *fin) //чтение данных из файла
fread((void *)(&kol), sizeof(kol), 1, fin);
fread((void *)(&dpi), sizeof(dpi), 1, fin);
int strlen;
fread((void *)(&strlen), sizeof(int), 1, fin);
char * text = new char[strlen+1];
fread((void *)(text), strlen, 1, fin);
text[strlen] = '\0';
src = text;
delete(text);
//абсолютные параметры точки
class TAbsDot{
CPoint coord; //координаты
double alpha; //направление в точке
bool type; //тип точки (1- окончание, 0- раздвоение)
bool show; //видимость точки (1- видима, 0- скрыта)
TAbsDot(){coord.x = -1; coord.y = -1; alpha = 0; type = false; show = false;};
~TAbsDot(){};
bool operator==(const TAbsDot &f){return (coord.x == f.coord.x && coord.y == f.coord.y && alpha == f.alpha);};
bool operator <(const TAbsDot &f){return (alpha < f.alpha);};
bool operator >(const TAbsDot &f){return (alpha > f.alpha);};
bool operator!=(const TAbsDot &f){return false;};
bool operator<=(const TAbsDot &f){return false;};
bool operator>=(const TAbsDot &f){return false;};
CString toStr()
CString str;
str.Format("%d %d %f %d %d\n", coord.x, coord.y, alpha, type, show);
return str;
//класс для хранения точек в _абсолютных_ параметрах
//Описание отпечатка в абсолютных параметрах
class TAbsFing: public list<TAbsDot>
TAbsFing(){this->clear();};
~TAbsFing(){this->clear();};
bool LoadFing(CString src); //Загрузка отпечатка из файла *.sav
bool SaveFing(CString fsav); //Сохранение отпечатка в файл *.sav
//относительные параметры точки
class TRelDot{
short l,a1,a2; //координаты точки
//l - растояние между точками
//a1 - угол между собственным направлением точки А и направлением A -> B [0, 2*M_PI)
//a2 - угол между собственным направлением точки В и направлением A -> B [0, 2*M_PI)
TAbsDot absDot; //ее абсолютные параметры (необходимо для отображения на экране совпавших точек)
bool operator<(const TRelDot &f){return this->l < f.l;}
bool sortByA1(TRelDot &f){return a1 < f.a1;} //эта функция нужна для сортировки, но сортировка так и не реализованна
bool operator==(const TRelDot &f){return (this->l == f.l && this->a1 == f.a1 && this->a2 == f.a2);}
CString toStr(){CString s; s.Format("%d %d %d\n", l, a1, a2); return s;}
//класс для хранения _относительных_ параметров точки
typedef list<TRelDot> listTRelDot;
//Шаблон для хранения пары значений {first, second}
template <class data_t1, class data_t2> struct TPair{
data_t1 first;
data_t2 second;
TPair(data_t1 _f, data_t2 _s){first = _f; second = _s;};
typedef TPair<TAbsDot, TAbsDot> TPairAbsDot;
typedef TPair<listTRelDot*, listTRelDot*> TPairSur;
//результат сравнения отпечатков
struct TCompareFing{
double val; //уровень схожести отпечатков
short cDot; //количество совпавших точек
short nfng; //номер отпечатка
CString name; //файл отпечатка
list<TPairAbsDot> dots; //first - совпавшие точки на отпечатке в базе
//second - совпавшие точки на открытом отпечатке
list<TPairSur> surdots;
//окружения на одинаковых отпечатках должны быть одинаковыми,
//на этом основано сравнение "роз"
//Описание отпечатка в _относительных_ параметрах
class TRelFing: public list<listTRelDot>{
private:
inline double GetS(const CPoint A, const CPoint B); //растояние между точками
double GetAlpha(const CPoint A, const CPoint B); //Направлени из точки А в В [-pi,pi)
TRelFing(){};
~TRelFing(){};
TRelFing *Convert(TAbsFing &fng); //конвертировать абсолютные параметры к относительным
TCompareFing Compare(TRelFing &fng); //сравнить отпечатки
П.1.7 ТЕКСТ МОДУЛЯ fing.cpp
#include "fing.h"
bool TAbsFing::SaveFing(CString fsav)
//Сохранение отпечатка в файл *.sav
if(!this->size()) return false;
TAbsFing::iterator iter;
FILE *fingfile = fopen(fsav, "wb");
if(fingfile == NULL)
MessageBox(NULL,"Невозможно создать файл: '"+fsav+"'", "Ошибка работы с файлом", MB_OK);
return false;
for(iter = this->begin(); iter != this->end(); iter++)
TAbsDot dot = *iter;
if(iter->show) fwrite((void *)&dot, 1, sizeof(dot), fingfile);
fclose(fingfile);
return true;
bool TAbsFing::LoadFing(CString src)
//Загрузка отпечатка из файла *.sav
TAbsDot dot;
FILE *fingfile = fopen(src, "rb");
MessageBox(NULL,"Невозможно открыть файл: '"+src+"'", "Ошибка работы с файлом", MB_OK);
this->clear();
while(!feof(fingfile))
fread((void *)&dot, 1, sizeof(dot), fingfile);
this->push_back(dot);
this->pop_back();
///////////////////////////////////////////////////////////////////////////////////////
///TRelFing//TRelFing/TRelFing/TRelFing/TRelFing/TRelFing/TRelFing/TRelFing/TRelFing///
TRelFing *TRelFing::Convert(TAbsFing &fng)
//конвертировать абсолютные параметры к относительным
if(fng.empty()) return this;
TAbsFing::iterator iterA1, iterA2;
TRelDot tmpR;
listTRelDot listDots;
double tmpa, vecAB;
for(iterA1 = fng.begin(); iterA1 != fng.end(); iterA1++)
for(iterA2 = fng.begin(); iterA2 != fng.end(); iterA2++)
if(iterA2 == iterA1) continue;
tmpR.l = (short)(GetS(iterA1->coord, iterA2->coord)+0.5); //l - растояние между точками
vecAB = GetAlpha(iterA2->coord, iterA1->coord);
tmpa = iterA1->alpha - vecAB;
if(tmpa < 0) tmpa = 2*M_PI + tmpa;
tmpR.a1 = (short)(tmpa * 180.0/M_PI +0.5); //a1 - угол между собственным направлением точки А и направлением A -> B
tmpa = iterA2->alpha - vecAB;
tmpR.a2 = (short)(tmpa * 180.0/M_PI +0.5); //a2 - угол между собственным направлением точки В и направлением A -> B
tmpR.absDot = *iterA1; //Во всех точках хранятся одни и те же данные!(необходимо для отображения совпавших точек)
listDots.push_back(tmpR);
listDots.sort();
this->push_back(listDots);
listDots.clear();
return this;
inline double TRelFing::GetS(const CPoint A, const CPoint B)
//растояние между точками
return sqrt( (double)((A.x-B.x)*(A.x-B.x)+(A.y-B.y)*(A.y-B.y)) );
double TRelFing::GetAlpha(const CPoint A, const CPoint B)
//Направлени из точки А в В [-pi,pi)
if(A == B) return 0.0;
double alpha;
Страницы: 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