官术网_书友最值得收藏!

Notifying the user of an update

However impressive a created display is it is unlikely to hold the user's attention forever and they are likely to switch to another application or browser tab. Luckily, HTML5 has a feature that will allow notifications on the desktop.

The main.dart function quakeUpdate checks if there is a significant update to notify the user about. To determine which item in the list to notify the user about, the lastWhere method is used. This List method finds the last item in the list that matches the criteria defined by the supplied function. In this case, we look at each feature's magnitude value (stored in gf[2]) and return true or false if the value meets the threshold:

quakeUpdate([Timer t = null]) async {
  await featPlotter.updateData();
  featPlotter.updateHotspots();
  quakeMap.drawMapGrid();

  List notiFeature =
      featPlotter.geoFeatures.lastWhere((List gf) => gf[2] > 1.9);

  String permResult = await Notification.requestPermission();
  if (permResult == 'granted') {
    Notification notifyQuake = new Notification('Quake Alert',
        body: 'Quake Update ${notiFeature[3]} - ${notiFeature[2]}');
  }
}

As this feature is potentially intrusive to a user's computer, the web page must ask for permission to show alerts. In Dartium, a prompt is shown at the top of the page requiring a yes or no response:

Notifying the user of an update

Once permission has been granted, the final step is to create an instance of the notification class. No further method call is required:

Notifying the user of an update

The application is set to notify quite often—you may wish to raise the level at which quakes are notified or you will find yourself dismissing a lot of notifications. The visual display of the notification may vary on different platforms and web browsers.

主站蜘蛛池模板: 永泰县| 裕民县| 千阳县| 兴山县| 宁德市| 天台县| 繁峙县| 晋中市| 廊坊市| 玛曲县| 邓州市| 禄劝| 元阳县| 望城县| 新竹县| 嘉黎县| 宜都市| 体育| 筠连县| 南投县| 长岭县| 鲁甸县| 清徐县| 久治县| 普兰店市| 浦县| 交城县| 大城县| 马鞍山市| 都江堰市| 福海县| 新营市| 无极县| 三河市| 房产| 色达县| 民丰县| 高阳县| 兴国县| 寿光市| 定南县|