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

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

新規登録して質問してみよう
ただいま回答率
85.48%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Unity3D

Unity3Dは、ゲームや対話式の3Dアプリケーション、トレーニングシュミレーション、そして医学的・建築学的な技術を可視化する、商業用の開発プラットフォームです。

Unity

Unityは、Unity Technologiesが開発・販売している、IDEを内蔵するゲームエンジンです。主にC#を用いたプログラミングでコンテンツの開発が可能です。

Q&A

解決済

1回答

5664閲覧

Unity)HTMLタグをテキストに反映させたい

navesanta

総合スコア198

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Unity3D

Unity3Dは、ゲームや対話式の3Dアプリケーション、トレーニングシュミレーション、そして医学的・建築学的な技術を可視化する、商業用の開発プラットフォームです。

Unity

Unityは、Unity Technologiesが開発・販売している、IDEを内蔵するゲームエンジンです。主にC#を用いたプログラミングでコンテンツの開発が可能です。

0グッド

1クリップ

投稿2019/03/22 08:25

CSVデータを参照してprefabのテキストに入れて表示したいのですが
データの一部がHTMLです。

質問はHTMLタグで囲まれている箇所の色を赤にしたいのですが
HTMLをラップするような良い方法分かる方教えて下さい。

環境)
PC: mac
Unity2018.2
言語:C#

CSVデータ:ReadCsv.catecsvDatas

こんにちわ!私は<font color="red">太郎</font>です。 こんにちわ!私は<font color="red">花子</font>です。 さようなら<font color="red">太郎</font>さん。 さようなら。
using System.Collections; using System.Collections.Generic; using UnityEngine; public class ScrollController : MonoBehaviour { [SerializeField] GameObject prefab; // ButtonのPrefab [SerializeField] GameObject panel; // オブジェクト紐づけ先のPanel // Start is called before the first frame update void Start() { for (int i=0; i < 3; i++) { var item = GameObject.Instantiate(prefab) as GameObject; item.transform.SetParent(panel.transform, false); item.GetComponent<Text>().text = ReadCsv.catecsvDatas[i][0]): } }

イメージ説明

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

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

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

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

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

guest

回答1

0

ベストアンサー

UnityにはリッチテキストというHtmlタグに似たものがあるので該当タグをリッチテキストに置換するのがシンプルかと思います。

簡単な実装サンプル

イメージ説明

リッチテキストを有効にするにはTextコンポーネントのRich Textを有効にする必要があります。

イメージ説明

HtmlタグをRich Textタグに変換するスクリプト
変換文字列に正規表現を使えばもっとシンプルになると思いますが、すみませんがあまり詳しくありません。

C#

1using System.Text; 2 3public static class HtmlTagToRichTextCombater 4{ 5 /// <summary> 6 /// 削除する文字 7 /// </summary> 8 static readonly string[] DeleteWords = 9 { 10 "\"", "'" 11 }; 12 13 /// <summary> 14 /// 変換する文字 15 /// </summary> 16 static readonly string[][] ReplaceWords = 17 { 18 new string[]{"<font ", "<"}, 19 new string[]{"< font ", "<"}, 20 new string[]{"</font", "</color"}, 21 new string[]{"</ font", "</color"} 22 }; 23 24 /// <summary> 25 /// HTMLタグをリッチテキストに変更する 26 /// </summary> 27 /// <returns>The tag to rich text.</returns> 28 /// <param name="stg">Stg.</param> 29 public static string HtmlTagToRichText(this string stg) 30 { 31 StringBuilder sb = new StringBuilder(stg); 32 33 foreach (var word in DeleteWords) 34 { 35 sb.Replace(word, string.Empty); 36 } 37 38 foreach (var words in ReplaceWords) 39 { 40 sb.Replace(words[0], words[1]); 41 } 42 43 return sb.ToString(); 44 } 45} 46

利用側

C#

1using UnityEngine; 2using UnityEngine.UI; 3 4public class HtmlTagToRichTextTest : MonoBehaviour 5{ 6 [SerializeField] Text TextRender; 7 8 const string Txt = "こんにちわ!私は<font color=\"red\">太郎</font>です。\nこんにちわ!私は<font color=\"red\"> 花子</font>です。\nさようなら<font color=\"red\"> 太郎</font>さん。\nさようなら。"; 9 10 void Start () 11 { 12 //HTMLタグをリッチテキストに変換してTextに表示 13 TextRender.text = Txt.HtmlTagToRichText(); 14 } 15}

最後に

CSVデータはUnityで扱えないので

[追記]
CsVはUnity上で扱えます。エクセル形式(xml)と勘違いしておりました。
xmlはビルドしてもビルド内に含まれませんがCSVは含まれて割と簡単に中身を取り出せますが、ScriptableObjectの方が負荷も少なく軽いのでオススメです。下記はエクセル形式(xml)からScriptableObjectへの変換方法です。エクセルをお持ちであれば簡単にCsVをエクセル形式(xml)に変換できます。
[追記終了]

ScriptableObjectに変換すると良いと思います。
変換のタイミングでHTMLタグも合わせて変換すればパフォーマンスも良くなると思います。

もしUnity-Excel-Importer-Makerを使うとすればEditorフォルダ内に変換用スクリプトが出力されるので、簡単に好きな処理を挟むことができオススメです。

投稿2019/03/22 13:00

編集2019/03/23 17:25
IShix

総合スコア1724

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

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

navesanta

2019/03/23 01:39

HTMLを変換する方法理解しました。 ScriptableObjectとUnity-Excel-Importer-Makerも今まで知らなかった知識なので 大変参考になります。今までUnityの参考書は10冊ほど読みましたがどこにも 書いてなかった情報です。ありがとうございました。これからもよろしくお願いします。
IShix

2019/03/23 17:14

本10冊はすごいですね!僕なら心が折れそうですw すみません、1点間違ってました。Unity-Excel-Importer-MakerはCSVではなくエクセル形式(xls)を変換するプラグインです。エクセルお持ちでしたらCSVからエクセル形式へ変換可能です。 いつもマスターデータ(レベルバランス、アイテムの詳細、キャラの詳細)はすべてGoogleスプレッドシートで制作して、Excelデータとして出力しUnity上でScriptableObjectに変換して利用しています。 そうするとGoogleスプレッドシート上でソートや動的に計算したものを共有したり、アイテムやキャラの翻訳を依頼したりなど楽なのでおすすめです。
navesanta

2019/03/24 00:30

>CsVはUnity上で扱えます。 そうですよね。実際に扱っています。 >エクセルお持ちでしたらCSVからエクセル形式へ変換可能 実はエクセルデータをあえてCSVに変換して使っていたので 仰る方法は大変有用です。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問