質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.31%
Google Charts

Google Chartsは、円グラフ・棒グラフ・折れ線グラフなどのさまざまなグラフをJavaScriptで容易に表示できる無料のライブラリ。デザインやイベント処理といったカスタマイズができ、商用利用も可能です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

1回答

1423閲覧

googlechart tooltipの表示設定について

domingojapan

総合スコア26

Google Charts

Google Chartsは、円グラフ・棒グラフ・折れ線グラフなどのさまざまなグラフをJavaScriptで容易に表示できる無料のライブラリ。デザインやイベント処理といったカスタマイズができ、商用利用も可能です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

1クリップ

投稿2022/05/03 00:58

概要

googlechartを利用してScatterChart(散布図)の作成をしています。

<html> <head> <script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script> <script type="text/javascript"> google.charts.load('current', {'packages':['corechart','scatter']}); google.charts.setOnLoadCallback(drawChart); function drawChart () { var data = new google.visualization.DataTable(); data.addColumn('number', 'Hours Studied'); data.addColumn('number', 'Final'); data.addColumn('number', 'Semi-Final'); data.addColumn('number', 'Quarter-Final'); data.addColumn({type: 'string', role: 'tooltip'}); data.addRows([ [0,67, null, null,'ac'], [1,88, null, null,'bg'], [2,77, null, null,'ca'], [0,null, null, 86,'dl'], [3,null, 55, null,'er'], [4,null, null, 95,'fp'], [2, 50, null, null,'gu'], [2, null, 60, null,'hp'], ]); var options = { series: { 0: {pointShape: 'square', pointSize: 15}, 1: {pointShape: 'diamond', pointSize:15}, 2: {pointShape: 'circle', pointSize:15} }, colors: ['red', 'blue', 'orange'], title: 'Students\' Final Grades', titleTextStyle:{ fontSize: 24, fontName: 'Meiryo UI', }, backgroundColor: '#f0f8ff', hAxis: {title: 'Class', titleTextStyle:{fontSize:18, bold:true}}, vAxis: {title: 'Score', titleTextStyle:{fontSize:18, bold:true}}, legend: 'none', }; var chart = new google.visualization.ScatterChart(document.getElementById('scatterchart_material')); chart.draw(data, google.charts.Scatter.convertOptions(options)); } </script> </head> <body> <div id="scatterchart_material"></div> </body> </html>

のhtmlソースで
イメージ説明

の図を表示させる所までできています。

想定外の現象内容

今回質問したいのはtooltipの表示設定に関する内容になります。
図でいう"Quarter-Final"となるポイントの
[0,null, null, 86,'dl'],
[4,null, null, 95,'fp'],
についてはツールチップがそれぞれ’dl’,’fp’と、自分が今実装したhtmlファイルとしては
想定どおりの表示がされるのですが、
それ以外のポイントについては想定どおりの表示がされません。例えば

  • リスト[0,67, null, null,'ac']のツールチップの表示は「Final 0,67」
  • リスト[1,88, null, null,'bg']のツールチップの表示は「Final 1,88」
  • リスト[2, null, 60, null,'hp']のツールチップの表示は「Semi-Final 2,60」
  • リスト[3,null, 55, null,'er']のツールチップの表示は「Semi-Final 3,55」

とツールチップ表示されてしまいます。

質問

全ポイントでツールチップ列の文字列を表示させるには
どこの実装内容がまずいのかを御教授いただきたいです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

自己解決できました。

addColumnメソッドとaddRowsメソッドの実装を変更する事で
狙っていた処理を実現する事ができました。

- data.addColumn('number', 'Hours Studied'); - data.addColumn('number', 'Final'); - data.addColumn('number', 'Semi-Final'); - data.addColumn('number', 'Quarter-Final'); - data.addColumn({type: 'string', role: 'tooltip'}); - data.addRows([ - [0,67, null, null,'ac'], - [1,88, null, null,'bg'], - [2,77, null, null,'ca'], - [0,null, null, 86,'dl'], - [3,null, 55, null,'er'], - [4,null, null, 95,'fp'], - [2, 50, null, null,'gu'], - [2, null, 60, null,'hp'], - ]); // pointの各シリーズに対してtooltip列を追加するようにした + data.addColumn('number', 'Hours Studied'); + data.addColumn('number', 'Final'); + data.addColumn({type: 'string', role: 'tooltip'}); + data.addColumn('number', 'Semi-Final'); + data.addColumn({type: 'string', role: 'tooltip'}); + data.addColumn('number', 'Quarter-Final'); + data.addColumn({type: 'string', role: 'tooltip'}); + data.addRows([ + [0, 67, 'ac', null, null, null, null], + [1, 88, 'bg', null, null, null, null], + [2, 77, 'ca', null, null, null, null], + [0, null, null, null, null, 86, 'dl'], + [3, null, null, 55, 'er', null, null], + [4, null, null, null, null, 95, 'fp'], + [2, 50, 'gu', null, null, null, null], + [2, null, null, 60, 'hp', null, null], + ]);

投稿2022/05/03 14:34

domingojapan

総合スコア26

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.31%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問