将两个CGPoints转换为CGRect

问题描述 投票:21回答:6

我怎么能,给两个不同的CGPoints,把它们变成一个CGRect

例:

CGPoint p1 = CGPointMake(0,10);
CGPoint p2 = CGPointMake(10,0);

我怎么能把它变成CGRect

ios iphone core-graphics cgrect cgpoint
6个回答
48
投票

这将需要两个任意点,并为您提供将它们作为对角的CGRect。

CGRect r = CGRectMake(MIN(p1.x, p2.x), 
                      MIN(p1.y, p2.y), 
                      fabs(p1.x - p2.x), 
                      fabs(p1.y - p2.y));

与较小y值配对的较小x值将始终是rect的起源(前两个参数)。 x值之间的差值的绝对值将是宽度,y值之间的差值的绝对值将是高度。


9
投票

肯的​​回答略有修改。让CG Geometry为您标准化“矩形”。

CGRect rect = CGRectStandardize(CGRectMake(p1.x, p1.y, p2.x - p1.x, p2.y - p1.y));


4
投票

假设p1是原点而另一个点是矩形的对角,你可以这样做:

CGRect rect = CGRectMake(p1.x, p1.y,  fabs(p2.x-p1.x), fabs(p2.y-p1.y));

4
投票

此函数接受任意数量的CGPoints,并为您提供最小的CGRect。

CGRect CGRectSmallestWithCGPoints(CGPoint pointsArray[], int numberOfPoints)
{
    CGFloat greatestXValue = pointsArray[0].x;
    CGFloat greatestYValue = pointsArray[0].y;
    CGFloat smallestXValue = pointsArray[0].x;
    CGFloat smallestYValue = pointsArray[0].y;

    for(int i = 1; i < numberOfPoints; i++)
    {
        CGPoint point = pointsArray[i];
        greatestXValue = MAX(greatestXValue, point.x);
        greatestYValue = MAX(greatestYValue, point.y);
        smallestXValue = MIN(smallestXValue, point.x);
        smallestYValue = MIN(smallestYValue, point.y);
    }

    CGRect rect;
    rect.origin = CGPointMake(smallestXValue, smallestYValue);
    rect.size.width = greatestXValue - smallestXValue;
    rect.size.height = greatestYValue - smallestYValue;

    return rect;
}

1
投票

如果两个点在一条线上,这将返回宽度或高度为0的矩形

float x,y,h,w;
if (p1.x > p2.x) {
    x = p2.x;
    w = p1.x-p2.x;
} else {
    x = p1.x;
    w = p2.x-p1.x;
}
if (p1.y > p2.y) {
    y = p2.y;
    h = p1.y-p2.y;
} else {
    y = p1.y;
    h = p2.y-p1.y;
}

CGRect newRect = CGRectMake(x,y,w,h);

0
投票

Swift扩展:

extension CGRect {
    init(p1: CGPoint, p2: CGPoint) {
        self.init(x: min(p1.x, p2.x),
                  y: min(p1.y, p2.y),
                  width: abs(p1.x - p2.x),
                  height: abs(p1.y - p2.y))
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.