首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    深入详解iOS适配技术

    iPhone自诞生以来,随着其屏幕尺寸不断的多样化,屏幕适配的技术一直在发展更新。目前,iOS系统版本已经更新到9.3,XCode的最新版本已经是7.3,仅iPhone历史产品的尺寸就已经有4种:3.5英寸、4.0英寸、4.7英寸、5.5英寸。最近,iPhone家族又诞生一款iPhoneSE,鉴于这款iPhoneSE的屏幕尺寸和iPhone5S的尺寸一模一样——同样是4.0英寸,广大iOS开发者可算是松了口气,不然iOS的屏幕尺寸真的是越来越让人眼花缭乱。 按照时间顺序,屏幕适配是这样发展的:纯代码计算frame-> autoresizing(早期进行UI布局的技术,仅适用于约束父子控件之间的关系)->AutoLayout(iOS6/2012年、iPhone5被引入,比autoresizing更加高级,旨在替代autoresizing,可以设置任何控件之间的关系)->sizeClass(iOS8出现,用于解决越来越多的屏幕尺寸的适配问题)。 在iPhone3gs时代,手机的屏幕尺寸有且只有一种,也就是3.5英寸。开发app的时候,根本不用考虑同一个视图在不同尺寸的屏幕上显示的问题。iOS开发者完全可以用纯代码的方式把一个控件的frame写死。 后来apple公司推出了4.0英寸的iPhone5和iPhone5S,所以,针对于不同尺寸的屏幕,再把控件的frame写死就不可取了。(其实也不是不可取,很多iOS开发者做屏幕适配的时候不是用的autoresizing或autolayout,而是以代码的方式动态获取屏幕的尺寸,然后根据屏幕的尺寸来写死子控件的frame。使用这种方式你会在代码中无辜增加很多if...else... 的条件判断语句。另一种方式是获取到屏幕的尺寸后,按照控件和屏幕的比例来设置控件的frame,其本质上也是写死frame。所以这两种方式都不可取,毕竟将来会回出现越来越多的屏幕尺寸。从开发的角度,重复繁琐的代码会牵绊住开发者的进度;从程序设计角度,这样的设计思路不够高级,且日后不易于拓展和维护。)

    07

    Install Jumpserver49

    luna/OpenSans-LightItalic.6725fc490942895a65f5.eot luna/OpenSans-LightItalic.b64e9910811cdcc8df89.svg luna/OpenSans-Regular.ac327c4db6284ef64ebe.woff luna/OpenSans-Light.963eb32907744d9a0d6b.woff luna/OpenSans-LightItalic.e7cc7120e670a8073073.woff2 luna/OpenSans-SemiboldItalic.3343e54368719e3786f7.woff2 luna/OpenSans-BoldItalic.c36b5ac7c2dddf6f525c.ttf luna/OpenSans-BoldItalic.ea07932c5245dd421e3d.eot luna/OpenSans-Regular.cd7296352d159532b66c.ttf luna/OpenSans-ExtraBoldItalic.5f467e780ed0aead6614.eot luna/OpenSans-ExtraBold.19b56cfcb97fbcc24524.ttf luna/fontawesome-webfont.b06871f281fee6b241d6.ttf luna/OpenSans-LightItalic.97534dd409492b05b11a.woff luna/OpenSans-Semibold.0ea04502930623aa3de1.eot luna/OpenSans-SemiboldItalic.da061416028fc9a66fbc.eot luna/OpenSans-LightItalic.26f1e68dfbd8b8621e5d.ttf luna/OpenSans-Light.804037562eabaa5dbefa.eot luna/theme/ luna/static/ luna/MaterialIcons-Regular.570eb83859dc23dd0eec.woff2 luna/OpenSans-Regular.f641a7d4e80fd6321135.svg luna/OpenSans-Italic.9b30f13428e1b4a659ae.ttf luna/OpenSans-ExtraBoldItalic.bc511bacf828ac9e833e.woff2 luna/OpenSans-SemiboldItalic.ddc348f204283c4f4090.svg luna/OpenSans-ExtraBold.561e4b63e9119235465e.eot luna/OpenSans-ExtraBoldItalic.9704305e6fd8184b40d5.svg luna/OpenSans-Light.d79f021974b1f6bc5c21.svg luna/OpenSans-Bold.3326e4d74d3924ee1c88.woff2 luna/main.a3c75c0a3047ed1eef01.bundle.js luna/OpenSans-Italic.d6671d41dde41d355619.svg luna/OpenSans-ExtraBold.5211065d7cf88c28086d.woff2 luna/OpenSans-Bold.5a100916f94b0babde0c.ttf luna/OpenSans-Bold.7ae9b8ba7886341831bf.eot luna/scripts.56fb3235bc9c0e75506e.bundle.js luna/i18n/ luna/fontawesome-webfont.fee66e712a8a08eef580.woff luna/inline.6602a1f82e32b48c37e4.bundle.js luna/OpenSans-Regular.55835483c304eaa8477f.woff2 luna/data-table.b0aebd744ce7adb780a9.svg luna/OpenSans-Italic.525074686dfb8aa36b1b.woff luna/MaterialIcons-Regular.012cf6a10129e2275d79.woff luna/MaterialIcons-Regular.a37b0c01c0baf1888ca8.ttf luna/i18n/zh.json luna/i18n/cn.json luna/i18n/zh-CN.json luna/static/imgs/ luna/static/imgs/inspi

    02
    领券