亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

angularJS結合canvas畫圖例子

2019-11-20 13:11:32
字體:
來源:轉載
供稿:網友

這里給大家分享一個angularJS結合canvas畫圖例子,效果非常不錯,贊一個先。

復制代碼 代碼如下:

<!DOCTYPE html>
<html ng-app="APP">
<head>
    <meta charset="UTF-8">
  <script src="http://cdn.bootcss.com/angular.js/1.3.0-beta.12/angular.min.js"></script>
</head>
<body ng-controller="MainCtrl">
  <!--
    界面的這個元素會被替換成canvas元素;
  -->
    <div ang:round:progress data-round-progress-model="roundProgressData"></div>
    <br>
    <input type="number" ng-model="roundProgressData.label"/>
    <script>
                                   //引用angular.directives-round-progress這個模塊;
     var APP = angular.module('APP', ['angular.directives-round-progress']).
     controller('MainCtrl', function($scope) {
        $scope.roundProgressData = {
          //這個是初始化的數據;
          label: 11,
          percentage: 0.11
        }
        //通過監聽scope下的這個roundProgressData屬性, 對界面的canvas進行重繪;
        $scope.$watch('roundProgressData', function (newValue) {
          newValue.percentage = newValue.label / 100;
        }, true);
      });
    </script>
<script>
    /*!
 * AngularJS Round Progress Directive
 *
 * Copyright 2013 Stephane Begaudeau
 * Released under the MIT license
 */
angular.module('angular.directives-round-progress', []).directive('angRoundProgress', [function () {
  var compilationFunction = function (templateElement, templateAttributes, transclude) {
    if (templateElement.length === 1) {
      //初始化DOM模型, 包括初始化canvas等;
      var node = templateElement[0];
      var width = node.getAttribute('data-round-progress-width') || '400';
      var height = node.getAttribute('data-round-progress-height') || '400';
      var canvas = document.createElement('canvas');
      canvas.setAttribute('width', width);
      canvas.setAttribute('height', height);
      canvas.setAttribute('data-round-progress-model', node.getAttribute('data-round-progress-model'));
        //相當于demo, 替換原來的元素;
      node.parentNode.replaceChild(canvas, node);
        //各種配置;
      var outerCircleWidth = node.getAttribute('data-round-progress-outer-circle-width') || '20';
      var innerCircleWidth = node.getAttribute('data-round-progress-inner-circle-width') || '5';
      var outerCircleBackgroundColor = node.getAttribute('data-round-progress-outer-circle-background-color') || '#505769';
      var outerCircleForegroundColor = node.getAttribute('data-round-progress-outer-circle-foreground-color') || '#12eeb9';
      var innerCircleColor = node.getAttribute('data-round-progress-inner-circle-color') || '#505769';
      var labelColor = node.getAttribute('data-round-progress-label-color') || '#12eeb9';
      var outerCircleRadius = node.getAttribute('data-round-progress-outer-circle-radius') || '100';
      var innerCircleRadius = node.getAttribute('data-round-progress-inner-circle-radius') || '70';
      var labelFont = node.getAttribute('data-round-progress-label-font') || '50pt Calibri';
      return {
        pre: function preLink(scope, instanceElement, instanceAttributes, controller) {
          var expression = canvas.getAttribute('data-round-progress-model');
            //監聽模型, O了
            //就監聽一個屬性;
          scope.$watch(expression, function (newValue, oldValue) {
            // Create the content of the canvas
            //包括新建和重繪;
            var ctx = canvas.getContext('2d');
            ctx.clearRect(0, 0, width, height);
            // The "background" circle
            var x = width / 2;
            var y = height / 2;
            ctx.beginPath();
            ctx.arc(x, y, parseInt(outerCircleRadius), 0, Math.PI * 2, false);
            ctx.lineWidth = parseInt(outerCircleWidth);
            ctx.strokeStyle = outerCircleBackgroundColor;
            ctx.stroke();
            // The inner circle
            ctx.beginPath();
            ctx.arc(x, y, parseInt(innerCircleRadius), 0, Math.PI * 2, false);
            ctx.lineWidth = parseInt(innerCircleWidth);
            ctx.strokeStyle = innerCircleColor;
            ctx.stroke();
            // The inner number
            ctx.font = labelFont;
            ctx.textAlign = 'center';
            ctx.textBaseline = 'middle';
            ctx.fillStyle = labelColor;
            ctx.fillText(newValue.label, x, y);
            // The "foreground" circle
            var startAngle = - (Math.PI / 2);
            var endAngle = ((Math.PI * 2 ) * newValue.percentage) - (Math.PI / 2);
            var anticlockwise = false;
            ctx.beginPath();
            ctx.arc(x, y, parseInt(outerCircleRadius), startAngle, endAngle, anticlockwise);
            ctx.lineWidth = parseInt(outerCircleWidth);
            ctx.strokeStyle = outerCircleForegroundColor;
            ctx.stroke();
          }, true);
        },
        post: function postLink(scope, instanceElement, instanceAttributes, controller) {}
      };
    }
  };
  var roundProgress = {
      //compile里面先對dom進行操作, 再對$socpe進行監聽;
    compile: compilationFunction,
    replace: true
  };
  return roundProgress;
}]);
</script>
</body>
</html>

