import os
import numpy as np
from scipy.io import savemat
from glob import glob
from .read_obj import read_obj
from .read_ply import read_ply
from .read_off import read_off

def read_off(file_path):
    with open(file_path, 'r') as file:
        if 'OFF' != file.readline().strip():
            raise ValueError('Not a valid OFF header')
        n_verts, n_faces, _ = map(int, file.readline().strip().split())
        verts = [list(map(float, file.readline().strip().split())) for _ in range(n_verts)]
        faces = [list(map(int, file.readline().strip().split()[1:])) for _ in range(n_faces)]
    return np.array(verts), np.array(faces)




def compute_triangle_areas(X):
    verts = X['vert']
    triv = X['triv']
    areas = []
    for tri in triv:
        a, b, c = verts[tri]
        area = 0.5 * np.linalg.norm(np.cross(b - a, c - a))
        areas.append(area)
    return np.array(areas)

def convert_dataset(folder_in, shape_file_ext):
    files = glob(os.path.join(folder_in, f"*{shape_file_ext}"))
    #folder_name, file_name = os.path.split(files)
    folder_out = os.path.join(folder_in, "mat")
    os.makedirs(folder_out, exist_ok=True)

    for i, file_in in enumerate(files):
        print(f"Processing {i + 1} of {len(files)}")
        _, file_in_ext = os.path.splitext(file_in)
        file_out = os.path.join(folder_out, f"shape_{i:03d}.mat")
        if os.path.exists(file_out):
            continue
        
        # verts, triv, normals= read_obj(file_in)
        verts, triv= read_obj(file_in)
        # verts, triv= read_off(file_in)
        # verts, triv, color, normals= read_ply(file_in)

        X = {'vert': verts, 'triv': triv}
        X['n'] = verts.shape[0]
        X['m'] = triv.shape[0]

        X['vert'] = X['vert'] - np.mean(X['vert'], axis=0)

        refarea = 0.44
        X['vert'] = X['vert'] / np.sqrt(np.sum(compute_triangle_areas(X))) * np.sqrt(refarea)
        print(i,file_in)
        savemat(file_out, {'X': X})
        print(f"Saved {file_out}")

# Example usage
# if __name__ == "__main__":
#     convert_dataset("data/meshes/banana/banana.obj")


