0

我正在尝试将纹理应用于球体。我使用 3d 建模软件来创建球体,其中顶点、法线和 texcoords 导出为 .obj 文件。我解析文件并用数据创建一个顶点缓冲区。IDE 是 Visual C++ 2012。纹理是地球的 512x256 jpg(原始,是吗?)它看起来像这样 ,看起来不像预期的那样。一直在尝试不同的 UV 映射,但没有运气。

加载资源:

D3DX11CreateShaderResourceViewFromFile(dev,        // the Direct3D device
    L"earth.jpg",    
    NULL,           
    NULL,           
    &pTexture,      
    NULL);          
devcon->PSSetShaderResources(0, 1, &pTexture);

解析文件:

if (fileIn) {
    while (fileIn) {
        VERTEX vertex;
        inChar = fileIn.get();
        std::wstring string;
        switch (inChar)
        {       
        case '#':
            inChar = fileIn.get();
            while(inChar != '\n')
                inChar = fileIn.get();
            break;
        case 'v':
            inChar = fileIn.get();
            if (inChar == ' ')  //v - vert position
            {
                fileIn >> x >> y >> z;                      
                vVector.push_back(D3DXVECTOR3(x, y, z));
                vertCount++;
            }
            else if(inChar == 'n')  //vn - vert normal
            {
                fileIn >> x >> y >> z;                      
                nVector.push_back(D3DXVECTOR3(x, y, z));                    
                normCount++;
            }
            else if(inChar == 't')  //vt - vert tex coords
            {           
                fileIn >> u >> v;                       
                tVector.push_back(D3DXVECTOR2(u, v));
                texCount++;
            }
            break;
        case 'f': // assuming vectors are filled..
            inChar = fileIn.get();
            if (inChar != ' ')
                break;
            while (!fileIn.eof()) {
                std::getline(fileIn, string);

                size_t pos = 0;
                while((pos = string.find(L"/", pos)) != std::string::npos)
                {
                    string.replace(pos, 1, L" ");
                    pos++;
                }
                if (string.find(L"f ") != std::wstring::npos)
                    string = string.replace(0, 2, L"");
                std::wistringstream iss(string);
                iss.seekg(0, std::ios::beg);
                while (iss >> i) {
                    iVector.push_back(i);
                }
            }
            break;
        }
    }
}

int vv, vt, vn;
for (i = 0; i < iVector.size(); i += 3) {
    vv  = iVector.at(i) - 1;
    vt = iVector.at(i + 1) - 1;
    vn = iVector.at(i + 2) - 1;
    VERTEX vertex;
    vertex.X = vVector.at(vv).x;
    vertex.Y = vVector.at(vv).y;
    vertex.Z = vVector.at(vv).z;
    vertex.U = tVector.at(vt).x;
    vertex.V = tVector.at(vt).y;
    vertex.Normal.x = nVector.at(vn).x;
    vertex.Normal.y = nVector.at(vn).y;
    vertex.Normal.z = nVector.at(vn).z;
    vector.push_back(vertex);
}

像素着色器:

float4 outputColor = (1.0f, 0.0f, 1.0f, 1.0f);
if (calc == 0) {
    outputColor = lightAmbient;
    float3 lightVector = lightPos.xyz - input.worldPosition.xyz;
    float3 normalVector = input.normal.xyz;
    float distance = length(lightVector);
    //if (distance > range) 
        //return outputColor;
    float diffuseBrightness = saturate(dot(normalize(normalVector), normalize(lightVector)));
    outputColor += diffuseBrightness;
    //outputColor *= lightAtt.x + (lightAtt.y * distance) + (lightAtt.z * (distance * distance));
    outputColor = saturate(outputColor);

    outputColor *= Texture.Sample(ss, input.texcoord);
}
return outputColor;

有任何想法吗?帮助表示赞赏。OBJ 文件可以在这里找到

4

0 回答 0