import numpy as np

import open3d as o3d
import numpy as np
from scipy.io import loadmat

def read_ply(filepath):
# 读取 .ply 文件
    # mesh = o3d.io.read_triangle_mesh("/workspace/projects/Frosting/colormorph/data/applegreen.ply")
    mesh = o3d.io.read_triangle_mesh(filepath)
    # 打印顶点和面片数据
    print("Vertices:")
    vert=np.asarray(mesh.vertices)
    # print(np.asarray(mesh.vertices))
    print(vert.shape)

    print("Faces:")
    face=np.asarray(mesh.triangles)
    # print(np.asarray(mesh.triangles))
    print(face.shape)

    # 如果有颜色信息，打印颜色数据
    color=np.asarray(mesh.vertex_colors)
    # if mesh.has_vertex_colors():
    print("Vertex Colors:")
    #     print(np.asarray(mesh.vertex_colors))
    print(color.shape)

    normal=np.asarray(mesh.vertex_normals)
    # if mesh.has_vertex_colors():
    print("Vertex normal:")
    #     print(np.asarray(mesh.vertex_colors))
    print(normal.shape)
    return vert,face,color,normal