Slide 1

Slide 1 text

JavaScriptΛ޷͖ʹͳΔͨΊʹ LineChartΛඳըͯ͠Έͨ 2019.05.22 Ginza.js #1 @MzRyuKa !1

Slide 2

Slide 2 text

ࣗݾ঺հɿΈͣΓΎ { ৬ۀ: ‘ಠཱܥSIer’, ΤϯδχΞྺ: ‘20೥໨ʹಥೖ’, ࢓ࣄͰ࢖͏ٕज़: [ ‘Ruby’,’RRDtool’,’SNMP’,’JavaScript’ ], ਪ͠ݴޠ: [‘Golang’,’Elixir’], ޷͖ͳ΋ͷ: [ ‘Ͷ͜’, ’͏͞·Δ’,’ٕज़࿩’], Twitter : { TwitterID: ‘@MzRyuKa’, ঢ়ଶ: 'Search Suggestion Ban’ }, ϒϩά: ‘https://mzryuka.hatenablog.jp/’ } !2

Slide 3

Slide 3 text

͜Ε·ͰͷJavaScriptͱͷ෇͖߹͍ αʔόͰ࣮ࢪ͢ΔνΣοΫॲཧΛΫϥΠΞϯτଆ Ͱ΋࣮ࢪͤ͞ΒΕΔʢ͔͠΋௥Ճྉۚͳ͠ʣ ͔ͤͬ͘ॻ੍͍ͨޚ΋ʮJavaScript͸Φϑʹ͢Δӡ ༻͔ͩΒʯͰ࢖ΘΕͳ͔ͬͨ IE͚ͩจ๏͕ҧ͏ʂͰ΋ɺ࢖͏ͷ͸IEeee!!! 2000೥୅લ൒ͷࠒͷ࿩Ͱ͢ɻ Πϯλʔωοτ࿝ਓձͷ࿩ఔ౓Ͱฉ͖ྲྀ͍ͯͩ͘͠͞ !3

Slide 4

Slide 4 text

ύϥμΠϜγϑτɿJavaScript࣌୅ ਖ਼௚ɺഇΕ͍ͯ͘ͱࢥͬͯͨɻ
 ʢ2000೥લ൒͸ׂͱॏ͔ͬͨ͠ɺIE͕໘౗ͩ͠ʣ ͔͠͠ɺੈ͸·͞ʹʮJavaScriptͷ࣌୅ʯʂ
 JavaScript࢖͑ͳ͚Ε͹ΤϯδχΞʹඇͣͳ෩ை งғؾͰ࢖ͬͯ͸͍Δ͚Ͳɺਖ਼௚ͦ͜·Ͱ޷͖Ͱ ΋ͳ͍ɻԿΑΓɺۤखҙ͕ࣝ…orz !4

Slide 5

Slide 5 text

సػͷஹ͠ ͦΜͳ࣌ʹɺʮGinza.js #1ʯͷࠂ஌͕ʂ ͜Ε͸ɺྑ͍͖͔͚ͬʹͳΔ͔΋ʂ LT࿮͕ۭ͍͍ͯΔɻʮLTۦಈͩʂʯͰਃ͠ࠐΈʂ ※ޙ೔ɺCORSʹ͸·ͬͯٽ͖Λݟͨͷ͸ൿີͰ͢ɻ !5

Slide 6

Slide 6 text

JavaScriptΛ޷͖ʹͳΔͨΊʹ LineChartΛඳըͯ͠Έͨ ͔͜͜Βຊฤ !6

Slide 7

Slide 7 text

޷͖ʹͳ͍ͬͯ͘ʹ͋ͨͬͯ ϏδϡΞϥΠζ͞Ε͍ͯΔ͜ͱ ࠓ΍͍ͬͯΔۀ຿ͷϓϥεʹͳΔ͜ͱ ͦΜͳʹ࿑ྗ͔͚ͳͯ͘΋ࡁΉ͜ͱ ͜Ε·ͰɺงғؾͰjQueryΛ࢖ͬͯͨΓɺnode.js΍ReactɺVue.jsͷೖ໳Ϩϕϧ͸΍͖͚ͬͯͨͲΠ ϚΠνೃછ·ͳ͔ͬͨɻͳͷͰগ͠੔ཧͯ͠Έͨɻ !7

Slide 8

Slide 8 text

ࠓ΍͍ͬͯΔ͓࢓ࣄ SNMPͰऔಘͨ͠σʔλΛRRDtoolʹอଘͯ͠άϥϑΛ ඳը͍ͯ͠Δɻ → ͩͬͨΒɺ͜Εͱಉ͡Α͏ͳࣄ͢Ε͹ྑͦ͞͏ɻ ʢ࢓ࣄ࣌ؒதʹ΍ͬͯͯ΋ޡຐԽ͠ޮͬ͘͠ΐʣ !8

Slide 9

Slide 9 text

ߟ͑ͨߏ੒ νϟʔτ༻ͷJSONΛฦ͢ॲཧ JSONΛड͚औͬͯϥΠϯνϟʔτΛ
 දࣔ͢ΔWebαʔό !9 → ͲͪΒ΋ɺNetlifyΛ࢖͑͹؆୯ʹ४උͰ͖ͦ͏

Slide 10

Slide 10 text

DEMO !10 DEMO URL: https://upbeat-einstein-a1e1ed.netlify.com/public/index.html GitHub URL: https://github.com/rykawamu/biorhythm_chart_project

Slide 11

Slide 11 text

JSONΛฦ͢ॲཧ νϟʔτදࣔ࣌ʹΘ͔Γ΍͍͢΋ͷ͕ྑ͍ͷͰɺ ʮόΠΦϦζϜʯσʔλΛฦ͢͜ͱʹͨ͠ɻ ʮΫΤϦจࣈྻʯͰσʔλมಈཁૉ͸༩͑ͱ͘ Netlify FunctionsΛ࢖ͬͯJSONΛฦ͢ !11 URL: https://upbeat-einstein-a1e1ed.netlify.com/.netlify/functions/biorhythm?birth_date=1960-02-23&base_date=&period=60

Slide 12

Slide 12 text

༨ஊɿόΠΦϦζϜͱ͸ ੜ໋ମͷʮ਎ମʢPhysicalʣʯʮײ৘ ʢSensitivityʣʯʮ஌ੑʢIntellectualʣʯ͕Ұ ఆͷपظύλʔϯͰมԽ͢Δͱݴ͏આʹجͮ ͍ͨάϥϑͷ͜ͱ ʮਖ਼ݭ೾ʯͷ೾ܗͰɺy = sin(2 π t / T) 
 ͷࣜͰࢉग़͞ΕΔɻ t: ج४೔ - ੜ೥݄೔ ͔Βࢉग़͞ΕΔ೔਺ T: ਎ମʢPʣͷ৔߹23ɺײ৘ʢPʣͷ৔߹28ɺ ஌ੑʢIʣͷ৔߹33ͷݻఆͷ஋ͱͳΔɻ 23ͱ28ͱ33ͷ࠷খެഒ਺͸21252Ͱ͋Δɻ
 ೔਺ʹ௚͢ͱʮ58.2೥ʯͰ͋Δɻ !12 //Create biorhythm data const [p_v, s_v, i_v] = (function() { const pi = Math.PI const biorhythm_func = (function(T) { return Math.sin(elapsed_days * 2 * pi / T).toFixed(4) }) const physical = biorhythm_func(23); const sensitivity = biorhythm_func(28); const intellectual = biorhythm_func(33); return [physical, sensitivity, intellectual] })();

Slide 13

Slide 13 text

LineChart:ϥΠϯνϟʔτ Chart.js C3.js Google Chart खؒΛ͔͚ͨ͘ͳ͔ͬͨͷͰɺ·ͣ͸༗໊Ͳ͜ΖͷνϟʔτϥΠϒϥϦ͔ΒखΛ͚ͭͯΈΔɻ !13 ※৘ใࢀߟݩɿ JavaScriptͰάϥϑඳըೖ໳ʂશ̔ݸͷϥΠϒϥϦΛίʔυ෇͖ͰҰڍʹղઆʂ URL: https://paiza.hatenablog.com/entry/2016/06/07/JavaScriptͰάϥϑඳըೖ໳ʂશ̔ݸͷϥΠϒϥϦΛίʔ

Slide 14

Slide 14 text

Chart.js HTML5ͷcanvasΛ࢖ͬͯඳը͞ΕΔ ࣗಈతʹΞχϝʔγϣϯදࣔ͞ΕΔ ϥΠηϯε͸MIT ಛ௃ɿ !14 URL: https://upbeat-einstein-a1e1ed.netlify.com/public/chart_chart.html

Slide 15

Slide 15 text

Chart.js ར༻ྫ1 !15 var ctx = document.getElementById('myChart_b'); var myChart = new Chart(ctx, { type: 'line', data: { datasets: [{ label: '# of Physical', fill: false, data: [], backgroundColor: 'rgba(0, 0, 255, 0.3)', borderColor: 'rgba(0, 0, 255, 0.3)', borderWidth: 3 } ,{ label: '# of Sensitivity', fill: false, data: [], backgroundColor: 'rgba(255, 0, 0, 0.3)', ~ҎԼུ~ document.getElementById()Ͱඳըର৅ʹ͢ΔCanvasλάΛ ࢦఆ͢Δɻ canvasΦϒδΣΫτΛChartΦϒδΣΫτͷҾ਺ʹ౉͢Δ ͜ͱͰؔ࿈͚ͮΔɻ·ͨɺChartͷઃఆ͸ΦϒδΣΫτܗ ࣜͰ౉͢ɻ νϟʔτͷछྨ͸type:Ͱࢦఆ͢Δɻ’line’ʹ͢ΔͱʮϥΠ ϯνϟʔτʯʹͳΔɻ σʔλ͸ɺdata.datasets ʹରͯ͠ɺΦϒδΣΫτͷ഑ྻ Λ౉͢ɻΦϒδΣΫτ͸߲໨਺෼༻ҙ͢Δɻ ֤߲໨ͷΦϒδΣΫτ಺ͷʮdataʯʹදࣔ͢ΔσʔλΛ ઃఆ͢Δɻ

Slide 16

Slide 16 text

Chart.js ར༻ྫ2 !16 options: { scales: { xAxes: [{ type: 'time', distribution: 'series', time: { unit: 'day', displayFormats: {'day': 'YYYY-MM-DD'} }, scaleLabel: { display: true, labelString: '೔࣌' } }], yAxes: [{ ticks: { } }] } } ~ҎԼུ~ optionsΦϒδΣΫτΛ౉͢͜ͱͰɺX࣠΍Y࣠ ʹରͯ͠ͷઃఆ΋ՄೳʹͳΔɻ X࣠Λ࣌ܥྻʹ͢ΔͨΊʹɺtypeͰ’time’Λɺ distributionͰ’series’Λࢦఆ͢Δɻ X࣠ͷ஋Λ೔෇ܗࣜYYYY-MM-DDͰઃఆ͢Δɻ X࣠ʹࢦఆ͢ΔϥϕϧΛ’೔࣌’ʹ͢Δɻ

Slide 17

Slide 17 text

C3.js SVGʢScalable Vector GraphicsʣΛར༻͍ͯ͠Δɻ D3.jsΛwrapͯ͠ɺ࢖͍΍͍ͯ͘͢͠Δɻ άϥϑͷঢ়ଶʹΞΫηεͰ͖ΔAPI͕ଟ͍ɻ ಛ௃ɿ !17 URL: https://upbeat-einstein-a1e1ed.netlify.com/public/chart_c3.html

Slide 18

Slide 18 text

C3.js ར༻ྫ1 !18 c3.jsʹΑΔνϟʔτදࣔ
var chart = c3.generate({ bindto: '#chart', ~ҎԼུ~ D3.jsΛར༻͢ΔͨΊɺD3.jsͷࢦఆ͕ඞཁʹͳ Δɻ c3.js͸ɺಉ࣌ʹc3.cssͷࢦఆ΋ඞཁʹͳΔɻ divλάͰඳը͢ΔՕॴΛઃఆɻ c3.generateͰɺchartΦϒδΣΫτΛੜ੒

Slide 19

Slide 19 text

C3.js ར༻ྫ2 !19 grid: { x: { lines: [ {value: moment().format('YYYY-MM-DD'), text: 'ج४೔', position: 'start'}, ] }, y: { show: true, lines: [ {value: 0.0, text: 'ෆ҆ఆ', axis: 'y', position:’start'}, {value: 1.0, text: 'ߴௐ', axis: 'y', position: 'start'}, {value: -1.0, text: '௿ௐ', axis: 'y', position: 'start'}, ] } }, // animation: tansition duration: miliseconds transition: { duration: 5000 }, // sub chart(Experimental) subchart: {show: true} ~ҎԼུ~ X࣠ʹิॿઢΛೖΕΔ৔߹ɺgrid.x.linesʹର͠ ͯઃఆͷΦϒδΣΫτͷ഑ྻΛೖΕΔɻ Y࣠ʹิॿઢΛೖΕΔ৔߹ɺgrid.x.linesʹର͠ ͯઃఆͷΦϒδΣΫτͷ഑ྻΛೖΕΔɻ transition.duration Ͱɺνϟʔτͷඳը࣌ͷΞ χϝʔγϣϯॲཧ͕࣌ؒઃఆͰ͖Δɻ ࣮ݧػೳ͕ͩɺαϒνϟʔτ΋ࢦఆͰ͖Δɻ

Slide 20

Slide 20 text

Google Chart SVGΛར༻͍ͯ͠Δ σʔλςʔϒϧͰ͋Δgoogle.visualization.DataTable ͸ɺaddColumnͰ߲໨ΛɺaddRowsͰσʔλΛɺͦ ΕͧΕ௥ՃͰ͖Δɻ ಛ௃ɿ !20 URL: https://upbeat-einstein-a1e1ed.netlify.com/public/chart_google.html

Slide 21

Slide 21 text

Google Chart ར༻ྫ1 !21 const data = new google.visualization.DataTable(); data.addColumn('string', 'X'); data.addColumn('number', 'physical'); data.addColumn('number', 'sensitivity'); data.addColumn('number', 'intellectual'); data.addRows(chartData); const options = { 'title': 'Biorhythm Line Chart', 'width':900, 'height':500, hAxis: { title: 'Date', gridlines: {color: '#333', count: 10} }, vAxis: { title: 'Biorhythm PSI', gridlines: {color: '#333', count: 10} }, }; ~ҎԼུ~ දࣔσʔλ͸google.visualization.DatatTableͷΦ ϒδΣΫτΛੜ੒ͯ͠ɺͦ͜ʹઃఆ͢Δɻ දࣔ͢Δ߲໨͸addColumnͰݸʑʹ௥Ճ͢Δɻ දࣔσʔλ͸addRowsͰઃఆ͢Δɻઃఆσʔλ ͸ɺ[ [1,2,3,4], [5,6,7,8], [~ུ~], ... ]ͷΑ͏ʹೋ࣍ ݩ഑ྻɻʢ಺෦ͷ഑ྻཁૉ਺͸ɺ߲໨਺ʹ߹Θ ͤΔɻࠨͷྫͩͱ4ͭʣ දࣔσʔλҎ֎ͷઃఆ৘ใʢνϟʔτͷαΠζ ΍X࣠Y࣠ͷ৘ใͳͲʣ͸ɺΦϒδΣΫτʹઃఆ ͢Δɻ

Slide 22

Slide 22 text

Google Chart ར༻ྫ2 !22 const chart = new google.visualization.LineChart(document.getElementById('chart_div')); // printing png : // https://developers.google.com/chart/interactive/docs/printing const my_chart_div = document.getElementById('linechart_png'); google.visualization.events.addListener(chart, 'ready', function () { my_chart_div.innerHTML = ''; }); chart.draw(data, options); google.visualizetion.LineChartͰϥΠϯνϟʔτͷΦ ϒδΣΫτΛੜ੒ getImageURIϝιουΛར༻͢Ε͹ɺνϟʔτͷΠ ϝʔδਤ΋औಘՄೳɻ ϥΠϯνϟʔτʹΠϕϯτ΋௥ՃՄೳ ϕʔλ൛ͰʮϚςϦΞϧ൛ͷϥΠϯνϟʔτʯ΋ ར༻Ͱ͖ΔɻʢϚ΢εΦʔόʔ࣌ͷॲཧͳͲ͕߽ ՚ʹͳ͍ͬͯΔɻʣ ϚςϦΞϧ༻ͷϥΠϯνϟʔτʹ͢Δʹ͸ɺ packageͰlineΛϩʔυɺgoogle.charts.LineΦϒδΣ Ϋτੜ੒ɺϚςϦΞϧ༻ͷoptionsͷม׵͕ඞཁɻ google.charts.load('current', {packages: ['corechart', 'line']}); ɹɹɹɹɹɹ~தུ~ const chart = new google.charts.Line(document.getElementById('linechart_material')); chart.draw(data, google.charts.Line.convertOptions(options)); ɹɹɹɹɹɹ~ҎԼུ~

Slide 23

Slide 23 text

·ͱΊ Netlify͸Ϛδศར ChartϥΠϒϥϦ΋͘͢͝ศར νϟʔτ͕άϦάϦಈ͘ͱςϯγϣϯ্͕Δ ࣗ෼͕ੌ͍͜ͱ͍ͯ͠Δؾ࣋ͪʹͳΕΔʢࡨ֮େࣄʣ ඇಉظॲཧ͸͜Ε͔Β޷͖ʹͳ͍ͬͯ͘ !23

Slide 24

Slide 24 text

ͪΐͬͱ͚ͩ JavaScript͕ ޷͖ʹͳΕ·ͨ͠ !24

Slide 25

Slide 25 text

༨ஊɿάϥϑͱνϟʔτͷҧ͍ άϥϑʢgraphʣ νϟʔτʢchartʣ ݪଇ͸ಉٛɻͨͩ͠ɺνϟʔτͷํ͕ཧղͤ͞Δҙ͕ࣝߴ͍ɻ !25 ɾάϥϑɺਤදɺਤࣜ ɾมԽ͢Δ਺ࣈ΍ଌఆ஋ͷؒͷؔ܎Λࣔͨ͢Ίʹઢ΍ۂઢΛ࢖͏ֆ ɾ਺ྔͷ࣌ؒมԽ΍େখؔ܎ɺׂ߹ͳͲΛɺࢹ֮తʹදݱͨ͠ਤ ɾւਤɺਫ࿏ਤɺߤۭ༻ͷνϟʔτɺւਤΛਤදʹࡌͤΔɻ ɾਤදɺάϥϑɺද ɾཧղ͠΍͍͢Α͏ͳํ๏Ͱ৘ใΛࣔ͢Ϧετɺඳըɺάϥϑɻʢϑϩʔνϟʔτ΋ʣ ɾ৘ใͷࢹ֮తදࣔɺਤɾදɾάϥϑ౳ͷ͜ͱ

Slide 26

Slide 26 text

༨ஊɿsvgͱcanvasͷҧ͍ svg ϕΫλʔܗࣜͰඳըɻ֦େɾॖখͰਤܗͷྼԽ͕ͳ͍ canvas ϥελʔܗࣜͰඳըɻϐΫηϧ୯ҐͰͷࡉ͔͍ඳը͕ߦ͑Δɻ ϕΫλʔܗ͔ࣜϥελʔʢϏοτϚοϓʣܗ͔ࣜͷҧ͍ɻ !26 ※৘ใҾ༻ݩɿ URL: https://qiita.com/ryuichi1208/items/95057c253844dc7d2454