当前位置: 首页 > news >正文

电子商务网站策划书3000字沧州做网站

电子商务网站策划书3000字,沧州做网站,wordpress音乐列表,网站建设交流会原文链接 - iOS 开发一定要尝试的 Texture(ASDK)(排版正常, 包含视频) 前言 本篇所涉及的性能问题我都将根据滑动的流畅性来评判, 包括掉帧情况和一些实际体验 ASDK 已经改名为 Texture, 我习惯称作 ASDK 编译环境: MacOS 10.13.3, Xcode 9.2 参与测试机型: iPhone 6 10.3.3, i… 原文链接 - iOS 开发一定要尝试的 Texture(ASDK)(排版正常, 包含视频) 前言 本篇所涉及的性能问题我都将根据滑动的流畅性来评判, 包括掉帧情况和一些实际体验 ASDK 已经改名为 Texture, 我习惯称作 ASDK 编译环境: MacOS 10.13.3, Xcode 9.2 参与测试机型: iPhone 6 10.3.3, iPhone 7 11.2.1, iPhone X 11.2.5, 默认 iPhone 6 TableView / TableNode 包含的 TableViewCell / CellNode: 默认复杂程度一般, 包含 1~2 张图片和 2~4 条文本展示, 图片有圆角 列表滑动卡顿的原因及优化 大牛们把原因都说的很清楚了, 导致的结果就是 16ms 不足以渲染一帧, 产生掉帧卡顿 下面是尝试过的一些优化: 圆角 使用一张圆角图片覆盖, 经典文章 Corner Rounding, HYBImageCliped 也是这么做的 异步裁剪图片: 通过 UIGraphics 对图片进行裁剪, 可能造成内存暴涨行高缓存 老生长谈了, 除 UITableView-FDTemplateLayoutCell 之外, QMUI 中也有提供一套缓存行高方案 数据预加工 具体是在 JSON 转 Model 后把文本转为富文本, 处理一些弱逻辑等, 之后赋值就可以直接展示了 咳咳, 这个感觉不到什么效果 图形预加工 例如处理图片遮罩或固定的图标, 一般是直接使用多层视图实现 我曾尝试把三张小图绘制到一张大图上再进行展示, 于是乎, 异步复用问题除外, 内存炸了, 最终还是老老实实用多个视图实现 为什么要使用 ASDK 图形异步渲染 通常我们认为 UIKit 是不能渲染于非主线程的, 一旦你这么做, 就可能会导致崩溃, 无法正常显示等问题, 而 ASDK 为什么可以呢, 因为 ASDisplayNode 是线程安全的, Node 创建时, 不会立即在其内部新建 UIView 和 CALayer, 直到主线程第一次访问时才会生成对应的对象, 除此之外, 还通过图层预合成和基于 Runloop 的异步并发, 使其拥有更好的性能 ASAsyncTransactionGroup 这个特点带来的相关实际体验就是: 安心的进行异步绘图, 如圆角裁剪, 增加遮罩等, 这在 UIKit 中是足以毁灭人生的, 内存暴涨, 异步复用, 性能极差 不过低性能设备下还是会出现明显空白 视频链接 预加载数据和对象 首先来一张 Gif 体验一下, 实际上使用 ASDK 开发完成后对比也是如此, 有种网速变快了的错觉 ASDK 中的 ASRangeController, ASTableView, ASCollectionView 相对于 UIKit 原生控件的特点是可用于监控视图的可见区域, 维护工作区域, 在合适的时机触发网络请求以及绘制, 单元格的异步布局 这里推荐阅读: 预加载与智能预加载iOS 异于原生控件的复用机制 单一的 Cell 意思是某个 List 展示的样式只有一种, TableView 只需要注册一个 Cell 这种情况下, 如果常规的一些优化得当, 滚动的流畅性还是可以接受的(与 ASDK 差距微小, 但仍然肉眼可分辨) 此时的差距主要体现在列表某项数据第一次展示, 以及 TableView 在分页加载时产生的等待较长, 当然, 这两点也是可以继续优化和解决的 相反的, 也就是来回滑动已经展示过的数据, 两者的差距就非常小了, 大概是 59.7 - 59.9 和 59.9 的区别 (我瞎扯的) 综上, 优化得当的情况下, 单一的 Cell 情况下 UIKit 与 ASDK 的差距不明显 视频链接 多种 Cell 表示某 List 中有多种不同的样式, TableView 必须要通过注册 N 个 Cell 来实现 这种情况下, 假设有 5 种 Cell, 屏幕可同时展示 6 条 Cell, 此时若第一屏幕刚好展示的就包含全部 5 种 Cell , 那么后续的滑动情况将与单一的 Cell表现一致, 若第一屏幕展示的内容只包含一种, 其他 4 种没有在屏幕上出现过, 那么当某一种首次出现在屏幕上时, 便会出现明显的卡顿; 我尝试过解决这个问题, 提前创建所有的 Cell 实例对象, 缓存和复用相同的子视图, 异步预绘制为一张图片并缓存(坑), 都收效渐微 因 ASDK 支持预渲染, 与处理单种 Cell 没有区别, 依旧 59.9 复用的差别 TableView 的复用机制我是既爱又恨的, 方便之处在于直接与数据绑定后, 可以方便的更新和修改, 只需保证 setModel 简洁就 OK, 只是当业务绑定较多时就比较麻烦了 下面重点说说 TableNode, TableNode 的复用机制就是没有复用, 只有缓存, 每个 CellNode 都是全新的, 因此会有一些特殊的地方: CellNode 与数据源没有绑定关系: 创建后就算把数据源删除, TableNode 依然可以正常展示 数据直接决定要创建一个怎样的 CellNode: 这一点很重要, TableViewCell 的展示大致为: 添加空假数据子视图 - 数据填充 - 刷新, 涉及布局或图文时会更复杂 CellNode 只有一步: 添加真数据的子视图; 因此可以直接根据业务逻辑对控件和布局做出处理, 而不用一次或多次刷新 Demo: 此处需求为每组一个大图 N个小图, 每组 3 或 5 个 解决思路: TableView 的方式是创建 5 个, 根据数量显隐下面两个, 或者两种 Cell, 把 3 和 5 的情况分别对应, 除此之外, 最重要的是: 祈祷数据正常, 每组数据个数仅为 3 或 5 此时若使用 TableNode 就灵活多了, 可以根据需要(数据个数), 加入需要的子视图, 我的思路是把顶部的大图固定, 剩下的两个为一行进行添加, 就算总数为偶数也是没有任何额外消耗的, 具体参见 ASDKDemo 视频链接 Flex 布局 值得学习的理由 ASDK 使用的是 Flex 布局, 且面向对象 偷一张图 具体对比: iOS 上的 FlexBox 布局 简单来说, 缺点只有一个, 就是学习曲线相对 Frame AutoLayout 更陡峭, 而优点是 性能与 Frame 相当, 上手后比 AutoLayout 还简单, 如果你已经开始尝试, 请坚持下去 不同的方式和思想 AutoLayout 使用 AutoLayout 时我心里想的无外乎: 我要把你放在左上角: Left Top把你放在它右边: LeftTo(它)放中间: Center至少/至多离它多远: less / greater缺点是视图之间的依赖性太强, 可读性维护性较差(更差的是 Frame), 例如排列数个距离不等控件, 就会很厌烦, 然后 cv 重复代码; 处理多个多行文本垂直排列时很恶心, 想要处理好最终需要去计算文字行高, 外加入自定行间距; ... Flex 例如 Demo 中的img srchttps://img.didee.cn/imgs/201...; width300/ 我做的事情是: 声明大图的比例: Ratio(9.0/16.0); 那么这个声明存储为 postImageRatioSpec 声明大标题的内边距: Inset(8, 8, 8, 8); titleInsetSpec 声明 titleInsetSpec 的位置是垂直方向下的最尾部; titleRelativeSpec 声明 titleRelativeSpec 是覆盖到 postImageRatioSpec 上: titleOverlaySpec 此时大图和文字布局完成 接下来是用户栏: 声明用户头像和名称水平排列, 水平方向从左也就是从头部开始, 距离 4, 对齐方式为居中, 此时的居中为垂直方向; leftStackSpec 同理, 声明两个图标为水平, 尾部起始, 距离4, 居中; rightStackSpec 接下来, 声明 leftStackSpec 和 rightStackSpec 水平排列, 等间距排列填充(实际是为 left 和 rightStack 进行填充), 距离 8, 对齐方式填充(无实际作用, 由于子视图同为 Stack 且都是水平方向); userStackSpec 最后: 声明 titleOverlaySpec 和 userStackSpec 垂直排列, 自上而下, 对齐方式填充(同理于userStackSpec, 此处影响的是 userStackSpec); videoStackSpec 声明 videoStackSpec 的内边距: Inset(16, 16, 0, 16); videoInsetSpec 特别注意 userStackSpec 和 videoStackSpec, StackSpec 多层叠加后, 父子间是存在影响的, 我在使用中也感觉比较奇怪, 具体需要自行尝试体会.. 具体实现代码: VideoCellNode.m , UserNode.m 相关链接 (不分先后) 文章 iOS性能优化探讨 AsyncDisplayKit 系列教程 —— 为什么要使用 AsyncDisplayKit 新大陆AsyncDisplayKit iOS 保持界面流畅的技巧 Texture-Resources (EN 推荐) Getting-Started 入门教程之一 Texture 布局篇 视频 AsyncDisplayKit State of the Code (WWDC 2016) Demo 包含无限滚动和不定子视图的 Demo ASDKDemo 官方示例 Texture Examples 线上项目 AppStore 耐飞视频
http://www.sadfv.cn/news/248937/