以上就是angularJS結合canvas畫圖例子的全部代碼了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品亚洲一区二区三区| 一区二区三区日韩在线| 亚洲欧美变态国产另类| 亚洲深夜福利在线| 欧美午夜精品在线| 亚洲色图狂野欧美| 欧美午夜性色大片在线观看| 日韩中文字幕在线视频| 国产一区二区精品丝袜| 日韩电影视频免费| 91国内免费在线视频| 亚洲xxxx视频| 中文字幕欧美精品在线| 国产精品旅馆在线| 亚洲欧美国产一本综合首页| 国产亚洲欧洲黄色| 国产亚洲综合久久| 日韩精品极品在线观看播放免费视频| 亚洲色图综合久久| 午夜精品久久久久久久99黑人| 欧美激情视频在线免费观看 欧美视频免费一| 欧美精品在线观看| 欧美性xxxx极品hd欧美风情| 欧美视频在线看| 欧美日韩国产二区| 在线日韩中文字幕| 国产免费一区二区三区在线观看| 狠狠色香婷婷久久亚洲精品| 国产日韩在线亚洲字幕中文| 成人午夜激情免费视频| 亚洲3p在线观看| 色综合91久久精品中文字幕| 九九精品在线观看| 亚洲字幕在线观看| 成人h视频在线| 日韩电影大全免费观看2023年上| 欧美怡春院一区二区三区| 日韩av在线高清| 国产精品成av人在线视午夜片| 免费成人高清视频| 91av在线播放| 久久久av一区| 91中文在线视频| 国产日本欧美一区二区三区在线| 欧美亚洲视频一区二区| 日韩精品免费观看| 国内精品久久久久久影视8| 成人黄色av免费在线观看| 亚洲乱亚洲乱妇无码| 久久久国产精品x99av| 91精品综合久久久久久五月天| 亚洲美女视频网站| 日韩中文字幕精品视频| 欧美成人午夜免费视在线看片| 国产美女扒开尿口久久久| 欧洲精品久久久| 国产精品入口日韩视频大尺度| 亚洲人成自拍网站| 91久久精品国产91久久| 久久精品在线播放| 欧美肥臀大乳一区二区免费视频| 亚洲福利视频网| 久久视频中文字幕| 欧美激情日韩图片| 国产精品久久9| 亚洲福利精品在线| 亚洲图片在区色| 国产97色在线|日韩| 国产成人在线亚洲欧美| 欧美一级高清免费播放| 亚洲精品国产拍免费91在线| 亚洲视频欧美视频| 成人有码视频在线播放| 国产成人久久精品| 国产乱人伦真实精品视频| 久久久国产精品亚洲一区| 亚洲第一色中文字幕| 精品国产一区二区三区久久狼黑人| 日韩电影大片中文字幕| 91九色国产在线| 中文日韩在线视频| 久久精品国产清自在天天线| 性欧美长视频免费观看不卡| 欧美激情免费在线| 日本国产欧美一区二区三区| 色婷婷av一区二区三区久久| 久久在精品线影院精品国产| 亚洲第一福利视频| 久久久亚洲精选| 欧美国产日韩在线| 亚洲精品女av网站| 国内精品视频一区| 日韩av在线电影网| 国产精品美女视频网站| 日韩在线视频免费观看高清中文| 在线亚洲男人天堂| 91色琪琪电影亚洲精品久久| 精品久久久久久久大神国产| 亚洲精品美女免费| 亚洲缚视频在线观看| 欧美在线观看www| 亚洲午夜激情免费视频| 一本一本久久a久久精品综合小说| 亚洲人午夜色婷婷| 91系列在线播放| 国产91精品视频在线观看| 色噜噜狠狠狠综合曰曰曰| 欧美午夜影院在线视频| 美日韩精品视频免费看| 日韩久久午夜影院| 久精品免费视频| 国语对白做受69| 亚洲黄一区二区| 国产精品91在线观看| 欧美精品一本久久男人的天堂| 8050国产精品久久久久久| 日韩精品视频在线免费观看| 亚洲一区中文字幕在线观看| 日韩欧美一区二区三区久久| 亚洲xxx大片| 主播福利视频一区| 欧美亚洲另类激情另类| 国产精品成熟老女人| 亚洲精选中文字幕| 欧美综合在线观看| 欧美日韩加勒比精品一区| 日本精品久久中文字幕佐佐木| 2018中文字幕一区二区三区| 亚洲国产成人爱av在线播放| 成人激情免费在线| 大伊人狠狠躁夜夜躁av一区| 欧美最猛黑人xxxx黑人猛叫黄| 亚洲剧情一区二区| 97在线观看免费| 欧美www视频在线观看| 国产91精品网站| 26uuu另类亚洲欧美日本老年| 欧美性猛交xxxx| 欧美一级高清免费| 自拍偷拍亚洲精品| 一二美女精品欧洲| 国产精品91免费在线| 黑人巨大精品欧美一区二区| 88国产精品欧美一区二区三区| 久久久久亚洲精品国产| 欧美精品情趣视频| 亚洲精品国产美女| 亚洲国产另类 国产精品国产免费| 91高清免费在线观看| 久久久国产一区| 欧美精品久久久久a| 亚洲美女在线看| 美女啪啪无遮挡免费久久网站| 国产精品久久久久久久av大片| 欧美第一淫aaasss性| 国产精品专区h在线观看| 日日骚久久av| 亚洲乱亚洲乱妇无码| 日本三级韩国三级久久| 亚洲人成网站色ww在线| 成人午夜激情网| 欧美中文在线观看| 欧美韩国理论所午夜片917电影| 欧美高清视频在线|