我有以下头文件:
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <stddef.h>
#include <GL/glew.h>
#include <GL/glfw.h>
#include <glm/glm.hpp>
#include <glm/gtc/matrix_transform.hpp>
#include <glm/gtc/type_ptr.hpp>
#include <stdlib.h>
#include <vector>
class Sphere
{
public:
Sphere();
int count_sphere_vertices(int ,int, int);
Vertex* create_sphere(int ,int , int);
};
现在,当我编译代码时,我得到以下信息:
Sphere.h:18:3: error: ‘Vertex’ does not name a type
Sphere.cpp:48:1: error: ‘Vertex’ does not name a type
和
test_1.cpp: In function ‘int main()’:
test_1.cpp:318:38: error: ‘class Sphere’ has no member named ‘create_sphere’
那是什么
“顶点”未命名类型
手段?为什么我得到
“ Sphere类”没有名为“ create_sphere”的成员
因为我在Sphere.cpp中有这个:
//Calculating points for the sphere (the algorithm is implemented here)
Vertex* Sphere::create_sphere(int dtheta,int dphi, int no_vertices)
{
GLdouble x,y,z,x2,y2,z2;
GLdouble magnitude=0;
int n=-1;
int theta,phi;
const double PI = 3.1415926535897;
GLdouble DTOR = (PI/180);//degrees to radians
Vertex* sphere_vertices = new Vertex[no_vertices];
for (theta=-90;theta<=90-dtheta;theta+=dtheta) {
for (phi=0;phi<=360-dphi;phi+=dphi) {
//calculating Vertex 1
x = cos(theta*DTOR) * cos(phi*DTOR);
y = cos(theta*DTOR) * sin(phi*DTOR);
z = sin(theta*DTOR);
n+=1;
sphere_vertices[n].position[0] = x;
sphere_vertices[n].position[1] = y;
sphere_vertices[n].position[2] = z;
//calculating Vertex 2
x = cos((theta+dtheta)*DTOR) * cos(phi*DTOR);
y = cos((theta+dtheta)*DTOR) * sin(phi*DTOR);
z = sin((theta+dtheta)*DTOR);
n+=1;
sphere_vertices[n].position[0] = x;
sphere_vertices[n].position[1] = y;
sphere_vertices[n].position[2] = z;
//calculating Vertex 3
x = cos((theta+dtheta)*DTOR) * cos((phi+dphi)*DTOR);
y = cos((theta+dtheta)*DTOR) * sin((phi+dphi)*DTOR);
z = sin((theta+dtheta)*DTOR);
n+=1;
sphere_vertices[n].position[0] = x;
sphere_vertices[n].position[1] = y;
sphere_vertices[n].position[2] = z;
//adding Vertex_1 again to divide the Quad into 2 triangles so it can be later filled with triangles!!!
//adding Vertex 1 again!
x = cos(theta*DTOR) * cos(phi*DTOR);
y = cos(theta*DTOR) * sin(phi*DTOR);
z = sin(theta*DTOR);
n+=1;
sphere_vertices[n].position[0] = x;
sphere_vertices[n].position[1] = y;
sphere_vertices[n].position[2] = z;
if (theta > -90 && theta < 90) {
//calculating Vertex 4
x = cos(theta*DTOR) * cos((phi+dphi)*DTOR);
y = cos(theta*DTOR) * sin((phi+dphi)*DTOR);
z = sin(theta*DTOR);
n+=1;
sphere_vertices[n].position[0] = x;
sphere_vertices[n].position[1] = y;
sphere_vertices[n].position[2] = z;
}
}
}
//Setting the color
for(int i=0; i<no_vertices; i+=1)
{
sphere_vertices[i].color[0] = 1;
sphere_vertices[i].color[1] = 0;
sphere_vertices[i].color[2] = 0;
}
printf("%d >> \n", n);
return sphere_vertices;
}
坦斯克
编辑:
这包括在我的test_1.cpp中,“主要”方法所在。
#include "Sphere.h"
#include "Terrain.h"
using namespace std;
//Vertex Structure
struct Vertex {
GLdouble position[3];
GLfloat color[3];
GLfloat texture[2];
};
然后我创建一个这样的球体
sphere_vertices_final = planet_1->create_sphere(5,5,no_sphere_vertices);
我应该如何在Sphere.h文件中包含Vertex?
最佳答案
这意味着编译器不知道Vertex
是什么。您包含的任何头文件中都没有定义(或定义不正确)。因此,试图返回一个指针的函数也无法编译。
因为您只在头文件中处理指向Vertex
的指针,所以可以向前声明该类:
class Vertex;
class Sphere
{
public:
// ...
...但是,然后,在访问任何方法或类的其他成员之前,您必须在cpp文件中包含正确的定义。