溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android開發(fā)如何實現(xiàn)幾何圖形工具類GeometryUtil

發(fā)布時間:2021-07-10 10:18:01 來源:億速云 閱讀:182 作者:小新 欄目:移動開發(fā)

這篇文章主要介紹Android開發(fā)如何實現(xiàn)幾何圖形工具類GeometryUtil,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

具體如下:

package com.android.imooc.goo;
import android.graphics.PointF;
/**
 * 幾何圖形工具
 */
public class GeometryUtil {
  /**
   * As meaning of method name. 獲得兩點之間的距離
   *
   * @param p0
   * @param p1
   * @return
   */
  public static float getDistanceBetween2Points(PointF p0, PointF p1) {
    float distance = (float) Math.sqrt(Math.pow(p0.y - p1.y, 2) + Math.pow(p0.x - p1.x, 2));
    return distance;
  }
  /**
   * Get middle point between p1 and p2. 獲得兩點連線的中點
   *
   * @param p1
   * @param p2
   * @return
   */
  public static PointF getMiddlePoint(PointF p1, PointF p2) {
    return new PointF((p1.x + p2.x) / 2.0f, (p1.y + p2.y) / 2.0f);
  }
  /**
   * Get point between p1 and p2 by percent. 根據(jù)百分比獲取兩點之間的某個點坐標
   *
   * @param p1
   * @param p2
   * @param percent
   * @return
   */
  public static PointF getPointByPercent(PointF p1, PointF p2, float percent) {
    return new PointF(evaluateValue(percent, p1.x, p2.x), evaluateValue(percent, p1.y, p2.y));
  }
  /**
   * 根據(jù)分度值,計算從start到end中,fraction位置的值。fraction范圍為0 -> 1
   *
   * @param fraction
   * @param start
   * @param end
   * @return
   */
  public static float evaluateValue(float fraction, Number start, Number end) {
    return start.floatValue() + (end.floatValue() - start.floatValue()) * fraction;
  }
  /**
   * Get the point of intersection between circle and line. 獲取
   * 通過指定圓心,斜率為lineK的直線與圓的交點。
   *
   * @param pMiddle
   *      The circle center point.
   * @param radius
   *      The circle radius.
   * @param lineK
   *      The slope of line which cross the pMiddle.
   * @return
   */
  public static PointF[] getIntersectionPoints(PointF pMiddle, float radius, Double lineK) {
    PointF[] points = new PointF[2];
    float radian, xOffset = 0, yOffset = 0;
    if (lineK != null) {
      radian = (float) Math.atan(lineK);
      xOffset = (float) (Math.sin(radian) * radius);
      yOffset = (float) (Math.cos(radian) * radius);
    } else {
      xOffset = radius;
      yOffset = 0;
    }
    points[0] = new PointF(pMiddle.x + xOffset, pMiddle.y - yOffset);
    points[1] = new PointF(pMiddle.x - xOffset, pMiddle.y + yOffset);
    return points;
  }
}

以上是“Android開發(fā)如何實現(xiàn)幾何圖形工具類GeometryUtil”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI