mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-11 21:50:34 +05:00
Print function value on double click
This commit is contained in:
parent
ea7f6c1e94
commit
e5d339ed99
@ -209,6 +209,8 @@ namespace netgen
|
|||||||
void BuildBadelList();
|
void BuildBadelList();
|
||||||
void BuildIdentifiedList();
|
void BuildIdentifiedList();
|
||||||
void BuildDomainSurfList();
|
void BuildDomainSurfList();
|
||||||
|
|
||||||
|
bool Unproject (int px, int py, Point<3> &p);
|
||||||
};
|
};
|
||||||
|
|
||||||
DLL_HEADER extern VisualSceneMesh vsmesh;
|
DLL_HEADER extern VisualSceneMesh vsmesh;
|
||||||
|
@ -3128,9 +3128,7 @@ namespace netgen
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
bool VisualSceneMesh :: Unproject (int px, int py, Point<3> &p)
|
||||||
|
|
||||||
void VisualSceneMesh :: MouseDblClick (int px, int py)
|
|
||||||
{
|
{
|
||||||
shared_ptr<Mesh> mesh = GetMesh();
|
shared_ptr<Mesh> mesh = GetMesh();
|
||||||
|
|
||||||
@ -3150,20 +3148,59 @@ namespace netgen
|
|||||||
int hy = viewport[3]-py;
|
int hy = viewport[3]-py;
|
||||||
|
|
||||||
GLfloat pz;
|
GLfloat pz;
|
||||||
|
|
||||||
|
if(lock)
|
||||||
|
{
|
||||||
|
lock->UnLock();
|
||||||
|
delete lock;
|
||||||
|
lock = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(pz>=1.0)
|
||||||
|
return false;
|
||||||
// cout << "x, y = " << px << ", " << hy << endl;
|
// cout << "x, y = " << px << ", " << hy << endl;
|
||||||
glReadPixels (px, hy, 1, 1, GL_DEPTH_COMPONENT, GL_FLOAT, &pz);
|
glReadPixels (px, hy, 1, 1, GL_DEPTH_COMPONENT, GL_FLOAT, &pz);
|
||||||
// cout << "pz = " << pz << endl;
|
// cout << "pz = " << pz << endl;
|
||||||
gluUnProject(px, hy, pz, transformationmat, projection, viewport,
|
gluUnProject(px, hy, pz, transformationmat, projection, viewport,
|
||||||
&result[0], &result[1], &result[2]);
|
&result[0], &result[1], &result[2]);
|
||||||
|
|
||||||
if (pz < 1.0)
|
p = Point<3>{result[0], result[1], result[2]};
|
||||||
cout << "point : " << result[0] << ", " << result[1] << ", " << result[2] << endl;
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
if (user_me_handler && pz < 1.0)
|
|
||||||
|
void VisualSceneMesh :: MouseDblClick (int px, int py)
|
||||||
|
{
|
||||||
|
Point<3> p;
|
||||||
|
bool found_point = Unproject(px, py, p);
|
||||||
|
|
||||||
|
if(selelement!=-1)
|
||||||
{
|
{
|
||||||
if (selelement != -1)
|
const Element2d & sel = GetMesh()->SurfaceElement(selelement);
|
||||||
user_me_handler -> DblClick (selelement-1, result[0], result[1], result[2]);
|
|
||||||
|
cout << "select element " << selelement
|
||||||
|
<< " on face " << sel.GetIndex() << endl;
|
||||||
|
cout << "Nodes: ";
|
||||||
|
for (int i = 1; i <= sel.GetNP(); i++)
|
||||||
|
cout << sel.PNum(i) << " ";
|
||||||
|
cout << endl;
|
||||||
|
|
||||||
|
cout << "selected point " << selpoint
|
||||||
|
<< ", pos = " << GetMesh()->Point (selpoint)
|
||||||
|
<< endl;
|
||||||
|
|
||||||
|
cout << "seledge = " << seledge << endl;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if(found_point)
|
||||||
|
{
|
||||||
|
cout << "point : " << p << endl;
|
||||||
|
if (user_me_handler)
|
||||||
|
{
|
||||||
|
if (selelement != -1)
|
||||||
|
user_me_handler -> DblClick (selelement-1, p[0], p[1], p[2]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
selecttimestamp = NextTimeStamp();
|
selecttimestamp = NextTimeStamp();
|
||||||
@ -3401,6 +3438,7 @@ namespace netgen
|
|||||||
|
|
||||||
if (vispar.clipping.enable)
|
if (vispar.clipping.enable)
|
||||||
{
|
{
|
||||||
|
glEnable(GL_CLIP_PLANE0);
|
||||||
Vec<3> n(clipplane[0], clipplane[1], clipplane[2]);
|
Vec<3> n(clipplane[0], clipplane[1], clipplane[2]);
|
||||||
double len = Abs(n);
|
double len = Abs(n);
|
||||||
double mu = -clipplane[3] / (len*len);
|
double mu = -clipplane[3] / (len*len);
|
||||||
@ -3473,23 +3511,12 @@ namespace netgen
|
|||||||
{
|
{
|
||||||
const Element2d & sel = mesh->SurfaceElement(minname);
|
const Element2d & sel = mesh->SurfaceElement(minname);
|
||||||
|
|
||||||
|
|
||||||
cout << "select element " << minname
|
|
||||||
<< " on face " << sel.GetIndex() << endl;
|
|
||||||
cout << "Nodes: ";
|
|
||||||
for (i = 1; i <= sel.GetNP(); i++)
|
|
||||||
cout << sel.PNum(i) << " ";
|
|
||||||
cout << endl;
|
|
||||||
|
|
||||||
selelement = minname;
|
selelement = minname;
|
||||||
selface = mesh->SurfaceElement(minname).GetIndex();
|
selface = mesh->SurfaceElement(minname).GetIndex();
|
||||||
|
|
||||||
locpi = (locpi % sel.GetNP()) + 1;
|
locpi = (locpi % sel.GetNP()) + 1;
|
||||||
selpoint2 = selpoint;
|
selpoint2 = selpoint;
|
||||||
selpoint = sel.PNum(locpi);
|
selpoint = sel.PNum(locpi);
|
||||||
cout << "selected point " << selpoint
|
|
||||||
<< ", pos = " << mesh->Point (selpoint)
|
|
||||||
<< endl;
|
|
||||||
|
|
||||||
for (i = 1; i <= mesh->GetNSeg(); i++)
|
for (i = 1; i <= mesh->GetNSeg(); i++)
|
||||||
{
|
{
|
||||||
@ -3498,7 +3525,6 @@ namespace netgen
|
|||||||
(seg[1] == selpoint && seg[0] == selpoint2) )
|
(seg[1] == selpoint && seg[0] == selpoint2) )
|
||||||
{
|
{
|
||||||
seledge = seg.edgenr;
|
seledge = seg.edgenr;
|
||||||
cout << "seledge = " << seledge << endl;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4754,9 +4754,32 @@ namespace netgen
|
|||||||
|
|
||||||
void VisualSceneSolution :: MouseDblClick (int px, int py)
|
void VisualSceneSolution :: MouseDblClick (int px, int py)
|
||||||
{
|
{
|
||||||
vsmesh.SetClippingPlane();
|
Point<3> p;
|
||||||
// vsmesh.BuildFilledList();
|
bool found_point = vsmesh.Unproject(px, py, p);
|
||||||
vsmesh.MouseDblClick(px,py);
|
if(!found_point)
|
||||||
|
return;
|
||||||
|
|
||||||
|
|
||||||
|
if(selelement>0) // found a surface element (possibliy behind clipping plane), check if drawn point really is in this element
|
||||||
|
{
|
||||||
|
double lami[3];
|
||||||
|
lami[0] = lami[1] = lami[2] = 0.0;
|
||||||
|
// Check if unprojected Point is close to surface element (eps of 1e-3 due to z-Buffer accuracy)
|
||||||
|
if(GetMesh()->PointContainedIn2DElement(p, lami, selelement, false) && fabs(lami[2])<1e-3)
|
||||||
|
{
|
||||||
|
double val;
|
||||||
|
GetSurfValue(soldata[scalfunction], selelement-1, -1, 1.0-lami[0]-lami[1], lami[0], scalcomp, val);
|
||||||
|
cout << "surface function value: " << val << endl;
|
||||||
|
}
|
||||||
|
// otherwise assume that the unprojected point is on the clipping plane -> find 3d element containing it
|
||||||
|
else if(auto el3d = GetMesh()->GetElementOfPoint( p, lami ))
|
||||||
|
{
|
||||||
|
double val;
|
||||||
|
GetValue(soldata[scalfunction], el3d-1, lami[0], lami[1], lami[2], scalcomp, val);
|
||||||
|
cout << "clipping plane value: " << val << endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user