Files
1960-utils/Texturing/MergeTextures/merge_textures_dekogon.py

44 lines
1.3 KiB
Python
Raw Normal View History

2024-03-18 14:42:50 +01:00
import cv2
import sys
import numpy as np
import re
if len(sys.argv) < 2:
print("Please provide the input files.")
sys.exit(1)
basecolor_file = None
normal_file = None
rma_file = None
# Loop through the command-line arguments
for arg in sys.argv[1:]:
if '_alb.' in arg.lower():
basecolor_file = arg
elif '_nrm.' in arg.lower():
normal_file = arg
elif '_rma.' in arg.lower():
rma_file = arg
# Check if all files are provided
if not all([basecolor_file, normal_file, rma_file]):
print("Please provide all input files: base_color, normal, roughness, ambient_occlusion, and metallic.")
sys.exit(1)
basecolor = cv2.imread(basecolor_file, cv2.IMREAD_COLOR)
normal = cv2.imread(normal_file, cv2.IMREAD_COLOR)
orm = cv2.imread(rma_file, cv2.IMREAD_COLOR)
basecolorb, basecolorg, basecolorr = basecolor.T
normalb, normalg, normalr = normal.T
aob, metallicb, roughnessb, = orm.T
BCR = np.array([basecolorb, basecolorg, basecolorr, roughnessb])
NMO = np.array([metallicb, normalg, normalr, aob])
result = re.search(r'TX_(.*)_', basecolor_file)
output_dir = re.search(r'^(.+)\\.+$', basecolor_file).group(1)
cv2.imwrite(output_dir + f"\\{result.group(1)}_BCR.png", BCR.T)
cv2.imwrite(output_dir + f"\\{result.group(1)}_NMO.png", NMO.T)