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

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

新規登録して質問してみよう
ただいま回答率
85.47%
文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

Processing

Processingは、オープンソースプロジェクトによるCGのためのプログラミング言語です。Javaをベースにしており、グラフィック機能に特化しています。イメージの生成やアニメーションなど、視覚的なフィードバックを簡単に得ることが可能です。

Q&A

解決済

2回答

3004閲覧

クリックした場所だけ色を変えたいです

kitayama_0625

総合スコア1

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

Processing

Processingは、オープンソースプロジェクトによるCGのためのプログラミング言語です。Javaをベースにしており、グラフィック機能に特化しています。イメージの生成やアニメーションなど、視覚的なフィードバックを簡単に得ることが可能です。

0グッド

0クリップ

投稿2020/05/29 07:08

電話番号のように数字の所を押すと押した所だけ色を変えたいです。

数字を押すと、縦一列全て色が変わってしまいます。
どのように改善すればよいでしょうか。
Processing初心者です。>

char[]kfont = {'1', '2', '3', '4', '5', '6', '7', '8', '9', '*', '0', '#'};//出力する文字
int[]fcnt = {0, 0, 0,};//ボタンの色を変える時間を計測

void setup() {
size(300, 400);
PFont f = createFont("Meiryo", 72);
textFont(f);
textAlign(CENTER, CENTER);
}

void draw() {
for (int i=0; i<3; i++) {
for (int j=0; j<4; j++) {
fill(255);
rect(35+i80, 50+j80, 75, 75);
if (fcnt[i]>0) {
fill(255, 0, 0);
fcnt[i]--;
} else {
fill(0);
}
text(kfont[i+3j], 75+i80, 75+j*80);
}
}
}

void mouseClicked() {

for (int i=0; i<3; i++) {
for (int j=0; j<4; j++) {
if (mouseX>(35+i80)&&
mouseX<(35+i
80)+75 &&
mouseY>50+j80 &&
mouseY<(50+j
80)+75) {//それぞれのボタンのサイズで押された場所の判定
fcnt[i]=10;
print(kfont[i+3*j]);
}
}
}
}

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

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

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

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

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

guest

回答2

0

ベストアンサー

int[]fcnt = {0, 0, 0,};//ボタンの色を変える時間を計測
ボタンの数必要ですね。

fcnt[i]もボタンに対応する必要があるのでこれでは間違ってる。
kfont[i+3*j]でボタンのテキスト出してるのだから…fcntも当然(略

java

1char[]kfont = {'1', '2', '3', '4', '5', '6', '7', '8', '9', '*', '0', '#'};//出力する文字 2int[]fcnt = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};//ボタンの色を変える時間を計測 3 4void setup() { 5 size(300, 400); 6 PFont f = createFont("Meiryo", 72); 7 textFont(f); 8 textAlign(CENTER, CENTER); 9} 10 11void draw() { 12 for (int i=0; i<3; i++) { 13 for (int j=0; j<4; j++) { 14 fill(255); 15 rect(35+i*80, 50+j*80, 75, 75); 16 if (fcnt[i+3*j]>0) { 17 fill(255, 0, 0); 18 fcnt[i+3*j]--; 19 } else { 20 fill(0); 21 } 22 text(kfont[i+3*j], 75+i*80, 75+j*80); 23 } 24 } 25} 26 27void mouseClicked() { 28 for (int i=0; i<3; i++) { 29 for (int j=0; j<4; j++) { 30 if (mouseX>(35+i*80)&& 31 mouseX<(35+i*80)+75 && 32 mouseY>50+j*80 && 33 mouseY<(50+j*80)+75) {//それぞれのボタンのサイズで押された場所の判定 34 fcnt[i+3*j]=10; 35 print(kfont[i+3*j]); 36 } 37 } 38 } 39}

投稿2020/05/29 08:21

rururu3

総合スコア5545

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

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

0

回答はrururu3さんの通りです。

手軽さをとるなら専用のライブラリを使うという選択肢もあります。
「ライブラリをインポート...」から入れられるControlP5を使うと、ボタン等が簡単に作れます。

Processing

1import controlP5.*; 2 3ControlP5 cp5; 4char[]kfont = {'1', '2', '3', '4', '5', '6', '7', '8', '9', '*', '0', '#'}; 5 6void setup() { 7 size(300, 400); 8 cp5 = new ControlP5(this); 9 ControlFont font = new ControlFont(createFont("Meiryo", 72)); 10 11 for (int i = 0; i < 3; i++) { 12 for (int j = 0; j < 4; j++) { 13 String label = str(kfont[i + 3 * j]); 14 cp5.addButton("btn" + label).setLabel(label).setFont(font) 15 .setPosition(35 + i * 80, 50 + j * 80).setSize(75, 75); 16 } 17 } 18} 19 20void draw() { 21} 22 23void btn1() { // ボタンの名前と同名関数で押したときの処理 24 println("btn1 clicked"); 25} 26 27void controlEvent(ControlEvent event) { // まとめて受ける場合 28 String name = event.getController().getName(); 29 if(name.equals("btn1")) return; 30 println(name + " clicked"); 31}

processing GUI, controlP5
アプリ画像

投稿2020/05/29 08:58

TN8001

総合スコア9326

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問