zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    C#TreeView 添加 右键快捷菜单
    Zlib Usage
    C3499 a lambda that has been specified to have a void return type cannot return a value
    Question Need to Find out
    C++ wstring转string
    C# TabPage隐藏问题
    设置IIS支持INI文件下载
    SQL SERVER CTE查询
    compression format and tools
    C++11的for循环,以及范围Range类的实现
  • 原文地址:https://www.cnblogs.com/qqcc1388/p/14339328.html
Copyright © 2011-2022 走看看