iOS开发 -手机屏幕适配的简单使用

我们先来看一张美工小姐姐提供的蓝湖图。

发现什么了吗?

设计尺寸750X1314是设备(物理)分辨率。其实美工是按照6/6s/7/8标准标注的图。因为6/6s/7/8的缩放因子是@2x,所以750/2X1314/2 == 375X667,就是我们6/6s/7/8手机的逻辑分辨率。

    //UI设计基准px  750x1314 转换为iphone使用的逻辑分辨率值为 375x667

    iphone型号                       尺寸           逻辑分辨率(point)          设备(物理)分辨率(px)         缩放因子           宽/高比

    iphone6/6s/7/8                 4.7                375x667                             750x1314                        @2x                  0.562

    iphone6p/6sp/7p/8p       5.5                414x736                              1242x2208                     @3x                  0.563

    iphoneX/xs/11pro            5.8                 375X812                             1125X2436                     @3x                  0.462

    iphoneXr/11                      6.1                 414x896                             828x1792                       @2x                  0.462

    iphoneXsMac/proMax    6.5                414x896                              1242x2688                    @3x                  0.462

    iphone12/12pro              6.1                  390x884                             1170x2532                     @3x                  0.462

    iphone12proMax           6.7                   428x926                             1284x2778                    @3x                  0.462

等比例缩放

先阅读下代码

//屏幕尺寸
#define LTX_SCREEN_WIDTH             [UIScreen mainScreen].bounds.size.width
#define LTX_SCREEN_HEIGHT            [UIScreen mainScreen].bounds.size.height
//宽高比例
#define LTX_WIDTH_SCALE(width)       (width/375.0)*LTX_SCREEN_WIDTH
#define LTX_HEIGHT_SCALE(height)     (height/667.0)*LTX_SCREEN_HEIGHT
// 是否是刘海屏
#define IS_iPhoneXSeries                 (LTX_SCREEN_HEIGHT >= 780 ? YES : NO)
// 顶部安全区域
#define LTX_SAVEAREA_TOP                 (IS_iPhoneXSeries ? 24.0f : 0.0f)
//状态栏高度
#define LTX_STATUS_HEIGHT            [[UIApplication sharedApplication] statusBarFrame].size.height
// 导航栏高度
#define LTX_NAVBAR_HEIGHT                44.0f
//导航栏+状态栏高度
#define LTX_TOP_HEIGHT               (LTX_STATUS_HEIGHT+44)
//底部安全区域  工具栏底部 距离底部高度
#define LTX_SAFE_BOTTOM              (([[UIScreen mainScreen] bounds].size.height-780) ? 0 : 43)
//tabbar高度
#define LTX_TABBAR_HEIGHT                (IS_iPhoneXSeries ? 83.0f : 49.0f)

//不同屏幕尺寸字体适配
#define LTX_FONTSIZE_SCALE(R)     [UIFont systemFontOfSize:LTX_WIDTH_SCALE(R)]

以375/667为基准,采取等比例缩放。

1,文字

    label.font = LTX_FONTSIZE_SCALE(16);

如果在6/6s/7/8手机上字体大小是16pt,那么在6p/6sp/7p/8p上显示的字体大小就是17.6pt;在X/xs/11pro上显示的字体大小是16pt;在Xr/11/XsMac/proMax 上显示的字体大小就是17.6pt。

2,图片

    self.redView = [[RedView alloc] initWithFrame:CGRectMake(100, 100, LTX_WIDTH_SCALE(86*2), LTX_WIDTH_SCALE(88*2))];
    self.redView.layer.contents = (__bridge id)[UIImage imageNamed:@"2"].CGImage;
    [self.view addSubview:self.redView];

3,间距,使用Masonry自动布局。使用 LTX_WIDTH_SCALE(width) / LTX_HEIGHT_SCALE(height) 比例布局。

最简单的适配方案。

跟新

1.,375X812

// 适配小屏手机
NS_INLINE CGFloat AValueAfterScale(CGFloat value)
{
    if (AUIsPad()) {
        return value;
    }
    
    CGFloat minFactor = MIN([UIScreen mainScreen].bounds.size.width / 375, [UIScreen mainScreen].bounds.size.height / 812);
    return value * minFactor;
}

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iOS开发中上传图片可以采用以下步骤: 1.选择要上传的图片,可以使用系统提供的UIImagePickerController控制器,或者使用第三方库,例如TZImagePickerController。 2.将选中的图片转换为NSData格式。 3.使用NSURLSession或AFNetworking等网络库,将图片数据上传到服务器。 以下是一个简单的上传图片的示例代码: ``` // 选择图片 UIImagePickerController *imagePicker = [[UIImagePickerController alloc] init]; imagePicker.sourceType = UIImagePickerControllerSourceTypePhotoLibrary; imagePicker.delegate = self; [self presentViewController:imagePicker animated:YES completion:nil]; // 将选中的图片转换为NSData格式 - (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary<UIImagePickerControllerInfoKey,id> *)info { UIImage *selectedImage = info[UIImagePickerControllerOriginalImage]; NSData *imageData = UIImageJPEGRepresentation(selectedImage, 0.5); // 上传图片到服务器 NSURLSessionConfiguration *configuration = [NSURLSessionConfiguration defaultSessionConfiguration]; NSURLSession *session = [NSURLSession sessionWithConfiguration:configuration]; NSURL *url = [NSURL URLWithString:@"http://example.com/upload.php"]; NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url]; request.HTTPMethod = @"POST"; NSURLSessionUploadTask *uploadTask = [session uploadTaskWithRequest:request fromData:imageData completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) { // 处理服务器返回的响应 }]; [uploadTask resume]; [picker dismissViewControllerAnimated:YES completion:nil]; } ``` 其中,upload.php是服务器端接收图片的脚本文件。在服务器端,可以使用PHP等语言来处理上传的图片数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值