好友
阅读权限20
听众
最后登录1970-1-1
|
zhzhx
发表于 2022-11-15 09:39
一、需求:基于苹果数据4*4矩阵数据,转换成二维平面坐标系
二、解决方法与步骤:
1、4*4矩阵转成二维:基于四维矩阵中心点,求两端点坐标
2、利用平面内直角坐标系中坐标旋转变换公式将平面坐标点转化
用到的方法:
1、Matrix4的转化_Catirl的博客-CSDN博客
2、平面内直角坐标系中坐标旋转变换公式_Eric_Wangyz的博客-CSDN博客_坐标旋转变换公式
苹果数据代码:
[Python] 纯文本查看 复制代码 {
"windows" : [
{
"category" : {
"window" : {
}
},
"confidence" : {
"medium" : {
}
},
"dimensions" : [
4.4304699897766113,
2.4727039337158203,
0
],
"completedEdges" : [
],
"parentIdentifier" : "B4002F3F-2741-405F-9A82-18FF65284C8C",
"identifier" : "70ABA8D4-0AA8-4404-940E-04309F358EBC",
"curve" : null,
"transform" : [
-0.30633658170700073,
0,
-0.95192313194274902,
0,
0,
0.99999994039535522,
0,
0,
0.9519231915473938,
0,
-0.30633658170700073,
0,
-3.3060400485992432,
-0.20823472738265991,
2.7119290828704834,
1
]
}
],
"doors" : [
{
"category" : {
"door" : {
"isOpen" : false
}
},
"confidence" : {
"medium" : {
}
},
"dimensions" : [
1.0301132202148438,
2.5737776756286621,
0
],
"completedEdges" : [
],
"parentIdentifier" : "CC22237C-B6ED-44B5-8547-180A3A0E5994",
"identifier" : "B19AD43B-3C4D-4DA5-A5C0-34A1D39F5892",
"curve" : null,
"transform" : [
0.3063366711139679,
0,
0.95192307233810425,
0,
0,
1,
0,
0,
-0.95192307233810425,
0,
0.3063366711139679,
0,
0.90193623304367065,
-0.24133116006851196,
-0.033205278217792511,
1
]
},
{
"category" : {
"door" : {
"isOpen" : false
}
},
"confidence" : {
"medium" : {
}
},
"dimensions" : [
1.0522669553756714,
2.411841869354248,
0
],
"completedEdges" : [
],
"parentIdentifier" : "CC22237C-B6ED-44B5-8547-180A3A0E5994",
"identifier" : "8095E4C9-2986-446E-9FC9-D92225777FBC",
"curve" : null,
"transform" : [
0.30633670091629028,
0,
0.95192313194274902,
0,
0,
0.99999994039535522,
0,
0,
-0.95192307233810425,
0,
0.3063366711139679,
0,
1.2751809358596802,
-0.2488710880279541,
1.1266312599182129,
1
]
},
{
"category" : {
"door" : {
"isOpen" : true
}
},
"confidence" : {
"medium" : {
}
},
"dimensions" : [
0.79290330410003662,
2.3365452289581299,
0
],
"completedEdges" : [
],
"parentIdentifier" : "CC22237C-B6ED-44B5-8547-180A3A0E5994",
"identifier" : "717D86E1-F273-4577-85DF-E03B933D6188",
"curve" : null,
"transform" : [
0.30633661150932312,
0,
0.95192325115203857,
0,
0,
1,
0,
0,
-0.95192325115203857,
0,
0.30633661150932312,
0,
0.5105128288269043,
-0.35994744300842285,
-1.249530553817749,
1
]
}
],
"walls" : [
{
"category" : {
"wall" : {
}
},
"confidence" : {
"high" : {
}
},
"dimensions" : [
5.6710019111633301,
2.9569838047027588,
0
],
"completedEdges" : [
],
"parentIdentifier" : "8D161454-7233-4E76-BC11-3E3186A8B6D6",
"identifier" : "B4002F3F-2741-405F-9A82-18FF65284C8C",
"curve" : null,
"transform" : [
-0.30633664131164551,
0,
-0.9519231915473938,
0,
0,
0.99999994039535522,
0,
0,
0.95192313194274902,
0,
-0.30633658170700073,
0,
-3.4495170116424561,
-0.049728155136108398,
2.2660825252532959,
1
]
},
{
"category" : {
"wall" : {
}
},
"confidence" : {
"high" : {
}
},
"dimensions" : [
4.8466057777404785,
2.9569838047027588,
0
],
"completedEdges" : [
],
"parentIdentifier" : "5ADD04DA-13E7-4010-B381-D3307FFD5E46",
"identifier" : "F4BCF245-4442-422E-9894-177078F54AE0",
"curve" : null,
"transform" : [
0.9519231915473938,
0,
-0.30633658170700073,
0,
0,
0.99999994039535522,
0,
0,
0.30633652210235596,
0,
0.95192307233810425,
0,
-2.0113365650177002,
-0.049728155136108398,
-1.1754434108734131,
1
]
},
{
"category" : {
"wall" : {
}
},
"confidence" : {
"high" : {
}
},
"dimensions" : [
4.1486597061157227,
2.9569838047027588,
0
],
"completedEdges" : [
],
"parentIdentifier" : "25A96F47-C12D-4EFE-B971-472089DF4594",
"identifier" : "4AD4A1DE-4257-49F2-B788-EAEE5223107C",
"curve" : null,
"transform" : [
-0.9519231915473938,
0,
0.30633658170700073,
0,
0,
0.99999994039535522,
0,
0,
-0.30633652210235596,
0,
-0.95192307233810425,
0,
0.18788377940654755,
-0.049728155136108398,
4.5193233489990234,
1
]
},
{
"category" : {
"wall" : {
}
},
"confidence" : {
"high" : {
}
},
"dimensions" : [
0.69794571399688721,
2.9569838047027588,
0
],
"completedEdges" : [
],
"parentIdentifier" : "44C4678D-23CB-4C12-B6C4-762CB0452E60",
"identifier" : "74CA573A-F192-47E2-A262-EEF9CAF44E7E",
"curve" : null,
"transform" : [
-0.95192313194274902,
0,
0.30633693933486938,
0,
0,
0.99999994039535522,
0,
0,
-0.306336909532547,
0,
-0.95192307233810425,
0,
-2.2487037181854248,
-0.049728155136108398,
4.8583579063415527,
1
]
},
{
"category" : {
"wall" : {
}
},
"confidence" : {
"high" : {
}
},
"dimensions" : [
0.4236811101436615,
2.9569838047027588,
0
],
"completedEdges" : [
],
"parentIdentifier" : "D510898F-31C8-4986-8A1C-9EE75CC68D91",
"identifier" : "4912B095-361F-4914-8F1A-FB2F9A0C3C94",
"curve" : null,
"transform" : [
-0.30633756518363953,
0,
-0.95192277431488037,
0,
0,
0.99999994039535522,
0,
0,
0.95192277431488037,
0,
-0.30633756518363953,
0,
-1.8516137599945068,
-0.049728155136108398,
4.9531106948852539,
1
]
},
{
"category" : {
"wall" : {
}
},
"confidence" : {
"high" : {
}
},
"dimensions" : [
6.0946831703186035,
2.9569838047027588,
0
],
"completedEdges" : [
],
"parentIdentifier" : "34D0C39D-D4D7-48B4-9DE0-7ACD7E6EFBB9",
"identifier" : "CC22237C-B6ED-44B5-8547-180A3A0E5994",
"curve" : null,
"transform" : [
0.30633670091629028,
0,
0.9519231915473938,
0,
0,
0.99999994039535522,
0,
0,
-0.95192313194274902,
0,
0.30633664131164551,
0,
1.2289738655090332,
-0.049728155136108398,
0.98304539918899536,
1
]
}
],
"openings" : [
],
"objects" : [
{
"dimensions" : [
1.5987249612808228,
0.94955956935882568,
0.065000005066394806
],
"confidence" : {
"medium" : {
}
},
"transform" : [
0.95192325115203857,
0,
-0.30633643269538879,
0,
0,
0.99999994039535522,
0,
0,
0.30633637309074402,
0,
0.9519231915473938,
0,
-1.6764084100723267,
-0.001988828182220459,
-0.99941855669021606,
1
],
"category" : {
"television" : {
}
},
"identifier" : "C3BEB09E-7408-42CE-8954-E87B355B4299"
},
{
"dimensions" : [
0.51159495115280151,
1.0113105773925781,
0.56274306774139404
],
"confidence" : {
"medium" : {
}
},
"transform" : [
-0.95192283391952515,
0,
0.30633756518363953,
0,
0,
1,
0,
0,
-0.30633753538131714,
0,
-0.95192289352416992,
0,
-0.40752917528152466,
-1.0225648880004883,
3.9929168224334717,
1
],
"category" : {
"chair" : {
}
},
"identifier" : "B8105472-71D6-417E-9E2C-F1155FB1F1F2"
},
{
"dimensions" : [
0.4749830961227417,
0.40395355224609375,
0.57471352815628052
],
"confidence" : {
"medium" : {
}
},
"transform" : [
-0.95192235708236694,
0,
0.30633917450904846,
0,
0,
1.0000001192092896,
0,
0,
-0.30633923411369324,
0,
-0.95192247629165649,
0,
-0.55003666877746582,
-1.3262432813644409,
3.1927976608276367,
1
],
"category" : {
"chair" : {
}
},
"identifier" : "2A7F638D-DAB2-4FAB-A4EA-FA0F9793390A"
},
{
"dimensions" : [
0.47498306632041931,
0.40395355224609375,
0.57471358776092529
],
"confidence" : {
"medium" : {
}
},
"transform" : [
-0.30632853507995605,
0,
-0.95192575454711914,
0,
0,
1.0000001192092896,
0,
0,
0.95192593336105347,
0,
-0.30632859468460083,
0,
-1.6257414817810059,
-1.3262432813644409,
1.6771179437637329,
1
],
"category" : {
"chair" : {
}
},
"identifier" : "0ED886B4-014C-47E9-B952-F868561FC3B0"
},
{
"dimensions" : [
0.52009981870651245,
0.94679880142211914,
0.57890421152114868
],
"confidence" : {
"medium" : {
}
},
"transform" : [
0.21847167611122131,
0,
0.97584319114685059,
0,
0,
0.99999988079071045,
0,
0,
-0.97584307193756104,
0,
0.21847164630889893,
0,
1.4021255970001221,
-1.0548207759857178,
2.5414259433746338,
1
],
"category" : {
"chair" : {
}
},
"identifier" : "5A194FF7-5D66-4FFA-9379-4B801234BA3A"
},
{
"dimensions" : [
3.7170906066894531,
0.83971703052520752,
1.2917746305465698
],
"confidence" : {
"high" : {
}
},
"transform" : [
0.30633649230003357,
0,
0.9519231915473938,
0,
0,
1.0000001192092896,
0,
0,
-0.95192337036132812,
0,
0.30633652210235596,
0,
-1.0929687023162842,
-1.1083616018295288,
1.5056676864624023,
1
],
"category" : {
"table" : {
}
},
"identifier" : "2524B480-8A47-4ED7-BD97-0A9C6ACE8A95"
},
{
"dimensions" : [
3.3376014232635498,
2.3581094741821289,
0.49721428751945496
],
"confidence" : {
"medium" : {
}
},
"transform" : [
-0.95192277431488037,
0,
0.30633765459060669,
0,
0,
1,
0,
0,
-0.3063376247882843,
0,
-0.95192277431488037,
0,
-0.2743067741394043,
-0.34916538000106812,
4.4068951606750488,
1
],
"category" : {
"storage" : {
}
},
"identifier" : "52E23C35-59C5-404B-A46F-DBDB2A5BECCC"
}
],
"version" : 1
}
1、4*4矩阵转成二维:基于四维矩阵中心点,求两端点坐标
[Python] 纯文本查看 复制代码 # 墙体信息
for wall in json_data["walls"]:
# 墙体中心坐标
center_p = np.array([wall["transform"][-4], wall["transform"][-2]])
length = wall["dimensions"][0]
transform01 = abs(wall["transform"][10])
if wall["transform"][10] < 0:
transform02 = wall["transform"][8]
else:
transform02 = -wall["transform"][8]
# 基于中心点与四维矩阵,获取起始点
p1 = center_p + 0.5 * length * np.array([transform01, transform02])
p2 = center_p - 0.5 * length * np.array([transform01, transform02])
2、平面坐标系转化
[Python] 纯文本查看 复制代码 cos = abs(json_data["walls"][0]["transform"][10])
sin = -abs(json_data["walls"][0]["transform"][8])
# # # 坐标翻转
x1 = p1[0] * cos - p1[1] * sin
y1 = p1[1] * cos + p1[0] * sin
p1 = Point2D(int(round(x1 * 1000, 0)), int(round(y1 * 1000, 0)))
x2 = p2[0] * cos - p2[1] * sin
y2 = p2[1] * cos + p2[0] * sin
p2 = Point2D(int(round(x2 * 1000, 0)), int(round(y2 * 1000, 0)))
3、整合代码:
[Python] 纯文本查看 复制代码 import json
from sympy.geometry import *
PATH = r"D:\Desktop\room74.json"
f = open(PATH, 'rb')
j = json.load(f)
f.close()
def get_start_end_point(center_p, length, transform01, transform02, cos, sin):
# 基于中心点与四维矩阵,获取起始点
p1 = center_p + 0.5 * length * np.array([transform01, transform02])
p2 = center_p - 0.5 * length * np.array([transform01, transform02])
# # # 坐标翻转
x1 = p1[0] * cos - p1[1] * sin
y1 = p1[1] * cos + p1[0] * sin
p1 = Point2D(int(round(x1 * 1000, 0)), int(round(y1 * 1000, 0)))
x2 = p2[0] * cos - p2[1] * sin
y2 = p2[1] * cos + p2[0] * sin
p2 = Point2D(int(round(x2 * 1000, 0)), int(round(y2 * 1000, 0)))
return p1, p2
def get_wall_points(json_data):
# 获取墙所有的坐标点
wall_p_list = []
# 墙体信息
cos = abs(json_data["walls"][0]["transform"][10])
sin = -abs(json_data["walls"][0]["transform"][8])
for wall in json_data["walls"]:
# 墙体中心坐标
center_p = np.array([wall["transform"][-4], wall["transform"][-2]])
length = wall["dimensions"][0]
transform01 = abs(wall["transform"][10])
if wall["transform"][10] < 0:
transform02 = wall["transform"][8]
else:
transform02 = -wall["transform"][8]
p1, p2 = get_start_end_point(center_p, length, transform01, transform02, cos, sin)
wall_p_list.extend([p1, p2])
return wall_p_list
# 获取墙所有的坐标点:
wall_points_list = get_wall_points(json_data)
print(wall_points_list )
4、结果:
[Python] 纯文本查看 复制代码 [[Point2D(760, -869), Point2D(-270, -869)], [Point2D(1989, -869), Point2D(937, -869)], [Point2D(-637, -869), Point2D(-1430, -869)]]
|
|