page.title=Dashboards page.metaDescription=An overview of device characteristics and platform versions that are active in the Android ecosystem. page.tags="android, dashboard, platforms, versions" meta.tags="ecosystem, versions, whatsnew, dashboards" page.image=https://chart.googleapis.com/chart?chl=GL%202.0%7CGL%203.0%7CGL%203.1&chf=bg%2Cs%2C00000000&chd=t%3A51.6%2C40.7%2C7.7&chco=c4df9b%2C6fad0c&cht=p&chs=400x250 @jd:body <style> div.chart, div.screens-chart { display:none; } tr .total { background-color:transparent; border:0; color:#666; } tr th.total { font-weight:bold; } </style> <div class="sidebox"> <h2>Google Play Install Stats</h2> <p>The Google Play Developer Console also provides <a href="{@docRoot}distribute/googleplay/developer-console.html#app-stats">detailed statistics</a> about your users' devices. Those stats may help you prioritize the device profiles for which you optimize your app.</p> </div> <p>This page provides information about the relative number of devices that share a certain characteristic, such as Android version or screen size. This information may help you prioritize efforts for <a href="{@docRoot}training/basics/supporting-devices/index.html">supporting different devices</a> by revealing which devices are active in the Android and Google Play ecosystem.</p> <p>This data reflects devices running the latest Google Play Store app, which is compatible with Android 2.2 and higher. Each snapshot of data represents all the devices that visited the Google Play Store in the prior 7 days.</p> <h2 id="Platform">Platform Versions</h2> <p>This section provides data about the relative number of devices running a given version of the Android platform.</p> <p>For information about how to target your application to devices based on platform version, read <a href="{@docRoot}training/basics/supporting-devices/platforms.html">Supporting Different Platform Versions</a>.</p> <div id="version-chart"> </div> <p style="clear:both"><em>Data collected during a 7-day period ending on June 6, 2016. <br/>Any versions with less than 0.1% distribution are not shown.</em> </p> <h2 id="Screens">Screen Sizes and Densities</h2> <p>This section provides data about the relative number of devices that have a particular screen configuration, defined by a combination of screen size and density. To simplify the way that you design your user interfaces for different screen configurations, Android divides the range of actual screen sizes and densities into several buckets as expressed by the table below.</p> <p>For information about how you can support multiple screen configurations in your application, read <a href="{@docRoot}guide/practices/screens_support.html">Supporting Multiple Screens</a>.</p> <div id="screens-chart"> </div> <p style="clear:both"><em>Data collected during a 7-day period ending on June 6, 2016. <br/>Any screen configurations with less than 0.1% distribution are not shown.</em></p> <h2 id="OpenGL">Open GL Version</h2> <p>This section provides data about the relative number of devices that support a particular version of OpenGL ES. Note that support for one particular version of OpenGL ES also implies support for any lower version (for example, support for version 2.0 also implies support for 1.1).</p> <img alt="" style="float:right" src="//chart.googleapis.com/chart?chl=GL%202.0%7CGL%203.0%7CGL%203.1&chf=bg%2Cs%2C00000000&chd=t%3A48.6%2C41.8%2C9.6&chco=c4df9b%2C6fad0c&cht=p&chs=400x250"> <p>To declare which version of OpenGL ES your application requires, you should use the {@code android:glEsVersion} attribute of the <a href="{@docRoot}guide/topics/manifest/uses-feature-element.html">{@code <uses-feature>}</a> element. You can also use the <a href="{@docRoot}guide/topics/manifest/supports-gl-texture-element.html">{@code <supports-gl-texture>}</a> element to declare the GL compression formats that your application uses.</p> <table style="width:350px"> <tr> <th scope="col">OpenGL ES Version</th> <th scope="col">Distribution</th> </tr> <tr> <td>2.0</td> <td>48.6%</td> </tr> <tr> <td>3.0</td> <td>41.8%</td> </tr> <tr> <td>3.1</td> <td>9.6%</td> </tr> </table> <p style="clear:both"><em>Data collected during a 7-day period ending on June 6, 2016</em></p> <script> var SCREEN_DATA = [ { "data": { "Large": { "hdpi": "0.5", "ldpi": "0.2", "mdpi": "4.5", "tvdpi": "2.2", "xhdpi": "0.5" }, "Normal": { "hdpi": "41.1", "mdpi": "4.2", "tvdpi": "0.1", "xhdpi": "25.6", "xxhdpi": "15.0" }, "Small": { "ldpi": "2.0" }, "Xlarge": { "hdpi": "0.3", "mdpi": "3.1", "xhdpi": "0.7" } }, "densitychart": "//chart.googleapis.com/chart?chs=400x250&cht=p&chco=c4df9b%2C6fad0c&chf=bg%2Cs%2C00000000&chd=t%3A2.2%2C11.8%2C2.3%2C41.9%2C26.8%2C15.0&chl=ldpi%7Cmdpi%7Ctvdpi%7Chdpi%7Cxhdpi%7Cxxhdpi", "layoutchart": "//chart.googleapis.com/chart?chs=400x250&cht=p&chco=c4df9b%2C6fad0c&chf=bg%2Cs%2C00000000&chd=t%3A4.1%2C7.9%2C86.0%2C2.0&chl=Xlarge%7CLarge%7CNormal%7CSmall" } ]; var VERSION_DATA = [ { "chart": "//chart.googleapis.com/chart?chs=500x250&cht=p&chco=c4df9b%2C6fad0c&chf=bg%2Cs%2C00000000&chd=t%3A0.1%2C2.0%2C1.9%2C18.9%2C31.6%2C35.4%2C10.1&chl=Froyo%7CGingerbread%7CIce%20Cream%20Sandwich%7CJelly%20Bean%7CKitKat%7CLollipop%7CMarshmallow", "data": [ { "api": 8, "name": "Froyo", "perc": "0.1" }, { "api": 10, "name": "Gingerbread", "perc": "2.0" }, { "api": 15, "name": "Ice Cream Sandwich", "perc": "1.9" }, { "api": 16, "name": "Jelly Bean", "perc": "6.8" }, { "api": 17, "name": "Jelly Bean", "perc": "9.4" }, { "api": 18, "name": "Jelly Bean", "perc": "2.7" }, { "api": 19, "name": "KitKat", "perc": "31.6" }, { "api": 21, "name": "Lollipop", "perc": "15.4" }, { "api": 22, "name": "Lollipop", "perc": "20.0" }, { "api": 23, "name": "Marshmallow", "perc": "10.1" } ] } ]; var VERSION_NAMES = [ {"api":0},{"api":1},{"api":2},{"api":3}, { "api":4, "link":'<a href="/about/versions/android-1.6.html">1.6</a>', "codename":"Donut", }, { "api":5}, { "api":6}, { "api":7, "link":'<a href="/about/versions/android-2.1.html">2.1</a>', "codename":"Eclair", }, { "api":8, "link":'<a href="/about/versions/android-2.2.html">2.2</a>', "codename":"Froyo" }, { "api":9, "link":'<a href="/about/versions/android-2.3.html">2.3 -<br>2.3.2</a>', "codename":"Gingerbread" }, { "api":10, "link":'<a href="/about/versions/android-2.3.3.html">2.3.3 -<br>2.3.7</a>', "codename":"Gingerbread" }, { "api":11}, { "api":12, "link":'<a href="/about/versions/android-3.1.html">3.1</a>', "codename":"Honeycomb" }, { "api":13, "link":'<a href="/about/versions/android-3.2.html">3.2</a>', "codename":"Honeycomb" }, { "api":14}, { "api":15, "link":'<a href="/about/versions/android-4.0.html">4.0.3 -<br>4.0.4</a>', "codename":"Ice Cream Sandwich" }, { "api":16, "link":'<a href="/about/versions/android-4.1.html">4.1.x</a>', "codename":"Jelly Bean" }, { "api":17, "link":'<a href="/about/versions/android-4.2.html">4.2.x</a>', "codename":"Jelly Bean" }, { "api":18, "link":'<a href="/about/versions/android-4.3.html">4.3</a>', "codename":"Jelly Bean" }, { "api":19, "link":'<a href="/about/versions/android-4.4.html">4.4</a>', "codename":"KitKat" }, { "api":20, "link":'<a href="/about/versions/android-4.4.html">4.4W</a>', "codename":"KitKat for Wear" }, { "api":21, "link":'<a href="/about/versions/android-5.0.html">5.0</a>', "codename":"Lollipop" }, { "api":22, "link":'<a href="/about/versions/android-5.1.html">5.1</a>', "codename":"Lollipop" }, { "api":23, "link":'<a href="/about/versions/marshmallow/index.html">6.0</a>', "codename":"Marshmallow" } ]; $(document).ready(function(){ // for each set of data (each month) $.each(VERSION_DATA, function(i, set) { // set up wrapper divs var $div = $('<div class="chart"' + ((i == 0) ? ' style="display:block"' : '') + ' >'); var $divtable = $('<div class="col-5" style="margin-left:0">'); var $divchart = $('<div class="col-8" style="margin-right:0">'); // set up a new table var $table = $("<table>"); var $trh = $("<tr><th>Version</th>" + "<th>Codename</th>" + "<th>API</th>" + "<th>Distribution</th></tr>"); $table.append($trh); // loop each data set (each api level represented in stats) $.each(set.data, function(i, data) { // check if we need to rowspan the codename var rowspan = 1; // must not be first row if (i > 0) { // if this row's codename is the same as previous row codename if (data.name == set.data[i-1].name) { rowspan = 0; // otherwise, as long as this is not the last row } else if (i < (set.data.length - 1)) { // increment rowspan for each subsequent row w/ same codename while (data.name == set.data[i+rowspan].name) { rowspan++; // unless we've reached the last row if ((i + rowspan) >= set.data.length) break; } } } // create table row and get corresponding version info from VERSION_NAMES var $tr = $("<tr>"); $tr.append("<td>" + VERSION_NAMES[data.api].link + "</td>"); if (rowspan > 0) { $tr.append("<td rowspan='" + rowspan + "'>" + VERSION_NAMES[data.api].codename + "</td>"); } $tr.append("<td>" + data.api + "</td>"); $tr.append("<td>" + data.perc + "%</td>"); $table.append($tr); }); // create chart image var $chart = $('<img style="margin-left:30px" alt="" data-dac-src="' + set.chart + '" />'); // stack up and insert the elements $divtable.append($table); $divchart.append($chart); $div.append($divtable).append($divchart); $("#version-chart").append($div); }); var SCREEN_SIZES = ["Small","Normal","Large","Xlarge"]; var SCREEN_DENSITIES = ["ldpi","mdpi","tvdpi","hdpi","xhdpi","xxhdpi"]; // for each set of screens data (each month) $.each(SCREEN_DATA, function(i, set) { // set up wrapper divs var $div = $('<div class="screens-chart"' + ((i == 0) ? ' style="display:block"' : '') + ' >'); // set up a new table var $table = $("<table>"); var $trh = $("<tr><th></th></tr>"); $.each(SCREEN_DENSITIES, function(i, density) { $trh.append("<th scope='col'>" + density + "</th>"); }); $trh.append("<th scope='col' class='total'>Total</th>"); $table.append($trh); // array to hold totals for each density var densityTotals = new Array(SCREEN_DENSITIES.length); $.each(densityTotals, function(i, total) { densityTotals[i] = 0; // make them all zero to start }); // loop through each screen size $.each(SCREEN_SIZES, function(i, size) { // if there are any devices of this size if (typeof set.data[size] != "undefined") { // create table row and insert data var $tr = $("<tr>"); $tr.append("<th scope='row'>" + size + "</th>"); // variable to sum all densities for this size var total = 0; // loop through each density $.each(SCREEN_DENSITIES, function(i, density) { var num = typeof set.data[size][density] != "undefined" ? set.data[size][density] : 0; $tr.append("<td>" + (num != 0 ? num + "%" : "") + "</td>"); total += parseFloat(num); densityTotals[i] += parseFloat(num); }) $tr.append("<td class='total'>" + total.toFixed(1) + "%</td>"); $table.append($tr); } }); // create row of totals for each density var $tr = $("<tr><th class='total'>Total</th></tr>"); $.each(densityTotals, function(i, total) { $tr.append("<td class='total'>" + total.toFixed(1) + "%</td>"); }); $table.append($tr); // create charts var $sizechart = $('<img style="float:left;width:380px" alt="" data-dac-src="' + set.layoutchart + '" />'); var $densitychart = $('<img style="float:left;width:380px" alt="" data-dac-src="' + set.densitychart + '" />'); // stack up and insert the elements $div.append($table).append($sizechart).append($densitychart); $("#screens-chart").append($div); }); // TODO (akassay): Remove this. // I replaced the src attributes in the javascript above with data-dac-src // so the value would not be molested by the DevSite parser. So this code here // moves that src value into a real src attribute at runtime. This should be // removed once we either move this script out of the content body or update // the parser to not modify src attributes in <script> tags. $('img[data-dac-src]').each(function() { var src = $(this).attr('data-dac-src'); $(this).attr('src', src); }); }); function changeVersionDate() { var date = $('#date-versions option:selected').val(); $(".chart").hide(); $(".chart."+date+"").show(); } function changeScreensVersionDate() { var date = $('#date-screens option:selected').val(); $(".screens-chart").hide(); $(".screens-chart."+date+"").show(); } </script>