• iOS/flutter LaunchImage启动图尺寸适配


    在iOS开发早期,启动图适配,可以通过自定义LaunchImage通过设置多张图片来实现通过尺寸的适配,2020年4月开始,所有使用iOS 13 SDK 的App都必须提供 LaunchScreen

    如果使用LaunchScreen一张图来适配所有尺寸的iPhone是一定不够的,不同程度的拉伸是不可避免的,那么针对这种,要如果和适配呢

    方法1. LaunchScreen中写自定义布局,把LaunchScreen当做一个页面,里面不仅仅可以放图片,也来用来放其他view,这样,重新布局,来实现我们想要的启动页就很容易实现了,这种也是官方推荐的方法

    方法2.仍然使用类似于LaunchImage的方法来实现,通过配置多张图片的方式,来达到多图适配的问题。该方法是经过测试确实可用,该方法对flutter项目中的iOS工程一样有效
    1.在Assets.xcasset中新建一个Image Set,并配置
    2.拷贝如下json内容到Contents.json中,并配置尺寸的图片到指定位置,设置只支持iPhone图片,【iPad设置了好像不生效】

    {
      "images" : [
        {
          "filename" : "1125x2436.png",
          "idiom" : "iphone",
          "scale" : "1x"
        },
        {
          "filename" : "640x960.png",
          "idiom" : "iphone",
          "scale" : "2x"
        },
        {
          "filename" : "1125x2436.png",
          "idiom" : "iphone",
          "scale" : "3x"
        },
        {
          "filename" : "640x1136.png",
          "idiom" : "iphone",
          "scale" : "1x",
          "subtype" : "retina4"
        },
        {
          "filename" : "640x1136.png",
          "idiom" : "iphone",
          "scale" : "2x",
          "subtype" : "retina4"
        },
        {
          "filename" : "640x1136.png",
          "idiom" : "iphone",
          "scale" : "3x",
          "subtype" : "retina4"
        },
        {
          "filename" : "1242x2208.png",
          "idiom" : "iphone",
          "scale" : "3x",
          "subtype" : "736h"
        },
        {
          "filename" : "750x1334.png",
          "idiom" : "iphone",
          "scale" : "2x",
          "subtype" : "667h"
        },
        {
          "filename" : "1125x2436.png",
          "idiom" : "iphone",
          "scale" : "3x",
          "subtype" : "2436h"
        },
        {
          "filename" : "1242x2688.png",
          "idiom" : "iphone",
          "scale" : "3x",
          "subtype" : "2688h"
        },
        {
          "filename" : "828x1792.png",
          "idiom" : "iphone",
          "scale" : "2x",
          "subtype" : "1792h"
        }
      ],
      "info" : {
        "author" : "xcode",
        "version" : 1
      }
    }
    
    

    设置完成后将模拟器中的app删除,并且重启模拟器,你会发现,设置的启动图已经生效了,使用这种方式确实能节省不少事情,对一些背景全屏的的启动图,使用LaunchScreen怎么布局都会出现一定的拉伸情况

    更多使用细节,请参考如下文章
    参考来源:

    https://www.jianshu.com/p/e1475261d2f9
    https://juejin.cn/post/6844904040132771847
    https://www.jianshu.com/p/ef5f877b2412

  • 相关阅读:
    php安全模式笔记
    ./configure,make,make install的作用(转)
    composer自动载入类库的方式
    Specified key was too long; max key length is 1000 bytes
    海量数据中找出前k大数(topk问题)
    斐波那契数列n项的值。(递归和非递归算法Golang实现)
    基于Docker和Golang搭建Web服务器
    Nginx简单介绍以及linux下使用Nginx进行负载均衡的搭建
    php实现商城秒杀
    一致性hash (PHP)
  • 原文地址:https://www.cnblogs.com/qqcc1388/p/14339328.html
Copyright © 2020-2023  润新知