多边形面积求解的方法很多,其中比较多见的就是增加一个点P,然后分别连接多边形各个定点与P点,然后计算每个三角形的符号面积(面积有正负之分),求和就可以计算出面积。

鉴于上面的方法,我们也可以用另外一种更简单的方法,将P点直接放在V0点,那么我们要求的面积就是V0V1V2,VoV2V3,...,V0Vn-2Vn-3的面积和。此处注意,如果我们假设逆时针的三角形(如上图V0V2V3)为正,那么顺时针的面积(如上图V0V1V2)就为负。

代码如下:

#------------------------------------------------------------------------------- # Name:        多边形面积计算 # Purpose: # # Author:      Administrator # # Created:     20-02-2013 # Copyright:   (c) Administrator 2013 # Licence:     #------------------------------------------------------------------------------- import math class Point():     def __init__(self,x,y):         self.x = x         self.y = y def GetAreaOfPolyGon(points):     '''计算多边形面积值        points:多边形的点集,每个点为Point类型        返回:多边形面积'''     area = 0     if(len(points)<3):         raise Exception("至少需要3个点才有面积")     p1 = points[0]     for i in range(1,len(points)-1):         p2 = points[1]         p3 = points[2]         #计算向量         vecp1p2 = Point(p2.x - p1.x,p2.y - p1.y)         vecp2p3 = Point(p3.x - p2.x,p3.y - p2.y)         #判断顺时针还是逆时针,顺时针面积为正,逆时针面积为负         vecMult = vecp1p2.x*vecp2p3.y - vecp1p2.y*vecp2p3.x         sign = 0         if(vecMult>0):             sign = 1         elif(vecMult < 0):             sign = -1         triArea = GetAreaOfTriangle(p1,p2,p3)*sign         area+=triArea     return abs(area) def GetAreaOfTriangle(p1,p2,p3):     '''计算三角形面积'''     area = 0     p1p2 = GetLineLength(p1,p2)     p2p3 = GetLineLength(p2,p3)     p3p1 = GetLineLength(p3,p1)     s = (p1p2 + p2p3 + p3p1)/2     area = s*(s-p1p2)*(s-p2p3)*(s-p3p1)     area = math.sqrt(area)     return area def GetLineLength(p1,p2):     '''计算边长'''     length = math.pow((p1.x-p2.x),2) + math.pow((p1.y-p2.y),2)     length = math.sqrt(length)     return length def main():     p1 = Point(1,1)     p2 = Point(2,1)     p3 = Point(2,2)     p4 = Point(1,2)     points = [p1,p2,p3,p4]     area = GetAreaOfPolyGon(points)     print(math.ceil(area))     assert math.ceil(area)==1 if __name__ == '__main__':     main()

