Newer
Older
PrismSoftware / ECTrainer2 / Stimulus.cpp

#include "Stimulus.h"
#include "ECTrainer.h"
#include "Marker.h"
#include <iostream>
#include <fstream>
#include <Windows.h>
#include <tchar.h>

// コンストラクタ
Stimulus::Stimulus(ECTrainer* pEct, Marker* pMarker)
	:BaseProcess(pEct)
	, _pMarker(pMarker)
	, _StimNo(0)
{
}

// 初期化
bool Stimulus::Init() {
	_DispBuffer = cv::imread(OPENING_FILE);

	std::ifstream ifs(DATA_FILE);
	if (!ifs)
	{
		OutputDebugString(_T("Can't open stim data file."));
		return false;
	}
	while (!ifs.eof()) {
		StimImage st;
		ifs >> st.filename >> st.eyes[0].x >> st.eyes[0].y >> st.eyes[1].x >> st.eyes[1].y;
		std::cout << st.filename << st.eyes[0] << st.eyes[1] << std::endl;
		if (st.filename.size() > 0) _StimImages.push_back(st);
	}

	return true;
}

// ループ
bool Stimulus::MainLoop() {
	while (_pEct->IsRunning()) {

		_pEct->SetDispBuffer(_DispBuffer);
		Sleep(30);
	}

	return true;
}


// キャリブレーション開始
void Stimulus::Calibration() {
	_DispBuffer = cv::imread(CALIB_FILE);
}

// 開始
void Stimulus::Start() {
	_StimNo = 0;
	SetStimulus();
}

// 次へ
void Stimulus::Next() {
	_StimNo = (_StimNo + 1) % _StimImages.size();
	SetStimulus();
}

// 刺激をセット
void Stimulus::SetStimulus() {
	cv::Mat img = cv::imread(_StimImages[_StimNo].filename);
	_pMarker->Generate(img.size());
	_pMarker->DrawMarker(img);
	img.copyTo(_DispBuffer);
}