相关文章:

  • 做网站的上市公司有哪些东至网站制作
  • 网站开发前台企业网站程序下载
  • 网络公司网站报价网站建设电脑端手机端
  • 邯郸网站开发定制龙岗区网络科技有限公司
  • 全面的聊城网站建设jf厂高仿手表网站
  • 短租网站建设推动高质量发展要坚持
  • 常州网站建设套餐夸克免费空间
  • ajax网站模板怎样做视频电影网站
  • 专业建设网站建站杭州哪家做外贸网站
  • 个人网站的设计与实现结论什么网站可以制作套餐
  • google帐户登录网站如何做的某些网页打不开是什么原因
  • 河北区做网站公司临沧网站开发
  • 北京云主机网站源码推荐聊城网站建设
  • 深圳网站建站建设公司地址品牌建设途径
  • 做电商网站的步骤企业网站建设浩森宇特
  • 建设一个网站的规划在vs2010里怎么做网站
  • 一个大学网站做的好坏于否的标准做代理记账网站
  • DW自动生成代码做网站网站备案上海
  • 宁波专业定制网站建设网站做标准曲线
  • 深圳响应式网站建设移动互联网营销
  • 企业网站建设用什么营销网站建设的价格
  • 做视频点播网站如何赚钱免费下载app
  • 湖南移动官网网站建设郑州网站加工
  • 西部数码网站助手网页游戏排行榜电脑
  • 龙岩建设局招聘网站wordpress如何撤销301
  • .net网站开发免费教程免费网站收录入口
  • 海珠做网站公司怎样创建网页
  • 永久免费网站建设大概多少钱江门网站推广公司
  • 增加网站和接入备案wordpress系统教程
  • 网站优化 月付费办公室内网怎么搭建局域网