Android仿天眼查人物关系图

效果图预览

绘制思路

这里使用了中学解析几何知识 XPoint = OPointX = OPointXcosθ; YPoint = OPointY = OPointYsinθ;

canvas.drawText(lists.get(i).getName(), XPoint + (float) Math.cos(pere * i + 5) * radius[i % radius.length] - 30, YPoint + (float) Math.sin(pere * i + 5) * radius[i % radius.length] + 35, paint);

用法

1、XML布局(PS要根据自己的包名) <com.gkzy.relation.CirclePeopleView
   android:id="@+id/layout_cricle_people"
   android:layout_width="match_parent"
   android:layout_height="280dp"
   app:layout_constraintBottom_toBottomOf="parent"
   app:layout_constraintLeft_toLeftOf="parent"
   app:layout_constraintRight_toRightOf="parent"
   app:layout_constraintTop_toTopOf="parent" />
  
       
2.  peopleView = findViewById(R.id.layout_cricle_people);

3. 添加数据,刷新UI peopleView.SetFieldInfo(lists);
   peopleView.invalidate();
   
   
4.添加了view的点击事件,通过手势判断。原理:
每个圆的Cx,Cy,r都能获取到,然后通过已知数据计算RectF的
 left,  top,  right,  bottom
  /**
    * Create a new rectangle with the specified coordinates. Note: no range
    * checking is performed, so the caller must ensure that left <= right and
    * top <= bottom.
    *
    * @param left   The X coordinate of the left side of the rectangle
    * @param top    The Y coordinate of the top of the rectangle
    * @param right  The X coordinate of the right side of the rectangle
    * @param bottom The Y coordinate of the bottom of the rectangle
    */
   public RectF(float left, float top, float right, float bottom) {
       this.left = left;
       this.top = top;
       this.right = right;
       this.bottom = bottom;
   }
   
   得到RectF后判断contains(x,y)来获得点击的位置

项目源码:GitHub - chenhua1008611/Co-People: 仿天眼查关系图的生成,自定义view,随机颜色,随机大小

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-12 00:28:02       66 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-12 00:28:02       70 阅读
  3. 在Django里面运行非项目文件

    2024-07-12 00:28:02       57 阅读
  4. Python语言-面向对象

    2024-07-12 00:28:02       68 阅读

热门阅读

  1. C++ 定时器触发

    2024-07-12 00:28:02       24 阅读
  2. SqlSugar分表笔记

    2024-07-12 00:28:02       25 阅读
  3. 模板语法指令语法——02

    2024-07-12 00:28:02       21 阅读
  4. LeetCode 算法:实现 Trie (前缀树) c++

    2024-07-12 00:28:02       21 阅读
  5. 周报 | 24.7.1-24.7.7文章汇总

    2024-07-12 00:28:02       20 阅读
  6. httpclient访问https请求报错处理

    2024-07-12 00:28:02       19 阅读
  7. 力扣---41. 缺失的第一个正数

    2024-07-12 00:28:02       23 阅读
  8. 微信小程序之使用上拉加载实现图片懒加载

    2024-07-12 00:28:02       24 阅读