前言:更多關於數智化轉型、數據中臺內容可掃碼加羣一塊兒探討
阿里雲數據中臺官網 https://dp.alibaba.com/indexhtml
(做者:qingliang_hu)web
團隊通過一年探索,已經實現了多終端可視化埋點方案,包含 Web / App / 小程序等終端,基本操做流程就是將原運行在終端的應用,映射到PC瀏覽器上,經過瀏覽器作配置埋點,相較於H5,App終端因技術棧及訪問環境等條件不一樣,在界面投屏及元素識別上有必定的難度,下面分享咱們實現的像素識別方案。canvas
埋點,簡單說就是對指定位置埋上指定的值,以便監控到該位置是否作了點擊、曝光、跳轉等操做,從而獲得數據以作分析使用。小程序
該數據一般被PD、運營等同窗使用,但埋點卻由編碼的開發同窗完成,且埋點的值還會不定時的更新,增長開發人員工做。瀏覽器
以此爲訴求,團隊着手實現可視化埋點方案,可視化埋點核心在於 如何以平臺的形式不經開發人員來對頁面埋點,好比由制定埋點規劃、使用埋點數據的PD人員來操做。weex
可視化埋點 從使用終端及技術棧上可劃分爲兩類,native和web,而weex、小程序則兩端都覆蓋
app
開發徹底不參與,固然是很是理想,實際上難以操做。簡單來講作埋點管理的平臺一般是在web端,而PD很難經過web平臺來操做native app的頁面元素。相比之下web端的埋點可視化因終端及技術的一致性,咱們已經實現。工具
退而求其次,由開發人員在代碼中標明須要埋點的位置,由PD來配置、更新需埋點的值,也能夠很大程度上減小開發人員工做,提高工做效率,咱們就以這種思路來實際App可視化埋點。大數據
下面主要分享下,如何在PC平臺對App實現可視化埋點解析,實際的實現行爲更復雜,這裏精要講下思路、流程。ui
web端的可視化埋點,用戶能夠經過js實現對html操做,從而直接在PC上對web頁面作元素的圈選、分析。
而web不具有操做native的能力,經過埋點規範、Native截屏、解析約定等,共同實現了一套完整的方案。
首先Native開發人員作硬編碼向須要埋點的元素定義id,native接入sdk,以識別此類元素,截應用圖,並將圖元素繪製在對應位置,保存爲RGB色值的png圖像,以下圖。
上圖中帶黑色邊框的藍色正方形的區塊,標明瞭須要埋點的元素及ID都隱藏這個區塊裏。
咱們放大該區塊
能夠看到黑框內的左上角,有一些彩色像素,這些像素就是用來標識埋點元素的位置及id。
web端的工做重點就是解析這張圖片的Data。
web端下載該圖並獲得其像素數據
const canvas = document.canvas;
const ctx = canvas.getContext('2d');
const img = new Image();
img.setAttribute("crossOrigin", "anonymous");
img.crossOrigin = "Anonymous"
img.src = src;
img.onload = function() {
ctx.drawImage(img, 0, 0);
let imageData = ctx.getImageData(0, 0, this.width, this.height); // imageData即 該圖片的全部像素點
}
獲得全部像素點,如
[255, 144, 0, 255, 255, 144, 0, 255, 255, 144, 0, 255, 255,...]
咱們知道,一個像素點,由四個值組成,分別爲RGBA,如第一個像素點
經過這套數據,四個一組 來篩選找到 web與native 約定好的起始點(即 [97, 117, 116, 255, 111, 116, 114, 255, 97, 99, 107, 255]) ,找到後,再取56_56px的區塊,且該區塊外有 2_2px的黑色邊框,符合這個條件的,便是雙方約定標識的有效區域,以下圖示意
好比咱們在第10000個像素找到了符合條件的區塊,通過簡單計算咱們能夠獲得每一個像素在圖片上的位置
const pi = 10000; //如對第10000個像素點
const width = 1000; //該圖片的寬度爲1000
const pos = {
height: pi*width,
width: parseInt(i / width, 10)
}
獲得有效區域後,再分析該區域像素數據,能夠得出,以下像素值
[
97, 117, 116, 255, #起始標識 a,u,t
111, 116, 114, 255, #起始標識 o,t,r
97, 99, 107, 255, #起始標識 a,c,k
0, 0, 27, 255, #id 長度 27
97, 50, 49, 255, #id值 a,2,1
52, 49, 46, 255, #id值 4,1,.
49, 46, 115, 255, #id值 1,.,s
101, 97, 114, 255, #id值 e,a,r
99, 104, 98, 255, #id值 c,h,b
97, 114, 46, 255, #id值 a,r,.
115, 101, 97, 255, #id值 s,e,a
114, 99, 104, 255, #id值 r,c,h
98, 111, 120, 255, #id值 b,o,x 0, 0,
255, 255, 0, 0,
255, 255, 0, 0,
255, 255, 0, 0,
255, 255, 0, 0,
255, 255, 0, 0,
255 ...
]
前三個像素表起始標識,
第四個像素表id的長度值,即27個字符,
據這個長度讀取後面的字符
並將每一個像素點除第四位外的其它值解析成asc碼
String.fromCharCode(97)//=> aString.fromCharCode(117)//=> u
咱們便可得出其表示的數據含義
前三個像素的表起始標識,解析爲 autotrack,
據第四像素指定長度(27)字符,解析後面的code爲 a2141.1.searchbar.searchbox。
再顯示到圖像上,效果以下
爲顯示友好對 "a2141.1.searchbar.searchbox",只顯示了最後一段。
這樣咱們即獲得了該元素的位置,又獲得了其id。
監聽用戶在該圖上的點擊操做,便可輕鬆選中埋點區域並獲得其id,爲該id綁定配置須要的參數值。生成配置文檔並打包到該App中,經過sdk解析該份配置,經過id將配置與頁面元素對應上,就大功告成!!
數據中臺是企業數智化的新基建,阿里巴巴認爲數據中臺是集方法論、工具、組織於一體的,「快」、「準」、「全」、「統」、「通」的智能大數據體系。目前正經過阿里雲數據中臺解決方案對外輸出,包括零售、金融、互聯網、政務等領域,其中核心產品有:
官方站點:
數據中臺官網 https://dp.alibaba.com