commit-bot@chromium.org | b3b0cfc | 2014-05-15 20:35:50 +0000 | [diff] [blame] | 1 | local canvas -- holds the current canvas (from startcanvas()) |
| 2 | |
| 3 | --[[ |
| 4 | startcanvas() is called at the start of each picture file, passing the |
| 5 | canvas that we will be drawing into, and the name of the file. |
| 6 | |
| 7 | Following this call, there will be some number of calls to accumulate(t) |
| 8 | where t is a table of parameters that were passed to that draw-op. |
| 9 | |
| 10 | t.verb is a string holding the name of the draw-op (e.g. "drawRect") |
| 11 | |
| 12 | when a given picture is done, we call endcanvas(canvas, fileName) |
| 13 | ]] |
| 14 | function sk_scrape_startcanvas(c, fileName) |
| 15 | canvas = c |
| 16 | end |
| 17 | |
| 18 | --[[ |
| 19 | Called when the current canvas is done drawing. |
| 20 | ]] |
| 21 | function sk_scrape_endcanvas(c, fileName) |
| 22 | canvas = nil |
| 23 | end |
| 24 | |
| 25 | --[[ |
| 26 | Use to initialize all keys passed in keyTable to zero in table. |
| 27 | Useful so that keys that are never get incremented still output zero at end |
| 28 | ]] |
| 29 | function resetTableKeys(table, keyTable) |
| 30 | for k, v in next, keyTable do |
| 31 | table[v] = 0 |
| 32 | end |
| 33 | end |
| 34 | |
| 35 | function increment(table, key) |
| 36 | table[key] = (table[key] or 0) + 1 |
| 37 | end |
| 38 | |
| 39 | local dashCount = 0 |
| 40 | |
| 41 | local total_found = {} |
| 42 | local drawPoints_count = {} |
| 43 | local drawPoints_direction = {} |
| 44 | resetTableKeys(drawPoints_direction, {"hori", "vert", "other"}) |
| 45 | local dashInterval_count = {} |
| 46 | local dashInterval_pattern = {} |
| 47 | resetTableKeys(dashInterval_pattern, {"one_one", "zero_on", "other"}) |
| 48 | local dash_phase = {} |
| 49 | resetTableKeys(dash_phase, {"zero", "other"}) |
| 50 | local dash_cap = {} |
| 51 | resetTableKeys(dash_cap, {"butt", "round", "square"}) |
| 52 | |
| 53 | local dashTable = {} |
| 54 | dashTable.total_found = total_found |
| 55 | dashTable.drawPoints_count = drawPoints_count |
| 56 | dashTable.drawPoints_direction = drawPoints_direction |
| 57 | dashTable.dashInterval_count = dashInterval_count |
| 58 | dashTable.dashInterval_pattern = dashInterval_pattern |
| 59 | dashTable.dash_phase = dash_phase |
| 60 | dashTable.dash_cap = dash_cap |
| 61 | |
| 62 | function sk_scrape_accumulate(t) |
| 63 | local p = t.paint |
| 64 | if p then |
| 65 | local pe = p:getPathEffect() |
| 66 | if pe then |
| 67 | local de = pe:asADash() |
| 68 | if de then |
| 69 | dashCount = dashCount + 1 |
| 70 | increment(total_found, t.verb); |
| 71 | increment(dashInterval_count, #de.intervals) |
| 72 | if 2 == #de.intervals then |
| 73 | if 1 == de.intervals[1] and 1 == de.intervals[2] then |
| 74 | increment(dashInterval_pattern, "one_one") |
| 75 | elseif 0 == de.intervals[1] then |
| 76 | increment(dashInterval_pattern, "zero_on") |
| 77 | else |
| 78 | increment(dashInterval_pattern, "other") |
| 79 | end |
| 80 | end |
| 81 | |
| 82 | if 0 == de.phase then |
| 83 | increment(dash_phase, "zero") |
| 84 | else |
| 85 | increment(dash_phase, "other") |
| 86 | end |
| 87 | |
| 88 | local cap = p:getStrokeCap() |
| 89 | if 0 == cap then |
| 90 | increment(dash_cap, "butt") |
| 91 | elseif 1 == cap then |
| 92 | increment(dash_cap, "round") |
| 93 | else |
| 94 | increment(dash_cap, "square") |
| 95 | end |
| 96 | |
| 97 | if "drawPoints" == t.verb then |
| 98 | local points = t.points |
| 99 | increment(drawPoints_count, #points) |
| 100 | if 2 == #points then |
| 101 | if points[1].y == points[2].y then |
| 102 | increment(drawPoints_direction, "hori") |
| 103 | elseif points[1].x == points[2].x then |
| 104 | increment(drawPoints_direction, "vert") |
| 105 | else |
| 106 | increment(drawPoints_direction, "other") |
| 107 | end |
| 108 | end |
| 109 | end |
| 110 | |
| 111 | --[[ |
| 112 | eventually would like to print out info on drawPath verbs with dashed effect |
| 113 | ]] |
| 114 | if "drawPath" == t.verb then |
| 115 | end |
| 116 | |
| 117 | end |
| 118 | end |
| 119 | end |
| 120 | end |
| 121 | |
| 122 | --[[ |
| 123 | lua_pictures will call this function after all of the pictures have been |
| 124 | "accumulated". |
| 125 | ]] |
| 126 | function sk_scrape_summarize() |
| 127 | -- use for non telemetry |
| 128 | --[[ |
| 129 | io.write("Total dashed effects is: ", dashCount, "\n"); |
| 130 | for k1, v1 in next, dashTable do |
| 131 | io.write("\nTable: ", k1, "\n") |
| 132 | for k, v in next, v1 do |
| 133 | io.write("\"", k, "\": ", v, "\n") |
| 134 | end |
| 135 | end |
| 136 | ]] |
| 137 | |
| 138 | -- use for telemetry |
| 139 | io.write("\ndashCount = dashCount + ", tostring(dashCount), "\n") |
| 140 | for k1, v1 in next, dashTable do |
| 141 | for k, v in next, v1 do |
| 142 | io.write("\nincrement(dashTable, \"", k1, "\", \"", k, "\", ", v, ")\n") |
| 143 | end |
| 144 | end |
| 145 | end |
| 146 | |