ILI9341TFTタッチスクリーンディスプレイシールドのビットマップアニメーション
コンポーネントと消耗品
> ![]() |
| × | 1 | |||
| × | 1 |
アプリとオンラインサービス
> ![]() |
| |||
![]() |
|
このプロジェクトについて
ILI9341ベースのTFTタッチスクリーンディスプレイシールド 非常に人気のある低コストのディスプレイシールド Arduino の場合 。 Visuino かなり長い間サポートされてきましたが、使い方のチュートリアルを書く機会はありませんでした。ただし、最近、 Visuino でのディスプレイの使用について質問する人はほとんどいませんでした。 、それでチュートリアルを作ることにしました。
このチュートリアルでは、シールドを Arduino に接続するのがいかに簡単かを紹介します。 、 Visuino でプログラムします ビットマップをアニメーション化して、ディスプレイ上を移動します。
ステップ1:コンポーネント <図>
data:image/s3,"s3://crabby-images/f571d/f571dadcbc32c593da3204741dcf7e55ff10bae5" alt=""
- 1つの Arduino Uno 互換性のあるボード(Megaでも動作する可能性がありますが、シールドはまだテストしていません)
- Arduino用の ILI9341 2.4 "TFTタッチスクリーンシールド1つ
ステップ2:ILI9341TFTタッチスクリーンディスプレイシールドをArduinoに接続する <図>
data:image/s3,"s3://crabby-images/3d93e/3d93e3e339902db8cc3d3bcc7f7fad60ddd19110" alt=""
data:image/s3,"s3://crabby-images/81de1/81de138d443041e53e96140c90c8c4ea7a42d770" alt=""
data:image/s3,"s3://crabby-images/4838d/4838dc8704fd53e1c4d99d951aedaf9e099bfe5b" alt=""
TFTシールドを接続します Arduino Uno の上に 写真に示されているように。
ステップ3:Visuinoを起動し、TFTディスプレイシールドを追加します <図>
data:image/s3,"s3://crabby-images/ddc73/ddc733d2b504a431905fce4400dce53090919407" alt=""
data:image/s3,"s3://crabby-images/2648d/2648de3fa72eb1c83d024a4a78175d2d7344481d" alt=""
Arduinoのプログラミングを開始するには、 Arduino IDE が必要です。 ここからインストール:http://www.arduino.cc/。
必ず1.6.7以降をインストールしてください。インストールしないと、このチュートリアルは機能しません!
Visuino :https://www.visuino.comもインストールする必要があります。
- Visuino を開始します 最初の写真に示されているように
- [下に矢印]をクリックします ドロップダウンメニューを開くためのArduinoコンポーネントのボタン(写真1 )
- メニューから[シールドを追加... ]を選択します "(写真1 )
- 「シールド」 []ダイアログで[ディスプレイ]を展開します 「」カテゴリをクリックし、「 TFTカラータッチスクリーンディスプレイILI9341シールド」を選択します。 "をクリックし、[ + ]をクリックします 追加するボタン(写真2 )
ステップ4:Visuinoの場合:テキストシャドウの描画テキスト要素を追加します <図>
data:image/s3,"s3://crabby-images/644ee/644ee9110096a8dbe255450a4c8d06597ebe4fe8" alt=""
data:image/s3,"s3://crabby-images/a0b7c/a0b7cbc8bde2df8d70230e109b1e02ba8bc0a07d" alt=""
data:image/s3,"s3://crabby-images/5454f/5454fcdc1f55f38d7e02e7126b2e9faf47a6d53d" alt=""
data:image/s3,"s3://crabby-images/f2157/f215705f72775c5c8a2dcf73e89b2bca82adc241" alt=""
data:image/s3,"s3://crabby-images/644ee/644ee9110096a8dbe255450a4c8d06597ebe4fe8" alt=""
data:image/s3,"s3://crabby-images/75f36/75f36c8b20c32c7d4f6bae43fcdac30c0d6467f7" alt=""
次に、テキストとビットマップをレンダリングするためのグラフィック要素を追加する必要があります。まず、テキストの影を描くためのグラフィック要素を追加します:
- オブジェクトインスペクターで、[ ... ]をクリックします 「要素」の値の横にある「」ボタン 「 TFTディスプレイの」プロパティ "要素(写真1 )
- 要素エディタで「テキストの描画」を選択します 」をクリックし、[ + ]をクリックします "ボタン(写真2 )1つ追加します(写真3 )
- オブジェクトインスペクターで、「色」の値を設定します " Draw Text1 の"プロパティ "要素から" aclSilver "(写真3 )
- オブジェクトインスペクターで、「サイズ」の値を設定します " Draw Text1 の"プロパティ "要素から" 4 "(写真4 )。これにより、テキストが大きくなります
- オブジェクトインスペクターで、「テキスト」の値を設定します " Draw Text1 の"プロパティ "要素から" Visuino "(写真5 )
- オブジェクトインスペクターで「 X 」の値を設定します " Draw Text1 の"プロパティ "要素から" 43 "(写真6 )
- オブジェクトインスペクターで「 Y 」の値を設定します " Draw Text1 の"プロパティ "要素から" 278 "(写真6 )
ステップ5:Visuinoの場合:テキストの前景に描画テキスト要素を追加します <図>
data:image/s3,"s3://crabby-images/b8272/b8272ad22f1d747ea53223389cb4ad8f4f16b552" alt=""
data:image/s3,"s3://crabby-images/2b392/2b3925cdc0fd83ada747214c14e99f559d0141a6" alt=""
data:image/s3,"s3://crabby-images/68e08/68e089e75ebda1a573c61bb5f9340dca9dc2cbb4" alt=""
data:image/s3,"s3://crabby-images/d4018/d40189ac25dd0bce1dc0e838879a1f6a57593f7c" alt=""
次に、テキストを描画するためのグラフィック要素を追加します:
- 要素エディタで「テキストの描画」を選択します 」をクリックし、["]ボタンをクリックします(写真1 )2番目のものを追加します(写真2 )
- オブジェクトインスペクターで、「サイズ」の値を設定します " Draw Text1 の"プロパティ "要素から" 4 "(写真2 )
- オブジェクトインスペクターで、「テキスト」の値を設定します " Draw Text1 の"プロパティ "要素から" Visuino "(写真3 )
- オブジェクトインスペクターで「 X 」の値を設定します " Draw Text1 の"プロパティ "要素から" 40 "(写真4 )
- オブジェクトインスペクターで「 Y 」の値を設定します " Draw Text1 の"プロパティ "要素から" 275 "(写真4 )
ステップ6:Visuinoの場合:アニメーションの描画ビットマップ要素を追加します <図>
data:image/s3,"s3://crabby-images/e6c35/e6c351ddcbcb9ff1eac7e6e7f35a8f8bbbe9c62c" alt=""
data:image/s3,"s3://crabby-images/4a46f/4a46ff6332b82a1509563b1b3f4b3e4884a1eda5" alt=""
data:image/s3,"s3://crabby-images/9cea9/9cea90139578068949fbc93c7dfea3424f06a76a" alt=""
data:image/s3,"s3://crabby-images/1dd08/1dd08ae068928069fba7b87fc2ea9f0967e57a4f" alt=""
data:image/s3,"s3://crabby-images/7d4c3/7d4c3c997ea5d92900ab15e758904c9971ee2523" alt=""
次に、ビットマップを描画するためのグラフィック要素を追加します:
- 要素エディタで「ビットマップの描画」を選択します 」をクリックし、["]ボタンをクリックします(写真1 )1つ追加します(写真2 )
- オブジェクトインスペクターで、[ ... ]をクリックします 「ビットマップ」の値の横にある「」ボタン " Draw Bitmap1 の"プロパティ "要素(写真2 )「ビットマップエディタ」を開きます "(写真3 )
- 「ビットマップエディタ」 "[読み込み... ]をクリックします "ボタン(写真3 )[ファイルを開く]ダイアログを開きます(画像4 )
- [ファイルを開く]ダイアログで、描画するビットマップを選択し、[開く]をクリックします。 "ボタン(写真4 )。ファイルが大きすぎると、Arduinoメモリに収まらない可能性があります。コンパイル中にメモリ不足エラーが発生した場合は、小さいビットマップを選択する必要がある場合があります
- 「ビットマップエディタ」 「 OK をクリックします 。」ボタン(写真5 )ダイアログを閉じる
ステップ7:Visuinoの場合:描画ビットマップ要素のXプロパティとYプロパティのピンを追加します <図>
data:image/s3,"s3://crabby-images/91ec1/91ec1634628d332301073d28bb36bfc91f887e14" alt=""
data:image/s3,"s3://crabby-images/26082/2608284ed128c034870c47b108632b19981639ad" alt=""
data:image/s3,"s3://crabby-images/4a46f/4a46ff6332b82a1509563b1b3f4b3e4884a1eda5" alt=""
data:image/s3,"s3://crabby-images/0a7e1/0a7e1a65ac75a339304437ec3f552533b6996d0d" alt=""
ビットマップをアニメーション化するには、XとYの位置を制御する必要があります。このために、XプロパティとYプロパティのピンを追加します。
- オブジェクトインスペクターで[ピン]をクリックします 「 X 」の前にある「」ボタン " Draw Bitmap1 の"プロパティ "要素(写真1 )、[ Integer SinkPin ]を選択します "(写真2 )
- オブジェクトインスペクターで[ピン]をクリックします 「 Y 」の前にある「」ボタン " Draw Bitmap1 の"プロパティ "要素(写真3 )、[ Integer SinkPin ]を選択します "(写真4 )
ステップ8:Visuinoの場合:2つの整数正弦波ジェネレーターを追加し、最初のジェネレーターを構成します <図>
data:image/s3,"s3://crabby-images/faf05/faf05f69c4c21da61d720df59bcb4797573f2828" alt=""
data:image/s3,"s3://crabby-images/0fd13/0fd13358f2a6e85a67943c486bc91241ec804d14" alt=""
data:image/s3,"s3://crabby-images/b5c0c/b5c0cbefcd5527931600c57b7e861d61f7b2c466" alt=""
data:image/s3,"s3://crabby-images/f0f13/f0f1334bc84477156475ecb3b04f77306e895454" alt=""
ビットマップの動きをアニメーション化するために、2つの整数正弦波ジェネレーターを使用します。
- 「正弦」と入力します [コンポーネントツールボックス]の[フィルター]ボックスで、[正弦整数ジェネレーター]を選択します。 "コンポーネント(写真1 )、 2つをドロップします デザインエリアにあります
- オブジェクトインスペクターで、「振幅」の値を設定します " SineIntegerGenerator1 のプロパティ 「 96 」のコンポーネント "(写真2 )
- オブジェクトインスペクターで、「オフセット」の値を設定します " SineIntegerGenerator1 のプロパティ 「 96 」のコンポーネント "(写真3 )
- オブジェクトインスペクターで、「頻度」の値を設定します " SineIntegerGenerator1 のプロパティ 「 0.2 」へのコンポーネント "(写真4 )
ステップ9:Visuinoの場合:2番目の正弦波ジェネレーターを構成し、正弦波ジェネレーターをビットマップのX座標ピンとY座標ピンに接続します <図>
data:image/s3,"s3://crabby-images/9aab6/9aab6d1f57a6d3319095fb0fff5ee2cf9abe5449" alt=""
data:image/s3,"s3://crabby-images/a1aac/a1aac40b106be1e5f18849c4c6523b17f3199bda" alt=""
data:image/s3,"s3://crabby-images/a1228/a1228c9c0f9a50788e2cd331a185762fc9d12acf" alt=""
data:image/s3,"s3://crabby-images/a5706/a5706cc088a8d38833cc51408543156a82c53f35" alt=""
data:image/s3,"s3://crabby-images/76b58/76b589528e69626599c4c4a503bea6ae74010d53" alt=""
- オブジェクトインスペクターで、「振幅」の値を設定します " SineIntegerGenerator2 のプロパティ 「 120 」のコンポーネント "(写真1 )
- オブジェクトインスペクターで、「オフセット」の値を設定します " SineIntegerGenerator2 のプロパティ 「 120 」のコンポーネント "(写真2 )
- オブジェクトインスペクターで、「頻度」の値を設定します " SineIntegerGenerator2 のプロパティ コンポーネントを「 0.03 "(写真3 )
- 「アウト」を接続します " SineIntegerGenerator1 の出力ピン 「 X 」のコンポーネント 「 Shields.TFTSisplay.Elements.Draw Bitmap1 の入力ピン " Arduino の要素 コンポーネント(写真4 )
- 「アウト」を接続します " SineIntegerGenerator2 の出力ピン 「 Y 」のコンポーネント " Shields.TFT Display.Elements.Draw Bitmap1 の入力ピン " Arduino の要素 コンポーネント(写真5 )
ステップ10:Visuinoの場合:StartおよびClockマルチソースコンポーネントを追加して接続します <図>
data:image/s3,"s3://crabby-images/f9deb/f9deb1936ebc69e4767131145a67ba81a4a301aa" alt=""
data:image/s3,"s3://crabby-images/ede34/ede34e89528412c176d46ecabec4b6cea3158420" alt=""
data:image/s3,"s3://crabby-images/fcc60/fcc607f07282fe33f1813969e4e3076f2236b499" alt=""
data:image/s3,"s3://crabby-images/7135a/7135a22233a3316e007a66a60e095b87a76adf2c" alt=""
data:image/s3,"s3://crabby-images/4635f/4635f95465f3c74b2d9a509e78f94a86797a3571" alt=""
data:image/s3,"s3://crabby-images/cb2be/cb2bee3ec7084475d2cd41e7375bf355c92c1f40" alt=""
XとYの位置が更新されるたびにビットマップをレンダリングするには、「DrawBitmap1」要素にクロック信号を送信する必要があります。位置が変更された後にコマンドを送信するには、イベントを同期する方法が必要です。このために、Repeatコンポーネントを使用して常にイベントを生成し、Clock MultiSourceを使用して2つのイベントを順番に生成します。最初のイベントは正弦波ジェネレーターをクロックしてXとYの位置を更新し、2番目のイベントは「DrawBitmap1」をクロックします:
- 「繰り返し」と入力します [コンポーネントツールボックス]の[フィルター]ボックスで、[繰り返し]を選択します。 "コンポーネント(写真1 )、デザインエリアにドロップします(写真2 )
- 「マルチ」と入力します [コンポーネントツールボックス]の[フィルター]ボックスで、[クロックマルチソース]を選択します。 "コンポーネント(写真2 )、デザインエリアにドロップします(写真3 )
- 「アウト」を接続します " Repeat1 の出力ピン 「 In 」のコンポーネント " ClockMultiSource1 の入力ピン コンポーネント(写真3 )
- 「ピン[0] 」を接続します 「出力」の出力ピン " ClockMultiSource1 のピン 「 In 」のコンポーネント " SineIntegerGenerator1 の入力ピン コンポーネント(写真4 )
- 「ピン[0] 」を接続します 「出力」の出力ピン " ClockMultiSource2 のピン 「 In 」のコンポーネント " SineIntegerGenerator1 の入力ピン コンポーネント(写真5 )
- 「ピン[1] 」を接続します 「時計の」出力ピン " Shields.TFT Display.Elements.Draw Bitmap1 の入力ピン " Arduino の要素 コンポーネント(写真6 )
ステップ11:Arduinoコードを生成、コンパイル、アップロードする <図>
data:image/s3,"s3://crabby-images/0f0d4/0f0d40a2180b93f00591af2208b40f650cf24098" alt=""
data:image/s3,"s3://crabby-images/960bc/960bc8d564a13517d55dc2347fd138453c1c5aeb" alt=""
- Visuino 、 F9 を押します または、写真1 に表示されているボタンをクリックします Arduinoコードを生成し、ArduinoIDEを開きます
- Arduino IDE 、アップロードをクリックします ボタンをクリックして、コードをコンパイルしてアップロードします(写真2 )
ステップ12:そしてプレイ... <図>
data:image/s3,"s3://crabby-images/a2b43/a2b43016e26d7de58665808a6bfcddcfd23f6ff3" alt=""
data:image/s3,"s3://crabby-images/3d742/3d742a438f4f061275eedd6d78e69265a5d22193" alt=""
data:image/s3,"s3://crabby-images/0c9ad/0c9ad459f0c7875ee20b44798146d6cb51a10197" alt=""
data:image/s3,"s3://crabby-images/b0acf/b0acf39e6575cfbc98eac4a2066b28582361f9b7" alt=""
data:image/s3,"s3://crabby-images/b8e74/b8e740bb160f106ca9bf75e2f5682ed24539893d" alt=""
おめでとうございます! プロジェクトが完了しました。
写真2、3、4、5 とビデオ 接続され、電源が入っているプロジェクトを表示します。ビットマップが ILI9341ベースのTFTタッチスクリーンディスプレイシールドの周りを移動しているのがわかります。 ビデオで見られるように 。
写真1 完全な Visuino を見ることができます 図。 Visuino も添付されています このチュートリアル用に作成したプロジェクトと、 Visuino を使用したビットマップ ロゴ。ダウンロードして Visuino で開くことができます :https://www.visuino.com
FPHWHL0IV0AHJLX.zip
製造プロセス