- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个....独特的问题。我正在制作一个游戏,我将在其中动态绘制点(代表城市)以及它们之间的飞行路径。然后用户将选择这些城市并执行进一步的操作。
此外,地球仪必须能够绕一个轴旋转,这样用户才能轻松看到所有城市。
我找到了一种在球体上绘制点和路径的方法。这些点是微小的球体,路径是我生成的贝塞尔曲线。我已将它们包含在 glpushmatrix() 和 glpopmatrix() 中,并在开始时调用 glrotate() 以便所有事物(地球、路径和顶点)一致旋转
我面临的唯一问题是弄清楚用户点击了哪个顶点。 glrotate 修改模型矩阵,所以我是否必须在每次旋转时计算顶点的新位置?我正在使用 glunproject 找出用户点击的位置。或者,还有其他方法可以解决这个问题吗?
这是我的代码:-
float venusRotate;
vector<vector3f>cityVertices;
//bezier curve
GLfloat bezierCurve(float t, GLfloat P0,
GLfloat P1, GLfloat P2) {
// Cubic bezier Curve
GLfloat point = pow(t,2)*P0 + 2*P1*t*(1-t) + P2*pow(1-t, 2);
return point;
}
vector3f randomSpherePoint()
{
float u = static_cast <float> (rand()) / static_cast <float> (RAND_MAX);
float v = static_cast <float> (rand()) / static_cast <float> (RAND_MAX);
float theta = 2 * M_PI * u;
float phi = acos(2*v-1);
float x=(10*sin(phi)*cos(theta));
float y=(10 * sin(phi) * sin(theta));
float z=10*cos(phi);
return vector3f(x, y, z);
}
void drawRandomSpherePoints()
{
for (int i=0; i<400; i++)
{
glPushMatrix();
vector3f point=cityVertices.at(i);
glTranslatef(point.x, point.y, point.z);
glutSolidSphere(0.25, 10, 10);
glPopMatrix();
}
}
vector3f GetOGLPos(int x, int y)
{
GLint viewport[4];
GLdouble modelview[16];
GLdouble projection[16];
GLfloat winX, winY, winZ;
GLdouble posX, posY, posZ;
glGetDoublev( GL_MODELVIEW_MATRIX, modelview );
glGetDoublev( GL_PROJECTION_MATRIX, projection );
glGetIntegerv( GL_VIEWPORT, viewport );
winX = (float)x;
winY = (float)viewport[3] - (float)y;
glReadPixels( x, int(winY), 1, 1, GL_DEPTH_COMPONENT, GL_FLOAT, &winZ );
gluUnProject( winX, winY, winZ, modelview, projection, viewport, &posX, &posY, &posZ);
return vector3f(posX, posY, posZ);
}
void mouseClick(int button,int state,int x, int y)
{
vector3f Coord=GetOGLPos(x, y);
cout<<Coord.x<<" "<<Coord.y<<" "<<Coord.z<<endl;
// for (int i=0;i<cityVertices.size();i++)
// {
// if (Coord.x-cityVertices.at(i).x<CLICK_ACCURACY && Coord.z-cityVertices.at(i).z<CLICK_ACCURACY && Coord.z-cityVertices.at(i).z<CLICK_ACCURACY ) {
// }
// }
}
void preProcessEvents()
{
CURRENT_TIME=(float)glutGet(GLUT_ELAPSED_TIME);
DELTA_TIME=CURRENT_TIME-LAST_TIME;
LAST_TIME=CURRENT_TIME;
mouse::update();
//mouse processing
Camera::rotationAngles.y+=(float)mouse::deltaX*MOUSE_SENSITIVITY;
Camera::rotationAngles.x-=(float)mouse::deltaY*MOUSE_SENSITIVITY;
if (Camera::rotationAngles.x>MAX_TILT)
{
Camera::rotationAngles.x=MAX_TILT;
}
else if (Camera::rotationAngles.x<-1*MAX_TILT)
{
Camera::rotationAngles.x=-1*MAX_TILT;
}
if (keyBoard::key['w'])
{
Camera::position.z-=WALKING_SPEED*DELTA_TIME*Math::sind(Camera::rotationAngles.y);
Camera::position.x-=WALKING_SPEED*DELTA_TIME*Math::cosd(Camera::rotationAngles.y);
}
else if (keyBoard::key['s'])
{
Camera::position.z+=WALKING_SPEED*DELTA_TIME*Math::sind(Camera::rotationAngles.y);
Camera::position.x+=WALKING_SPEED*DELTA_TIME*Math::cosd(Camera::rotationAngles.y);
}
else if (keyBoard::key['a'])
{
Camera::rotationAngles.y-=WALKING_SPEED*DELTA_TIME*3;
}
else if (keyBoard::key['d'])
{
Camera::rotationAngles.y+=WALKING_SPEED*DELTA_TIME*3;
}
else if (keyBoard::key['f'])
{
venusRotate++;
}
else if (keyBoard::key[' '])
{
glutDestroyWindow(subWindow);
}
}
void reshape(int w, int h)
{
float aspectRatio;
if (h==0)
{
h=1;
}
aspectRatio=float(w)/float(h);
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
glViewport(0, 0, w ,h);
gluPerspective(45, aspectRatio, 0.01, 100000000);
glMatrixMode(GL_MODELVIEW);
}
void display()
{
preProcessEvents();
glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);
glLoadIdentity();
gluLookAt(Camera::position.x, Camera::position.y, Camera::position.z,
Camera::position.x+Math::sind(Camera::rotationAngles.x)*Math::cosd(Camera::rotationAngles.y),
Camera::position.y+Math::cosd(Camera::rotationAngles.x),
Camera::position.z+Math::sind(Camera::rotationAngles.x)*Math::sind(Camera::rotationAngles.y),
0.0, 1.0, 0.0);
glBegin(GL_TRIANGLES);
glColor3f(1, 0, 0);
glVertex3f(-1, 0,-3);
glColor3f(0, 1, 0);
glVertex3f(0.0f, 2.0f,-3);
glColor3f(0, 0, 1);
glVertex3f(1.0f, 0.0f,-3);
glEnd();
glBindTexture(GL_TEXTURE_2D, tex->textureID);
glBegin(GL_QUADS);
glColor3f(1, 1, 1);
glTexCoord2f(100, 100);
glVertex3f(100,0,100);
glTexCoord2f(-100, 100);
glVertex3f(-100,0,100);
glTexCoord2f(-100,-100);
glVertex3f(-100,0,-100);
glTexCoord2f(100,-100);
glVertex3f(100,0,-100);
glEnd();
glBindTexture(GL_TEXTURE_2D, 0);
glPushMatrix();
object1.draw();
glPopMatrix();
//globe
glTranslatef(-10.0, 10.0, 0.0);
glBindTexture(GL_TEXTURE_2D, tex2->textureID);
gluQuadricTexture(quad,1);
glMatrixMode(GL_MODELVIEW);
glPushMatrix();
glRotatef(-90, 1.0f, 0.0f, 0.0f);
glRotatef(venusRotate, 0.0, 0.0, 1.0);
drawRandomSpherePoints();
for (int i=0; i<cityVertices.size()-1; i++)
{
vector3f start=cityVertices.at(i);
vector3f end=cityVertices.at(i+1);
vector3f perpBisectorDirection=vector3f((start.x+end.x)/2,(start.y+end.y)/2,(start.z+end.z)/2);
vector3f tan1(perpBisectorDirection.x/10*15,perpBisectorDirection.y/10*15,perpBisectorDirection.z/10*15);
glColor3f(1.0, 0.0, 0.0);
glLineWidth(12.0);
glBegin(GL_LINE_STRIP);
int t = 30;
for (int i = 0; i <= t; i++) {
float pos = (float) i / (float) t;
GLfloat x = bezierCurve( pos,start.x, tan1.x, end.x);
GLfloat y = bezierCurve( pos,start.y, tan1.y, end.y);
// In our case, the z should always be empty
GLfloat z = bezierCurve(pos,start.z, tan1.z, end.z);
vector3f result(x, y, z);
glVertex3f(x, y, z);
}
glEnd();
}
gluSphere(quad,10,20,20);
glPopMatrix();
glBindTexture(GL_TEXTURE_2D, 0);
glutSwapBuffers();
}
最佳答案
Opengl 有一个选择模式
glRenderMode(GL_SELECT);
关于c++ - 绘制带有飞行路径的地球,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26699364/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!