python计算图形面积的方法_Python计算任意多边形面积算法相关推荐

  1. python计算图形面积的方法_python计算不规则图形面积算法

    https://www.xin3721.com/eschool/pythonxin3721/ 介绍:大三上做一个医学影像识别的项目,医生在原图上用红笔标记病灶点,通过记录红色的坐标位置可以得到病灶点的 ...

  2. python计算多边形的面积并保留两位小数_Python计算任意多边形面积算法

    多边形面积求解的方法很多,其中比较多见的就是增加一个点P,然后分别连接多边形各个定点与P点,然后计算每个三角形的符号面积(面积有正负之分),求和就可以计算出面积. 鉴于上面的方法,我们也可以用另外一种 ...

  3. 图形面积用计算机软件计算方法,CAD当中计算图形面积的方法有哪些?四种方法全交给你!...

    对于设计工作者或者是建筑工作者来说,日常使用CAD软件来设计图形是非常常见的事情.而如果你在平日里,想要学习CAD的2D和3D图形设计的话,那么AutoCAD 2020这款软件就非常适合使用,因为使用 ...

  4. vue+d3.js计算任意多边形面积

    效果图 代码 <!DOCTYPE html> <html lang="en"> <head><meta charset="UTF ...

  5. 已知三个点坐标求 三角形面积 || 求任意多边形面积公式||判断点在直线的左侧还是右侧

    已知三个点坐标求 三角形面积 由A-->B-->C-->A 按逆时针方向转.(行列式书写要求) 设三角形的面积为S 则S=(1/2)*(下面行列式) |x1 y1 1| |x2 y2 ...

  6. python计算多边形的面积并保留两位小数_计算任意多边形面积的Python实现

    最近需要实现一个计算非凸多边形面积的功能,需要输入是顺次排序的多边形顶点坐标,假设输入的多边形顶点是V={v0, v1, v2, -, vn-1},则多边形的边为E={, , ,...,, }.要求输 ...

  7. 计算任意多边形面积的Python实现

    最近需要实现一个计算非凸多边形面积的功能,需要输入是顺次排序的多边形顶点坐标,假设输入的多边形顶点是V={v0, v1, v2, -, vn-1},则多边形的边为E={<v0, v1>, ...

  8. python计算任意多边形面积

    看了一些方法网上的资料,也自己倒腾了一些想法. 然后看到这个大神的博客(<计算任意多边形的面积>),我就服气了. 我把代码转换为python: # 计算任意多边形的面积,顶点按照顺时针或者 ...

  9. python计算和差积商_Python计算股票投资组合的风险价值(VaR)

    原文链接:http://tecdat.cn/?p=17758​tecdat.cn 什么是风险价值(VaR)? 风险价值(VaR)用于尝试量化指定时间范围内公司或投资组合中的财务风险水平.VaR提供了一 ...

最新文章

  1. VC中的TRACE宏:
  2. 企业网络推广——企业网络推广专员浅析网站关键词优化要注意哪些问题
  3. 【Groovy】闭包 Closure ( 闭包调用 | 闭包默认参数 it | 代码示例 )
  4. leetcode 763. Partition Labels | 763. 划分字母区间(双指针)
  5. 年薪50万的Python架构师 不是梦
  6. Android开发学习笔记:浅谈Content Provider
  7. Android官方开发文档Training系列课程中文版:通知用户之更新或移除通知
  8. 从程序员到项目经理(9):程序员加油站 -- 再牛也要合群【转载】
  9. A summary of OpenGL ES 3.1 demos and samples
  10. 互联网架构设计漫谈 (6)-90%的架构师都知道的工作流原理
  11. linux得到低权shell,oracle低权限下获取shell
  12. 中国哌唑替芬行业市场供需与战略研究报告
  13. java se开发工具_JavaSE基础代码(1)-Hi ShanShi与开发工具
  14. Mysql中将查询出来的多列的值用逗号拼接
  15. linux 网卡驱动编译安装包,CDlinux网卡驱动的编译、安装、集成
  16. 中兴笔试题,求子区间元素运算后结果为0
  17. 适合女孩子玩的计算机游戏,小仙女们!NS上7款最适合女孩子玩的游戏盘点
  18. 基于C++的BNN推理
  19. android集成twitter登录
  20. PHP 全局变量 - 超全局变量

热门文章

  1. 坐标反算c语言程序,道路坐标正反算无限个拐点计算器测量程序(新20070825)
  2. 【万字干获】阿里妈妈搜索推荐广告预估模型2021思考与实践
  3. libevent 使用流程
  4. 跨盘LV整合及硬盘分区合并
  5. CVE-2015-1635-HTTP.SYS远程执行代码漏洞复现
  6. 社会管理网格化 源码_天津市红桥区社会治理网格化管理平台获CIO智选政务应用奖...
  7. 计算机电源改60v,晒晒我用电脑电源改的可调电源0-24V非常好用
  8. 2023校招C++开发oppo笔试
  9. android 服务自动运行怎么办,怎么解决安卓软件服务停止后又自启?
  10. IEEE论文公式快捷获取