zhzhx 发表于 2022-11-15 09:39

小案例:4*4矩阵转换成二维平面坐标

一、需求:基于苹果数据4*4矩阵数据,转换成二维平面坐标系

二、解决方法与步骤:

1、4*4矩阵转成二维:基于四维矩阵中心点,求两端点坐标

2、利用平面内直角坐标系中坐标旋转变换公式将平面坐标点转化

用到的方法:

1、Matrix4的转化_Catirl的博客-CSDN博客

2、平面内直角坐标系中坐标旋转变换公式_Eric_Wangyz的博客-CSDN博客_坐标旋转变换公式

苹果数据代码:

{
"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矩阵转成二维:基于四维矩阵中心点,求两端点坐标

# 墙体信息
for wall in json_data["walls"]:
    # 墙体中心坐标
    center_p = np.array([-4], wall["transform"][-2]])
    length = wall["dimensions"]

    transform01 = abs(wall["transform"])
    if wall["transform"] < 0:
      transform02 = wall["transform"]
    else:
      transform02 = -wall["transform"]

# 基于中心点与四维矩阵,获取起始点
    p1 = center_p + 0.5 * length * np.array()
    p2 = center_p - 0.5 * length * np.array()

2、平面坐标系转化

cos = abs(json_data["walls"]["transform"])
sin = -abs(json_data["walls"]["transform"])

# # # 坐标翻转
x1 = p1 * cos - p1 * sin
y1 = p1 * cos + p1 * sin
p1 = Point2D(int(round(x1 * 1000, 0)), int(round(y1 * 1000, 0)))

x2 = p2 * cos - p2 * sin
y2 = p2 * cos + p2 * sin
p2 = Point2D(int(round(x2 * 1000, 0)), int(round(y2 * 1000, 0)))

3、整合代码:

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()
    p2 = center_p - 0.5 * length * np.array()

    # # # 坐标翻转
    x1 = p1 * cos - p1 * sin
    y1 = p1 * cos + p1 * sin
    p1 = Point2D(int(round(x1 * 1000, 0)), int(round(y1 * 1000, 0)))

    x2 = p2 * cos - p2 * sin
    y2 = p2 * cos + p2 * 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"]["transform"])
    sin = -abs(json_data["walls"]["transform"])
    for wall in json_data["walls"]:
      # 墙体中心坐标
      center_p = np.array([-4], wall["transform"][-2]])
      length = wall["dimensions"]

      transform01 = abs(wall["transform"])
      if wall["transform"] < 0:
            transform02 = wall["transform"]
      else:
            transform02 = -wall["transform"]

      p1, p2 = get_start_end_point(center_p, length, transform01, transform02, cos, sin)
      wall_p_list.extend()

    return wall_p_list


# 获取墙所有的坐标点:
wall_points_list = get_wall_points(json_data)

print(wall_points_list )

4、结果:

[, , ]


页: [1]
查看完整版本: 小案例:4*4矩阵转换成二维平面坐标