当前位置: 首页>>代码示例>>C++>>正文


C++ TriMesh::compute_areas方法代码示例

本文整理汇总了C++中TriMesh::compute_areas方法的典型用法代码示例。如果您正苦于以下问题:C++ TriMesh::compute_areas方法的具体用法?C++ TriMesh::compute_areas怎么用?C++ TriMesh::compute_areas使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在TriMesh的用法示例。


在下文中一共展示了TriMesh::compute_areas方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: load_background_mesh

TriMesh* Scene::load_background_mesh(const string& filename, const Mat4x4f& transform)
{
  TriMesh* mesh = new TriMesh; 
  obj_load(filename, *mesh);
  if(!mesh->has_normals())
  {
    cout << "Computing normals" << endl;
    mesh->compute_normals();
  }
  mesh->transform(transform);
  mesh->compute_areas();
  cout << "No. of triangles: " << mesh->geometry.no_faces() << endl;
  meshes.push_back(mesh);
  return mesh;
}
开发者ID:,项目名称:,代码行数:15,代码来源:

示例2: extract_area_lights

unsigned int Scene::extract_area_lights(RayTracer* tracer, unsigned int samples_per_light)
{
  light_tracer = tracer;
  for(unsigned int i = 0; i < meshes.size(); ++i)
  {
    TriMesh* mesh = new TriMesh;
    const vector<int>& indices = meshes[i]->mat_idx;
    for(unsigned int j = 0; j < indices.size(); ++j)
    {
      const ObjMaterial& mat = meshes[i]->materials[indices[j]];
      if(mat.name == "default")
        continue;

      bool emissive = false;
      for(unsigned int k = 0; k < 3; ++k)
        emissive = emissive || (meshes[i]->materials[indices[j]].ambient[k] > 0.0f);

      if(emissive)
      {
    	  Vec3i g_face = meshes[i]->geometry.face(j);
        for(unsigned int k = 0; k < 3; ++k)
          g_face[k] = mesh->geometry.add_vertex(meshes[i]->geometry.vertex(g_face[k]));
        int idx = mesh->geometry.add_face(g_face);
        if(meshes[i]->normals.no_faces() > j)
        {        
          Vec3i n_face = meshes[i]->normals.face(j);
          for(unsigned int k = 0; k < 3; ++k)
	          n_face[k] = mesh->normals.add_vertex(meshes[i]->normals.vertex(n_face[k]));
          mesh->normals.add_face(n_face, idx);
        }
        if(meshes[i]->texcoords.no_faces() > j)
        {
          Vec3i t_face = meshes[i]->texcoords.face(j);
          for(unsigned int k = 0; k < 3; ++k)
  	        t_face[k] = mesh->texcoords.add_vertex(meshes[i]->texcoords.vertex(t_face[k]));
          mesh->texcoords.add_face(t_face, idx);
        }
        
        bool material_exists = false;
        for(unsigned int k = 0; k < mesh->materials.size(); ++k)
          if(mesh->materials[k].name == meshes[i]->materials[indices[j]].name)
          {
            mesh->mat_idx.push_back(k);
            material_exists = true;
            break;
          }
        if(!material_exists)
        {
          mesh->mat_idx.push_back(mesh->materials.size());
          mesh->materials.push_back(meshes[i]->materials[indices[j]]);
        }
      }
    }
    if(mesh->geometry.no_faces() == 0)
      delete mesh;
    else
    {
      mesh->compute_areas();
      light_meshes.push_back(mesh);
      extracted_lights.push_back(lights.size());
      lights.push_back(new AreaLight(light_tracer, mesh, samples_per_light));
    }
  }
  return lights.size();
}
开发者ID:,项目名称:,代码行数:65,代码来源:


注:本文中的TriMesh::compute_areas方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。