106 Eigen::Map<Eigen::Vector3f>(default_eyes.left) = Eigen::Vector3f(-0.2f, 0.0f, 0.0f);
107 Eigen::Map<Eigen::Vector3f>(default_eyes.right) = Eigen::Vector3f( 0.2f, 0.0f, 0.0f);
108 Eigen::Map<Eigen::Vector3f>(default_eyes.left_up) = Eigen::Vector3f(0.0f, 0.0f, 1.0f);
109 Eigen::Map<Eigen::Vector3f>(default_eyes.right_up) = Eigen::Vector3f(0.0f, 0.0f, 1.0f);
122 Eigen::Vector3f::Map(
rot) = Eigen::Vector3f::Zero();
123 Eigen::Vector3f::Map(
move) = Eigen::Vector3f::Zero();
124 Eigen::Vector3f::Map(
eye) = Eigen::Vector3f(1.0f, 0.0f, 0.0f);
125 Eigen::Vector3f::Map(
up) = Eigen::Vector3f(0.0f, 0.0f, 1.0f);
127 Eigen::Vector3f::Map(
bg_color) = Eigen::Vector3f::Zero();
128 Eigen::Vector3f::Map(
text_color) = Eigen::Vector3f::Ones();
142 QString pathLh = QString(
"%1/%2/surf/%3.%4").arg(subjects_dir).arg(subject_id).arg(
"lh").arg(surf);
143 QString pathLhCurv = QString(
"%1/%2/surf/%3.%4").arg(subjects_dir).arg(subject_id).arg(
"lh").arg(
"curv");
144 QString pathRh = QString(
"%1/%2/surf/%3.%4").arg(subjects_dir).arg(subject_id).arg(
"rh").arg(surf);
145 QString pathRhCurv = QString(
"%1/%2/surf/%3.%4").arg(subjects_dir).arg(subject_id).arg(
"rh").arg(
"curv");
147 printf(
"Loading surface %s ...\n", pathLh.toUtf8().constData());
153 left->add_uniform_curv();
156 printf(
"Loading surface %s ...\n", pathRh.toUtf8().constData());
162 right->add_uniform_curv();
165 auto result = std::make_unique<MNEMshDisplaySurfaceSet>(2);
167 result->surfs[0] = std::make_unique<MNEMshDisplaySurface>();
168 result->surfs[1] = std::make_unique<MNEMshDisplaySurface>();
170 result->active[0] =
true;
171 result->active[1] =
false;
172 result->drawable[0] =
true;
173 result->drawable[1] =
true;
175 auto* pThis = result->surfs[0].get();
176 pThis->filename = pathLh;
179 pThis->subj = subject_id;
180 pThis->surf_name = surf;
182 pThis->decide_surface_extent(
"Left hemisphere");
183 pThis->decide_curv_display(surf);
184 pThis->setup_curvature_colors();
186 pThis = result->surfs[1].get();
187 pThis->filename = pathRh;
190 pThis->subj = subject_id;
191 pThis->surf_name = surf;
193 pThis->decide_surface_extent(
"Right hemisphere");
194 pThis->decide_curv_display(surf);
195 pThis->setup_curvature_colors();
197 result->apply_left_right_eyes();
198 result->setup_current_lights();
207 const QString& bemname,
211 printf(
"Loading BEM surface %s (id = %d) from %s ...\n",
212 bemname.toUtf8().constData(), kind, filepath.toUtf8().constData());
219 surf->compute_surface_cm();
220 double sum = surf->sum_solids(Eigen::Map<const Eigen::Vector3f>(surf->cm)) / (4*
M_PI);
221 if (std::fabs(sum - 1.0) > 1e-4) {
222 printf(
"%s surface is not closed "
223 "(sum of solid angles = %g * 4*PI).",
224 bemname.toUtf8().constData(), sum);
229 auto newSurf = std::make_unique<MNEMshDisplaySurface>();
230 newSurf->filename = filepath;
234 newSurf->surf_name = bemname;
239 newSurf->decide_surface_extent(bemname);
254 for (
int k = 0; k <
nsurf; k++) {
255 auto& surf =
surfs[k];
256 if (surf->id == newSurf->id) {
257 newSurf->transparent = surf->transparent;
258 newSurf->show_aux_data = surf->show_aux_data;
259 surfs[k] = std::move(newSurf);
262 this->drawable[k] =
false;
269 surfs.push_back(std::move(newSurf));
273 this->drawable.conservativeResize(
nsurf+1);
286 if (neyes == 0 || current_eyes < 0 || current_eyes > neyes-1) {
287 eyes = &default_eyes;
289 eyes = all_eyes+current_eyes;
292 for (
int k = 0; k <
nsurf; k++) {
293 auto* surf =
surfs[k].get();
297 surf->eye = Eigen::Vector3f::Map(eyes->
left);
298 surf->up = Eigen::Vector3f::Map(eyes->
left_up);
302 surf->eye = Eigen::Vector3f::Map(eyes->
right);
303 surf->up = Eigen::Vector3f::Map(eyes->
right_up);
306 surf->eye = Eigen::Vector3f::Map(eyes->
left);
307 surf->up = Eigen::Vector3f::Map(eyes->
left_up);
341 if (!custom_lights) {
342 custom_lights = std::make_unique<MNEMshLightSet>();
344 custom_lights->lights.push_back(std::make_unique<MNEMshLight>(
true, 0.0f, 0.0f, 1.0f, 0.8f, 0.8f, 0.8f));
345 custom_lights->lights.push_back(std::make_unique<MNEMshLight>(
true, 0.0f, 0.0f, -1.0f, 0.8f, 0.8f, 0.8f));
346 custom_lights->lights.push_back(std::make_unique<MNEMshLight>(
true, 0.6f, -1.0f, -1.0f, 0.6f, 0.6f, 0.6f));
347 custom_lights->lights.push_back(std::make_unique<MNEMshLight>(
true, -0.6f, -1.0f, -1.0f, 0.6f, 0.6f, 0.6f));
348 custom_lights->lights.push_back(std::make_unique<MNEMshLight>(
true, 1.0f, 0.0f, 0.0f, 0.8f, 0.8f, 0.8f));
349 custom_lights->lights.push_back(std::make_unique<MNEMshLight>(
true, -1.0f, 0.0f, 0.0f, 0.8f, 0.8f, 0.8f));
350 custom_lights->lights.push_back(std::make_unique<MNEMshLight>(
true, 0.0f, 1.0f, 0.5f, 0.6f, 0.6f, 0.6f));
351 custom_lights->lights.push_back(std::make_unique<MNEMshLight>(
false, 0.0f, 0.0f, -1.0f, 1.0f, 1.0f, 1.0f));