사용자:Pika/연습: 두 판 사이의 차이

편집 요약 없음
편집 요약 없음
2번째 줄: 2번째 줄:
{
{
   "$schema": "https://vega.github.io/schema/vega/v5.json",
   "$schema": "https://vega.github.io/schema/vega/v5.json",
  "description": "A radar chart example, showing multiple dimensions in a radial layout.",
   "width": 400,
   "width": 400,
   "height": 400,
   "height": 200,
   "padding": 40,
   "padding": 5,
  "autosize": {"type": "none", "contains": "padding"},
 
  "signals": [
    {"name": "radius", "update": "width / 2"}
  ],


   "data": [
   "data": [
16번째 줄: 10번째 줄:
       "name": "table",
       "name": "table",
       "values": [
       "values": [
         {"key": "key-0", "value": 19, "category": 0},
         {"category": "A", "amount": 28},
         {"key": "key-1", "value": 22, "category": 0},
         {"category": "B", "amount": 55},
         {"key": "key-2", "value": 14, "category": 0},
         {"category": "C", "amount": 43},
        {"key": "key-3", "value": 38, "category": 0},
         {"category": "D", "amount": 91},
         {"key": "key-4", "value": 23, "category": 0},
         {"category": "E", "amount": 81},
        {"key": "key-5", "value": 5, "category": 0},
         {"category": "F", "amount": 53},
         {"key": "key-6", "value": 27, "category": 0},
         {"category": "G", "amount": 19},
        {"key": "key-0", "value": 13, "category": 1},
         {"category": "H", "amount": 87}
         {"key": "key-1", "value": 12, "category": 1},
        {"key": "key-2", "value": 42, "category": 1},
         {"key": "key-3", "value": 13, "category": 1},
        {"key": "key-4", "value": 6, "category": 1},
         {"key": "key-5", "value": 15, "category": 1},
        {"key": "key-6", "value": 8, "category": 1}
       ]
       ]
     },
     }
  ],
 
  "signals": [
     {
     {
       "name": "keys",
       "name": "tooltip",
       "source": "table",
       "value": {},
       "transform": [
       "on": [
         {
         {"events": "rect:mouseover", "update": "datum"},
          "type": "aggregate",
         {"events": "rect:mouseout",  "update": "{}"}
          "groupby": ["key"]
         }
       ]
       ]
     }
     }
46번째 줄: 35번째 줄:
   "scales": [
   "scales": [
     {
     {
       "name": "angular",
       "name": "xscale",
       "type": "point",
       "type": "band",
      "range": {"signal": "[-PI, PI]"},
       "domain": {"data": "table", "field": "category"},
      "padding": 0.5,
       "range": "width",
       "domain": {"data": "table", "field": "key"}
       "padding": 0.05,
    },
       "round": true
    {
       "name": "radial",
       "type": "linear",
      "range": {"signal": "[0, radius]"},
       "zero": true,
      "nice": false,
      "domain": {"data": "table", "field": "value"},
      "domainMin": 0
     },
     },
     {
     {
       "name": "color",
       "name": "yscale",
      "type": "ordinal",
       "domain": {"data": "table", "field": "amount"},
       "domain": {"data": "table", "field": "category"},
       "nice": true,
       "range": {"scheme": "category10"}
      "range": "height"
     }
     }
   ],
   ],


   "encode": {
   "axes": [
     "enter": {
     { "orient": "bottom", "scale": "xscale" },
      "x": {"signal": "radius"},
    { "orient": "left", "scale": "yscale" }
      "y": {"signal": "radius"}
   ],
    }
   },


   "marks": [
   "marks": [
     {
     {
       "type": "group",
       "type": "rect",
      "name": "categories",
       "from": {"data":"table"},
      "zindex": 1,
       "from": {
        "facet": {"data": "table", "name": "facet", "groupby": ["category"]}
      },
      "marks": [
        {
          "type": "line",
          "name": "category-line",
          "from": {"data": "facet"},
          "encode": {
            "enter": {
              "interpolate": {"value": "linear-closed"},
              "x": {"signal": "scale('radial', datum.value) * cos(scale('angular', datum.key))"},
              "y": {"signal": "scale('radial', datum.value) * sin(scale('angular', datum.key))"},
              "stroke": {"scale": "color", "field": "category"},
              "strokeWidth": {"value": 1},
              "fill": {"scale": "color", "field": "category"},
              "fillOpacity": {"value": 0.1}
            }
          }
        },
        {
          "type": "text",
          "name": "value-text",
          "from": {"data": "category-line"},
          "encode": {
            "enter": {
              "x": {"signal": "datum.x"},
              "y": {"signal": "datum.y"},
              "text": {"signal": "datum.datum.value"},
              "align": {"value": "center"},
              "baseline": {"value": "middle"},
              "fill": {"value": "black"}
            }
          }
        }
      ]
    },
    {
      "type": "rule",
      "name": "radial-grid",
      "from": {"data": "keys"},
      "zindex": 0,
       "encode": {
       "encode": {
         "enter": {
         "enter": {
           "x": {"value": 0},
           "x": {"scale": "xscale", "field": "category"},
           "y": {"value": 0},
           "width": {"scale": "xscale", "band": 1},
           "x2": {"signal": "radius * cos(scale('angular', datum.key))"},
           "y": {"scale": "yscale", "field": "amount"},
           "y2": {"signal": "radius * sin(scale('angular', datum.key))"},
           "y2": {"scale": "yscale", "value": 0}
           "stroke": {"value": "lightgray"},
        },
           "strokeWidth": {"value": 1}
        "update": {
           "fill": {"value": "steelblue"}
        },
        "hover": {
           "fill": {"value": "red"}
         }
         }
       }
       }
136번째 줄: 76번째 줄:
     {
     {
       "type": "text",
       "type": "text",
      "name": "key-label",
      "from": {"data": "keys"},
      "zindex": 1,
       "encode": {
       "encode": {
         "enter": {
         "enter": {
           "x": {"signal": "(radius + 5) * cos(scale('angular', datum.key))"},
           "align": {"value": "center"},
           "y": {"signal": "(radius + 5) * sin(scale('angular', datum.key))"},
           "baseline": {"value": "bottom"},
           "text": {"field": "key"},
           "fill": {"value": "#333"}
          "align": [
        },
            {
        "update": {
              "test": "abs(scale('angular', datum.key)) > PI / 2",
           "x": {"scale": "xscale", "signal": "tooltip.category", "band": 0.5},
              "value": "right"
           "y": {"scale": "yscale", "signal": "tooltip.amount", "offset": -2},
            },
           "text": {"signal": "tooltip.amount"},
            {
           "fillOpacity": [
              "value": "left"
            {"test": "isNaN(tooltip.amount)", "value": 0},
            }
            {"value": 1}
          ],
          ]
           "baseline": [
            {
              "test": "scale('angular', datum.key) > 0", "value": "top"
            },
            {
              "test": "scale('angular', datum.key) == 0", "value": "middle"
            },
            {
              "value": "bottom"
            }
          ],
           "fill": {"value": "black"},
          "fontWeight": {"value": "bold"}
        }
      }
    },
    {
      "type": "line",
      "name": "outer-line",
      "from": {"data": "radial-grid"},
      "encode": {
        "enter": {
           "interpolate": {"value": "linear-closed"},
           "x": {"field": "x2"},
          "y": {"field": "y2"},
          "stroke": {"value": "lightgray"},
          "strokeWidth": {"value": 1}
         }
         }
       }
       }

2021년 1월 4일 (월) 22:29 판