1

私は OpenGL を初めて使用するため、助けが必要です。したがって、私の仕事は、CNC マシンでワークピースを切断するプロセスをリアルタイムで描画するコントロールを作成することです。

glBegin、glEnd を介して古典的に実行しようとしましたが、すべて正常に動作しますが、頂点の数が多いため、最後にゆっくりと動作し始めます。したがって、 VertexBufferArray () と VertexBuffer () を使用してみることにしました - これも機能しますが、この状況では線幅とそのタイプを変更する方法がわかりません (具体的には、通常の線とダッシュの 2 つのタイプがあります) -点線)。

ここに配列を使用する私の方法があります

                private void CreateBufferAndDraw(OpenGL GL)
    {
        try
        {
            if (shaderProgram == null && vertexBufferArray == null)
            {
                var vertexShaderSource = ManifestResourceLoader.LoadTextFile("vertex_shader.glsl");
                var fragmentShaderSource = ManifestResourceLoader.LoadTextFile("fragment_shader.glsl");
                shaderProgram = new ShaderProgram();
                shaderProgram.Create(gL, vertexShaderSource, fragmentShaderSource, null);
                attribute_vpos = (uint)gL.GetAttribLocation(shaderProgram.ShaderProgramObject, "vPosition");
                attribute_vcol = (uint)gL.GetAttribLocation(shaderProgram.ShaderProgramObject, "vColor");
                shaderProgram.AssertValid(gL);
            }

            if (_data == null)
            {
                _data = new vec3[_Points.Count];
            }
            else
            {
                if (_data.Length != _Points.Count)
                {
                    _data = (vec3[])ResizeArray(_data, _Points.Count);
                }
            }

            if (_dataColor == null)
            {
                _dataColor = new vec3[_Points.Count];
            }
            else
            {
                if (_dataColor.Length != _Points.Count)
                {
                    _dataColor = (vec3[])ResizeArray(_dataColor, _Points.Count);
                }
            }

            for (int i = _dataTail; i < _Points.Count; i++)
            {
                _data[i].y = _Points[i].Y;
                _data[i].x = _Points[i].X;
                _data[i].z = _Points[i].Z;

                _dataColor[i] = new vec3(_Points[i].ToolColor.R / 255.0f, _Points[i].ToolColor.G / 255.0f, _Points[i].ToolColor.B / 255.0f);
            }

            _dataTail = _Points.Count;

            //  Create the vertex array object.
            vertexBufferArray = new VertexBufferArray();
            vertexBufferArray.Create(GL);
            vertexBufferArray.Bind(GL);

            //  Create a vertex buffer for the vertex data.
            var vertexDataBuffer = new VertexBuffer();
            vertexDataBuffer.Create(GL);
            vertexDataBuffer.Bind(GL);
            vertexDataBuffer.SetData(GL, attribute_vpos, _data, false, 3);

            //  Now do the same for the colour data.
            var colourDataBuffer = new VertexBuffer();
            colourDataBuffer.Create(GL);
            colourDataBuffer.Bind(GL);
            colourDataBuffer.SetData(GL, attribute_vcol, _dataColor, false, 3);

            //  Unbind the vertex array, we've finished specifying data for it.
            vertexBufferArray.Unbind(GL);

            //  Bind the shader, set the matrices.
            shaderProgram.Bind(GL);

            // Set matrixs for shader program
            float rads = (90.0f / 360.0f) * (float)Math.PI * 2.0f;
            mat4 _mviewdata = glm.translate(new mat4(1f), new vec3(_track_X, _track_Y, _track_Z));
            mat4 _projectionMatrix = glm.perspective(rads, (float)this.trackgl_control.Height / (float)this.trackgl_control.Width, 0.001f, 1000f);
            mat4 _modelMatrix = glm.lookAt(new vec3(0, 0, -1), new vec3(0, 0, 0), new vec3(0, -1, -1));

            shaderProgram.SetUniformMatrix4(GL, "projectionMatrix", _projectionMatrix.to_array());
            shaderProgram.SetUniformMatrix4(GL, "viewMatrix", _modelMatrix.to_array());
            shaderProgram.SetUniformMatrix4(GL, "modelMatrix", _mviewdata.to_array());

            //  Bind the out vertex array.
            vertexBufferArray.Bind(GL);

            GL.LineWidth(5.0f);
            //  Draw the square.
            GL.DrawArrays(OpenGL.GL_LINE_STRIP, 0, _dataTail);

            //  Unbind our vertex array and shader.
            vertexBufferArray.Unbind(GL);
            shaderProgram.Unbind(GL);
        }
        catch (Exception ex) { MessageBox.Show("CreateAndPlotData" + "\n" + ex.ToString()); }
    }

これは私が得るものです
ここに画像の説明を入力

ご覧のとおり、すべての線は同じ幅です。だから、私の質問は次のとおりです。これについて私に何ができるか知っている人はいますか? もう 1 つ: 楽器の現在の位置を表示する必要がある場合はどうすればよいでしょうか? 1 つの Vertex で別の配列を作成する必要がありますか?

ps私の英語には申し訳ありませんが、ここにglBegin/glEndで得られるものの写真があります
ここに画像の説明を入力


タグのスパム行為は意図していません。
私はこのプロジェクトを C++ と C# のチュートリアルで部分的にガイドしながら行っています。したがって、誰かがこれを C ++ で行う方法を知っている場合、この場合は C# で同じことを実装しようとします。

4

0 に答える 0