如果我理解正确,您需要以下内容:
data:image/s3,"s3://crabby-images/4c012/4c012a8e30c45f70d888eec91965a5133a6456a7" alt="最终视图"
为了简化您的计算,您需要anchorPoint
使用CALayer
. 这anchorPoint
是应用变换的地方,它的效果在旋转中特别明显。我们要做的是告诉CALayer
围绕它的一个点旋转,而不是中心(这是默认值)。
这是我的loadView
:
UIView *view = [[UIView alloc] initWithFrame:[UIScreen mainScreen].applicationFrame];
view.backgroundColor = [UIColor whiteColor];
CGRect frame = CGRectMake(view.frame.size.width - 100.f,
view.frame.size.height / 2.f - 50.f,
100.f, 100.f);
UIView *red = [[UIView alloc] initWithFrame:frame];
red.backgroundColor = [UIColor redColor];
[view addSubview:red];
CATransform3D rotation = CATransform3DIdentity;
rotation.m34 = -1.0/500.0;
// Since the anchorPoint is displaced from the center, the position will move with
// it, so we have to counteract it by translating the layer half its width.
rotation = CATransform3DTranslate(rotation, 50.f, 0, 0);
rotation = CATransform3DRotate(rotation, 50.0 * M_PI / 180, 0.0, 1.0, 0.0);
// We tell the anchorPoint to be on the right side of the layer (the anchor point
// position is specified between 0.0-1.0 for both axis).
red.layer.anchorPoint = CGPointMake(1.f, 0.5f);
red.layer.transform = rotation;
red.layer.zPosition = 200;
我得到的是你在上面看到的图像。
希望能帮助到你!