基于vs2015中nuget插件的openmesh安装

如何安装nuget

  1. 打开vs2015
  2. 点击菜单栏中的"工具"->"扩展与更新",选择nuget包管理器进行安装。
  3. 参考网址:https://docs.microsoft.com/zh-cn/nuget/what-is-nuget

                          https://www.cnblogs.com/ShaYeBlog/p/5552893.html

如何利用nuget安装opengl 

  • 打开vs2015,创建一个“空项目”。

这里需要注意的一点:如果创建的项目为win32项目则会报错,具体的错误为

针对该问题目前尚未由较好的解决方法。

  • 点击“文件”->“新建”->"项目"->“Visual C++”->"空项目"->“为项目命名”->“完成”
  • 方案一:点击“工具”->"Nuget包管理器"->"管理解决方案的NuGet程序包"
  • 方案二:鼠标右键点击项目->"管理nuget程序包"
  • 在打开的界面搜索“openmesh”。
  • 尝试运行实例代码
  • /* ========================================================================= * 
    *                                                                           * 
    *                               OpenMesh                                    * 
    *           Copyright (c) 2001-2015, RWTH-Aachen University                 * 
    *           Department of Computer Graphics and Multimedia                  * 
    *                          All rights reserved.                             * 
    *                            www.openmesh.org                               * 
    *                                                                           * 
    *---------------------------------------------------------------------------* 
    * This file is part of OpenMesh.                                            * 
    *---------------------------------------------------------------------------* 
    *                                                                           * 
    * Redistribution and use in source and binary forms, with or without        * 
    * modification, are permitted provided that the following conditions        * 
    * are met:                                                                  * 
    *                                                                           * 
    * 1. Redistributions of source code must retain the above copyright notice, * 
    *    this list of conditions and the following disclaimer.                  * 
    *                                                                           * 
    * 2. Redistributions in binary form must reproduce the above copyright      * 
    *    notice, this list of conditions and the following disclaimer in the    * 
    *    documentation and/or other materials provided with the distribution.   * 
    *                                                                           * 
    * 3. Neither the name of the copyright holder nor the names of its          * 
    *    contributors may be used to endorse or promote products derived from   * 
    *    this software without specific prior written permission.               * 
    *                                                                           * 
    * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS       * 
    * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED * 
    * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A           * 
    * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER * 
    * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  * 
    * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,       * 
    * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR        * 
    * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF    * 
    * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING      * 
    * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS        * 
    * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.              * 
    *                                                                           * 
    * ========================================================================= */  
    /*===========================================================================*\ 
    *                                                                           * 
    *   $Revision$                                                         * 
    *   $Date$                   * 
    *                                                                           * 
    \*===========================================================================*/  
    #include <iostream>  
    // -------------------- OpenMesh  
    #include <OpenMesh/Core/IO/MeshIO.hh>  
    #include <OpenMesh/Core/Mesh/PolyMesh_ArrayKernelT.hh>  
    // ----------------------------------------------------------------------------  
    typedef OpenMesh::PolyMesh_ArrayKernelT<>  MyMesh;  
    // ----------------------------------------------------------------------------  
    // Build a simple cube and write it to std::cout  
      
    int main()  
    {  
        MyMesh mesh;  
        // generate vertices  
        MyMesh::VertexHandle vhandle[8];  
        vhandle[0] = mesh.add_vertex(MyMesh::Point(-1, -1, 1));  
        vhandle[1] = mesh.add_vertex(MyMesh::Point(1, -1, 1));  
        vhandle[2] = mesh.add_vertex(MyMesh::Point(1, 1, 1));  
        vhandle[3] = mesh.add_vertex(MyMesh::Point(-1, 1, 1));  
        vhandle[4] = mesh.add_vertex(MyMesh::Point(-1, -1, -1));  
        vhandle[5] = mesh.add_vertex(MyMesh::Point(1, -1, -1));  
        vhandle[6] = mesh.add_vertex(MyMesh::Point(1, 1, -1));  
        vhandle[7] = mesh.add_vertex(MyMesh::Point(-1, 1, -1));  
        // generate (quadrilateral) faces  
        std::vector<MyMesh::VertexHandle>  face_vhandles;  
        face_vhandles.clear();  
        face_vhandles.push_back(vhandle[0]);  
        face_vhandles.push_back(vhandle[1]);  
        face_vhandles.push_back(vhandle[2]);  
        face_vhandles.push_back(vhandle[3]);  
        mesh.add_face(face_vhandles);  
      
        face_vhandles.clear();  
        face_vhandles.push_back(vhandle[7]);  
        face_vhandles.push_back(vhandle[6]);  
        face_vhandles.push_back(vhandle[5]);  
        face_vhandles.push_back(vhandle[4]);  
        mesh.add_face(face_vhandles);  
        face_vhandles.clear();  
        face_vhandles.push_back(vhandle[1]);  
        face_vhandles.push_back(vhandle[0]);  
        face_vhandles.push_back(vhandle[4]);  
        face_vhandles.push_back(vhandle[5]);  
        mesh.add_face(face_vhandles);  
        face_vhandles.clear();  
        face_vhandles.push_back(vhandle[2]);  
        face_vhandles.push_back(vhandle[1]);  
        face_vhandles.push_back(vhandle[5]);  
        face_vhandles.push_back(vhandle[6]);  
        mesh.add_face(face_vhandles);  
        face_vhandles.clear();  
        face_vhandles.push_back(vhandle[3]);  
        face_vhandles.push_back(vhandle[2]);  
        face_vhandles.push_back(vhandle[6]);  
        face_vhandles.push_back(vhandle[7]);  
        mesh.add_face(face_vhandles);  
        face_vhandles.clear();  
        face_vhandles.push_back(vhandle[0]);  
        face_vhandles.push_back(vhandle[3]);  
        face_vhandles.push_back(vhandle[7]);  
        face_vhandles.push_back(vhandle[4]);  
        mesh.add_face(face_vhandles);  
        // write mesh to output.obj  
        try  
        {  
            if (!OpenMesh::IO::write_mesh(mesh, "output.off"))  
            {  
                std::cerr << "Cannot write mesh to file 'output.off'" << std::endl;  
                return 1;  
            }  
        }  
        catch (std::exception& x)  
        {  
            std::cerr << x.what() << std::endl;  
            return 1;  
        }  
        return 0;  
    }  

    利用meshView查看输出的output.off文件。meshView无需安装,下载完后即可使用。 

  • meshView的下载网址为:

  • http://mview.sourceforge.net/#Downloads

  • https://sourceforge.net/projects/mview/

  • 运行结果如下所示:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值