Я не знаю, что вызвало ошибку (C3074) - PullRequest
0 голосов
/ 20 июня 2020

Он говорит, что «массив не может быть инициализирован с помощью инициализатора в скобках», что я не уверен, я понимаю ... Итак, может ли кто-нибудь объяснить, что вызывает это, почему и как я это исправляю? Пожалуйста? (Кстати, я как бы новичок в памяти C ++, так что будьте осторожны, пожалуйста?) Я пытаюсь выполнить sh, чтобы me sh генерировался файлом obj. И, честно говоря, я не так уж хорош в этом. Извините!

Me sh .h ----------------------------------- ---------------------------

    #pragma once
#include <GL/glew.h>
#include <glm/glm.hpp>

#include <vector>

#include "../Shader/Shader.h"

struct Vertex
{
    float Position[3];
    float Uv[2];
    float Normal[3];
};

class Mesh
{
private:
    unsigned int VAO, VBO; // Vertex Array Object   ID
    unsigned int TextureID; // Texture ID
    unsigned int size;

    const char* objFilePath;
    const char* textureFilePath;

    Shader& shader;

public:
    Mesh(const char* objFilePath, const char* textureFilePath, Shader& shader);

    void draw();
};

Me sh. cpp ------ -------------------------------------------------- ------

    #include "Mesh.h"

void fillVerticesWithData(std::vector<float> data, std::vector<Vertex> info);

Mesh::Mesh(const char* objFilePath, const char* textureFilePath, Shader& shader)
    : objFilePath(objFilePath), textureFilePath(textureFilePath), shader(shader)
{
    {
        // Load Vertices from File!
        std::vector<Vertex> vertices;

        {
            std::vector<float[3]> filePos;    // Position(s)
            std::vector<float[2]> fileUV;     // Uv(s)
            std::vector<float[3]> fileNorm;   // Normal(s)

            std::ifstream file;
            file.open(objFilePath);

            std::string line;
            while (std::getline(file, line))
            {
                std::string text;
                std::istringstream iss(line);

                iss >> text;

                // Easy part!
                if (text == "v")
                {
                    float currectPos[3];

                    iss >> currectPos[0];
                    iss >> currectPos[1];
                    iss >> currectPos[2];

                    filePos.push_back(currectPos);
                }
                if (text == "vt")
                {
                    float currectUV[2];

                    iss >> currectUV[0];
                    iss >> currectUV[1];

                    fileUV.push_back(currectUV);
                }
                if (text == "vn")
                {
                    float currectNorm[3];

                    iss >> currectNorm[0];
                    iss >> currectNorm[1];
                    iss >> currectNorm[2];

                    fileNorm.push_back(currectNorm);
                }


                // Last part, hard part!
                if (text == "f")
                {
                    int x, y, z;
                    int x2, y2, z2;
                    int x3, y3, z3;
                    char e;

                    // First Vertex!
                    iss >> x;
                    iss >> e;
                    iss >> y;
                    iss >> e;
                    iss >> z;
                    iss >> x2;
                    iss >> e;
                    iss >> y2;
                    iss >> e;
                    iss >> z2;
                    iss >> x3;
                    iss >> e;
                    iss >> y3;
                    iss >> e;
                    iss >> z3;

                    Vertex temp_Vertex;
                    for (int i = 0; i < 3; i++)
                    {
                        temp_Vertex.Position[i] = filePos.at(x - 1)[i];
                        temp_Vertex.Normal[i] = fileNorm.at(y - 1)[i];
                    }
                    for (int i = 0; i < 2; i++)
                    {
                        temp_Vertex.Uv[i] = fileUV.at(z - 1)[i];
                    }

                    vertices.push_back(temp_Vertex);

                    std::cout << "Vertex 1 -----------" << std::endl;
                    std::cout << "Position: " << temp_Vertex.Position[0] << " " << temp_Vertex.Position[1] << " " << temp_Vertex.Position[2] << std::endl;
                    std::cout << "UV: " << temp_Vertex.Uv[0] << " " << temp_Vertex.Uv[1] << std::endl;
                    std::cout << "Normal: " << temp_Vertex.Normal[0] << " " << temp_Vertex.Normal[1] << temp_Vertex.Normal[2] << std::endl;

                    // Second Vertex!
                    Vertex temp_Vertex2;
                    for (int i = 0; i < 3; i++)
                    {
                        temp_Vertex2.Position[i] = filePos.at(x2 - 1)[i];
                        temp_Vertex2.Normal[i] = fileNorm.at(y2 - 1)[i];
                    }
                    for (int i = 0; i < 2; i++)
                    {
                        temp_Vertex2.Uv[i] = fileUV.at(z2 - 1)[i];
                    }

                    vertices.push_back(temp_Vertex2);

                    std::cout << "Vertex 1 -----------" << std::endl;
                    std::cout << "Position: " << temp_Vertex2.Position[0] << " " << temp_Vertex2.Position[1] << " " << temp_Vertex2.Position[2] << std::endl;
                    std::cout << "UV: " << temp_Vertex2.Uv[0] << " " << temp_Vertex2.Uv[1] << std::endl;
                    std::cout << "Normal: " << temp_Vertex2.Normal[0] << " " << temp_Vertex2.Normal[1] << temp_Vertex2.Normal[2] << std::endl;

                    // Third Vertex
                    Vertex temp_Vertex3;
                    for (int i = 0; i < 3; i++)
                    {
                        temp_Vertex3.Position[i] = filePos.at(x3 - 1)[i];
                        temp_Vertex3.Normal[i] = fileNorm.at(y3 - 1)[i];
                    }
                    for (int i = 0; i < 2; i++)
                    {
                        temp_Vertex3.Uv[i] = fileUV.at(z3 - 1)[i];
                    }

                    vertices.push_back(temp_Vertex3);

                    std::cout << "Vertex 1 -----------" << std::endl;
                    std::cout << "Position: " << temp_Vertex3.Position[0] << " " << temp_Vertex3.Position[1] << " " << temp_Vertex3.Position[2] << std::endl;
                    std::cout << "UV: " << temp_Vertex3.Uv[0] << " " << temp_Vertex3.Uv[1] << std::endl;
                    std::cout << "Normal: " << temp_Vertex3.Normal[0] << " " << temp_Vertex3.Normal[1] << temp_Vertex3.Normal[2] << std::endl;

                    // Face!!! :O
                    // This one here I am having trouble with
                    // How do I read it?
                }
            }
        }

        // Load Texture from File!

        // Last step:
        std::vector<float> vertexArray;

        fillVerticesWithData(vertexArray, vertices);

        glGenVertexArrays(1, &VAO);
        glGenBuffers(1, &VBO);

        glBindVertexArray(VAO);

        glBindBuffer(GL_ARRAY_BUFFER, VBO);
        glBufferDataARB(GL_ARRAY_BUFFER_ARB, vertexArray.size() * sizeof(float), &vertexArray[0], GL_STATIC_DRAW);

        // Position Pointer:
        glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void*)0);
        glEnableVertexAttribArray(0);
        glVertexAttribPointer(1, 2, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void*)3);
        glEnableVertexAttribArray(1);
        glVertexAttribPointer(3, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void*)5);
        glEnableVertexAttribArray(3);

        // Unbinding everything:
        glBindBuffer(GL_ARRAY_BUFFER, 0);
        glBindVertexArray(0);

        size = vertexArray.size();
    }
}

