设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 文件
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

揭秘!如何用Flutter设计一个100%准确的埋点框架?(2)

发布时间:2019-08-12 12:48 所属栏目:21 来源:兰昊
导读:那么我们的问题就是如何算出坑位在屏幕内曝光面积的比例。要算出这个值,需要知道以下几个数值: 容器相对屏幕的偏移量 坑位相对容器的偏移量 坑位的位置和宽高 容器的位置和宽高 其中坑位和容器的宽和高很容易获取

那么我们的问题就是如何算出坑位在屏幕内曝光面积的比例。要算出这个值,需要知道以下几个数值:

  • 容器相对屏幕的偏移量
  • 坑位相对容器的偏移量
  • 坑位的位置和宽高
  • 容器的位置和宽高

其中坑位和容器的宽和高很容易获取和计算,这里就不再累述。

获得容器相对屏幕的偏移量

  1. //监听容器滚动,得到容器的偏移量 
  2. double 
  3.  _scrollContainerOffset = scrollNotification.metrics.pixels; 

获得坑位相对屏幕的偏移量

  1. //曝光坑位Widget的context 
  2. final 
  3.   
  4. RenderObject 
  5.  childRenderObject = context.findRenderObject(); 
  6. final 
  7.   
  8. RenderAbstractViewport 
  9.  viewport =  
  10. RenderAbstractViewport 
  11. .of(childRenderObject); 
  12. if 
  13.  (viewport ==  
  14. null 
  15. ) { 
  16.    
  17. return 
  18. if 
  19.  (!childRenderObject.attached) { 
  20.    
  21. return 
  22. //曝光坑位在容器内的偏移量 
  23. final 
  24.   
  25. RevealedOffset 
  26.  offsetToRevealTop = viewport.getOffsetToReveal(childRenderObject,  
  27. 0.0 

逻辑判断

  1. if 
  2.  (当前坑位是invisible && 曝光比例 >= { 0.5) 
  3.  
  4. 记录当前坑位是visible状态 
  5.  
  6. 记录出现时间 
  7.  
  8. }  else if (当前坑位是visible && 曝光比例 <  0.5 ) { 
  9.  
  10. 记录当前坑位是invisible状态 
  11.  
  12. if (当前时间-出现时间 >  { 500ms )
  13.  
  14.  
  15. 调用曝光埋点接口 
  16.  
  17.  

点击坑位

点击坑位埋点没什么难点,很容易就可以想到下面的方案:

揭秘!如何用Flutter设计一个100%准确的埋点框架?

效果

经过多轮迭代和优化,目前线上Flutter页面的埋点准确率已经达到100%,有力地支持了业务的分析和判断。同时这套方案让业务同学在做开发时,对于页面进入/离开、曝光坑位可以做到无感知,即不用关心何时去触发,做到了简单易用和无侵入性。

未来

此外,针对页面进入/离开这个场景,由于闲鱼是基于Flutter Boost混合栈的方案,因此我们的解决方案还不够通用。不过未来随着闲鱼上的Flutter页面越来越多,我们后续也会去实现基于Flutter原生的方案。

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读