canvas手绘正五边形

2019-11-26 11:09:22

参考地址 canvas手绘正五边形

一、基本用法:

alertShow(param: any, $index: any) {

        let $log = this.$log;

        let $scope = this.$scope;

        if (param !== $scope.lastObj) {

            param.show = true;

            if ($scope.lastObj !== null) {

                $scope.lastObj.show = false;

            }

            $scope.lastObj = param;

            $scope.radarAlert = true;

            if ($index === 0) {

                $(".radarChart_alert").css({left: $scope.arr[$index].x + 100 + "px", top: $scope.arr[$index].y + "px"});

            } else {

                $(".radarChart_alert").css({left: $scope.arr[$index].x, top: $scope.arr[$index].y + 40 + "px"});

            }

        }

    }

drawRadarChart() {

    $scope.radarChartCategroy = [

            {name1: "词汇短语", name2: "排名前34%", show: false},

            {name1: "口语运用", name2: "排名前34%", show: false},

            {name1: "听力理解", name2: "排名前34%", show: false},

            {name1: "阅读理解", name2: "排名前34%", show: false},

            {name1: "语法句法", name2: "排名前34%", show: false}

        ];

        let $scope = this.$scope;

        let width: any, long: any, samll: any, big: any;

        getWidth();

        function getWidth() {

            width = $(".nav").width();

            $(".radarChart_div").height(width);

            $(".nav").height(width);

            $("#radarChart").attr({width: width, height: width});

            long = width / 2;

            samll = (width / 2) * Math.tan(36 * Math.PI / 180);

            big = (width / 2) / Math.cos(36 * Math.PI / 180);

            window.requestAnimationFrame(draw);

            let radarBtnWidth = $(".radarChart_select").width();

            let radarBtnHeight = $(".radarChart_select").height();

            $scope.arr = [

                {x: long - radarBtnWidth / 2, y: 5 - radarBtnHeight - 15},

                {x: -radarBtnWidth - 5, y: samll + 5 - radarBtnHeight / 2},

                {x: big * Math.sin(18 * Math.PI / 180) - radarBtnWidth * 2 / 3, y: big * Math.cos(18 * Math.PI / 180) + samll + radarBtnHeight / 2},

                {x: big * Math.sin(18 * Math.PI / 180) + big - radarBtnWidth / 3, y: big * Math.cos(18 * Math.PI / 180) + samll + radarBtnHeight / 2},

                {x: 2 * long + 5, y: samll + 5 - radarBtnHeight / 2}

            ]

            for (let i = 0; i < $scope.arr.length; i++) {

                $(".radarChart_select").eq(i).css({left: $scope.arr[i].x + "px", top: $scope.arr[i].y + "px"});

            }

        }

        function draw() {

            let canvas = document.getElementById("radarChart");

            if (canvas.getContext) {

                var ctx = canvas.getContext("2d");

                ctx.clearRect(0, 0, width, width);

                ctx.beginPath();

                ctx.lineWidth = 1;

                ctx.lineJoin = "miter";

                ctx.strokeStyle = "rgba(255,255,255,.5)";

                ctx.moveTo(long, 5);

                ctx.lineTo(0, samll + 5);

                ctx.lineTo(big * Math.sin(18 * Math.PI / 180), big * Math.cos(18 * Math.PI / 180) + samll + 5);

                ctx.lineTo(big * Math.sin(18 * Math.PI / 180) + big, big * Math.cos(18 * Math.PI / 180) + samll + 5);

                ctx.lineTo(2 * long, samll + 5);

                ctx.lineTo(long, 5);

                ctx.moveTo(long, long / Math.sin(72 * Math.PI / 180));

                ctx.lineTo(long, 5);

                ctx.moveTo(long, long / Math.sin(72 * Math.PI / 180));

                ctx.lineTo(0, samll + 5);

                ctx.moveTo(long, long / Math.sin(72 * Math.PI / 180));

                ctx.lineTo(big * Math.sin(18 * Math.PI / 180), big * Math.cos(18 * Math.PI / 180) + samll + 5);

                ctx.moveTo(long, long / Math.sin(72 * Math.PI / 180));

                ctx.lineTo(big * Math.sin(18 * Math.PI / 180) + big, big * Math.cos(18 * Math.PI / 180) + samll + 5);

                ctx.moveTo(long, long / Math.sin(72 * Math.PI / 180));

                ctx.lineTo(2 * long, samll + 5);

                ctx.stroke();

                ctx.save();

                ctx.beginPath();

                ctx.fillStyle = "rgba(255,255,255,.5)";

                ctx.moveTo(long, long / Math.sin(72 * Math.PI / 180) - $scope.num + 5);

                ctx.lineTo(long - $scope.num * Math.sin(72 * Math.PI / 180), long / Math.sin(72 * Math.PI / 180) - $scope.num * Math.cos(72 * Math.PI / 180) + 5);

                ctx.lineTo(long - $scope.num * Math.sin(36 * Math.PI / 180), long / Math.sin(72 * Math.PI / 180) + $scope.num * Math.cos(36 * Math.PI / 180) + 5);

                ctx.lineTo(long + $scope.num * Math.sin(36 * Math.PI / 180), long / Math.sin(72 * Math.PI / 180) + $scope.num * Math.cos(36 * Math.PI / 180) + 5);

                ctx.lineTo(long + $scope.num * Math.sin(72 * Math.PI / 180), long / Math.sin(72 * Math.PI / 180) - $scope.num * Math.cos(72 * Math.PI / 180) + 5);

//                ctx.lineTo(long, long / Math.sin(72 * Math.PI / 180) - $scope.num + 5);

                ctx.fill();

                ctx.save();

                ctx.restore();

                if ($scope.time2 < 60) {

                    window.requestAnimationFrame(draw);

                    $scope.num = $scope.num + long / 60;

                    $scope.time2 = $scope.time2 + 1;

                }

            }

        }

    }

}

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

            <div>

                <div class="radarChart_div"></div>

                <div class="nav">

                    <canvas id="radarChart"></canvas>

                    <div class="radarChart_select" ng-repeat="item in radarChartCategroy" ng-click="events.alertShow(item, $index)"

                         ng-class="{'radarChart_select_true':item.show,'radarChart_select_flase':!item.show}">

                        <div>{{item.name1}}</div>

                        <div>{{item.name2}}</div>

                    </div>

                    <div class="radarChart_alert" ng-style="radarAlert ? {'display': 'flex'} : {'display': 'none'}">

                        <div>213道</div>

                        <div>72%</div>

                        <div>正确答题</div>

                        <div>正确率</div>

                    </div>

                </div>

                <div class="radarChart_div"></div>              

            </div>



  • 2017-09-13 13:49:21

    Web性能测试:工具之Siege详解

    Siege是一款开源的压力测试工具,设计用于评估WEB应用在压力下的承受能力。可以根据配置对一个WEB站点进行多用户的并发访问,记录每个用户所有请求过程的相应时间,并在一定数量的并发访问下重复进行。siege可以从您选择的预置列表中请求随机的URL。所以siege可用于仿真用户请求负载,而ab则不能。但不要使用siege来执行最高性能基准调校测试,这方面ab就准确很多

  • 2017-09-14 10:18:25

    15分钟成为Git专家

    不管是以前使用过 Git 还是刚开始使用这个神奇的版本控制工具的开发者,阅读了本文以后都会收获颇丰。如果你是应一名有经验的 GIT 使用者,你会更好的理解 checkout -> modify -> commit 这个过程。如果你刚开始使用 Git,本文将给你一个很好的开端。

  • 2017-09-28 16:42:57

    Linux vmstat命令实战详解

    vmstat命令是最常见的Linux/Unix监控工具,可以展现给定时间间隔的服务器的状态值,包括服务器的CPU使用率,内存使用,虚拟内存交换情况,IO读写情况。这个命令是我查看Linux/Unix最喜爱的命令,一个是Linux/Unix都支持,二是相比top,我可以看到整个机器的CPU,内存,IO的使用情况,而不是单单看到各个进程的CPU使用率和内存使用率(使用场景不一样)。

  • 2017-10-13 16:21:29

    Activity的四种launchMode

    launchMode在多个Activity跳转的过程中扮演着重要的角色,它可以决定是否生成新的Activity实例,是否重用已存在的Activity实例,是否和其他Activity实例公用一个task里。这里简单介绍一下task的概念,task是一个具有栈结构的对象,一个task可以管理多个Activity,启动一个应用,也就创建一个与之对应的task。

  • 2017-10-16 16:45:45

    Android开发技巧:Application和Instance

    在开发过程中,我们经常会需要用到一些全局的变量或者全局的“管理者”,例如QQ,需要有一个“全局的管理者“保存好友信息,各个activity即可直接通过该”管理者“来获取和修改某个好友信息,显然,这样的一个好友信息,保存到某一个具体的activity里面,然后依靠activity的intent来传递参数是不合适。我们有两种方法来实现这样一个全局的管理者,一种是使用C++/Java中常用的单例模式,另一种是利用Android的Application类,下面一一阐述。

  • 2017-11-01 01:30:45

    解决第三方包内jar包冲突

    这个问题就是因为引入jar包的冲突,这时我们可以在build.gradle中添加如下代码,下方单独的是添加的代码

  • 2017-11-06 01:00:17

    撤销git add

    如何撤销git add,不小心执行了git add . 操作,但是又不能提交所有的文件,因为对应不同的分支,现在怎么样可以将git add 撤销回来