void Mesh::draw()
{
    shader.use();
    glBindVertexArray(VAO);
//  glBindTexture(GL_TEXTURE_2D, TextureID);

    // Later:
    // Draw Elements

    // For now:
    glDrawArrays(GL_TRIANGLES, 0, size);
}


// data is the data we wanna fill with information!
// The info has the information we want to put into data!
void fillVerticesWithData(std::vector<float> data, std::vector<Vertex> info)
{
    for (int i = 0; i < info.size(); i++)
    {
        // Position:
        for (int posI = 0; posI < 3; posI++)
        {
            float temp[3];

            temp[posI] = info.at(i).Position[posI];
            data.push_back(temp[posI]);
        }
        // Uv:
        for (int uvI = 0; uvI < 2; uvI++)
        {
            float temp[2];

            temp[uvI] = info.at(i).Uv[uvI];
            data.push_back(temp[uvI]);
        }
        // Normal:
        for (int norI = 0; norI < 3; norI++)
        {
            float temp[3];

            temp[norI] = info.at(i).Normal[norI];
            data.push_back(temp[norI]);
        }
    }
}

В любом случае, спасибо, что прочитали этот пост / вопрос, даже если он только что читал. Я ценю любую помощь, которую могу получить! (И я долгое время работал над загрузкой этой sh вещи, и я просто хочу покончить с ней)

Надеюсь, у вас хороший день! (Или ночь, смеется) :)

Ответы [ 2 ]

3 голосов
/ 20 июня 2020

Элементы std::vector должны быть копируемыми и назначаемыми. Массивы нельзя копировать и присваивать.

Я рекомендую использовать std::array:

std::vector<std::array<float, 3>> filePos;    // Position(s)
std::vector<std::array<float, 2>> fileUV;     // Uv(s)
std::vector<std::array<float, 3>> fileNorm;   // Normal(s)
std::array<float, 3> currectPos;
std::array<float, 2> currectUV;
std::array<float, 3> currectNorm;

Кроме того, если именованный буферный объект привязан, то последний параметр glVertexAttribPointer обрабатывается как байтовое смещение в хранилище данных буферного объекта:

glVertexAttribPointer(1, 2, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void*)3);

glVertexAttribPointer(1, 2, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void*)(sizeof(float)*3));

glVertexAttribPointer(3, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void*)5);

glVertexAttribPointer(3, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void*)(sizeof(float)*5));
0 голосов
/ 20 июня 2020

Нельзя использовать собственный массив c в качестве аргумента шаблона для std::vector<>. Вместо этого используйте std::array<3> Вот так: std::vector<std::array<float,3>>

Вы также можете использовать указатель на три числа с плавающей запятой, это нормально.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...