我在Photoshop中创建了一个图像,我希望在iPad应用程序中将其用作信息屏幕的背景。该图像还包含文本和一些图标。在图像周围,我有一个绿色的边框。
我想要达到的效果是:
当用户从纵向朝向横向时,我想让图像(只是框架和图标)旋转90度,使图像以横向模式显示,而不是在横向上显示框架的纵向视图。文本和图标是分离的(我在不同的UIImageView中组织的不同层)它们将旋转90度。
我已经完成的工作如下:
使用此方法进行了一些实验:
- (void)willAnimateRotationToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation duration:
并尝试这样做:
self.btnFacebook.transform = CGAffineTransformMakeRotation(1.5707964);
我认为它会将btnFacebook属性向右旋转90度(如果我错了,请纠正我)因为它指定了正弧度。我似乎无法让它正常工作。难道这不能将按钮绕框架中心坐标旋转90度吗?这不会导致按钮位置发生变化(按钮是正方形)?
制作图片:
由于图像显示图像背景(其上的一些自定义图形在两个方向看起来都很好)从纵向到横向并旋转,因此在横向上不显示为肖像,图标与背景分离,因此需要也可以旋转,因为它们需要处于正确的方向(这是社交图标)。然而,文本位于相同的位置,它只旋转90度而不重新定位。
答案 0 :(得分:21)
我理解您的问题是因为您试图不要将界面整体旋转,而是单独旋转紫色和红色方块。
我创建了一个类似于你的布局的UIViewController
。
黑色正方形是一个UIView,白色正方形只有这样我才能知道黑色视图何时旋转。此视图连接到控制器上的view1
属性。
有4个按钮连接到btnx
(x运行1到4)属性。
由于我不想再自动旋转界面,我只支持纵向方向。
- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
// Return YES for supported orientations
return (interfaceOrientation == UIInterfaceOrientationPortrait);
}
为了手动进行旋转,我向ViewController添加了一个方法。它确定将组件从纵向旋转到当前方向所需的角度,创建旋转变换并将其应用于所有出口。
- (void)deviceDidRotate:(NSNotification *)notification
{
UIDeviceOrientation currentOrientation = [[UIDevice currentDevice] orientation];
double rotation = 0;
UIInterfaceOrientation statusBarOrientation;
switch (currentOrientation) {
case UIDeviceOrientationFaceDown:
case UIDeviceOrientationFaceUp:
case UIDeviceOrientationUnknown:
return;
case UIDeviceOrientationPortrait:
rotation = 0;
statusBarOrientation = UIInterfaceOrientationPortrait;
break;
case UIDeviceOrientationPortraitUpsideDown:
rotation = -M_PI;
statusBarOrientation = UIInterfaceOrientationPortraitUpsideDown;
break;
case UIDeviceOrientationLandscapeLeft:
rotation = M_PI_2;
statusBarOrientation = UIInterfaceOrientationLandscapeRight;
break;
case UIDeviceOrientationLandscapeRight:
rotation = -M_PI_2;
statusBarOrientation = UIInterfaceOrientationLandscapeLeft;
break;
}
CGAffineTransform transform = CGAffineTransformMakeRotation(rotation);
[UIView animateWithDuration:0.4 delay:0.0 options:UIViewAnimationOptionBeginFromCurrentState animations:^{
[self.btn1 setTransform:transform];
[self.btn2 setTransform:transform];
[self.btn3 setTransform:transform];
[self.btn4 setTransform:transform];
[self.view1 setTransform:transform];
[[UIApplication sharedApplication] setStatusBarOrientation:statusBarOrientation];
} completion:nil];
}
最后要做的是让操作系统调用我的方法。为此,我将以下代码添加到AppDelegate中的application:didFinishLaunchingWithOptions:
。
[[UIDevice currentDevice] beginGeneratingDeviceOrientationNotifications];
[[NSNotificationCenter defaultCenter] addObserver:self.viewController selector:@selector(deviceDidRotate:) name:UIDeviceOrientationDidChangeNotification object:nil];
我不确定这是否正是您想要的,但我相信它至少是相似的,所以您可以从中获得一些想法如何解决您的问题。我可以为我创建的工作iPad应用程序提供源代码来说明这一点。