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

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

新規登録して質問してみよう
ただいま回答率
85.46%
Processing

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

Q&A

解決済

1回答

1834閲覧

魚のような動きを作りたい

退会済みユーザー

退会済みユーザー

総合スコア0

Processing

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

0グッド

1クリップ

投稿2021/06/02 08:15

前提・実現したいこと

魚の文字が魚のようにうねっているプログラミングを作成したいです。試しに魚の画像で作成して見たのですが,魚自体がうねりすぎて魚の形すらわからなくなりました。何かいい方法はないでしょうか。また,文字をうねらせる際にテキスト入力と文字の画像はどちらが扱いやすいでしょうか。

発生している問題・エラーメッセージ

エラーメッセージ

該当のソースコード

float theta;
float t;
float xspeed;
int direction=1;
PImage img;

void setup() {
size(500, 200);
smooth();
noStroke();
img = loadImage("sakana.png");
}

void draw() {
background(180, 200, 100);
t=20noise(1, 1);
fill(0);
for (int i=0; i<100; i++) {
image(img,i+xspeed, height/2+t
sin(theta+0.1i), 31, 31);
//ellipse(i+xspeed, height/2+t
sin(theta+0.1i), 31, 31);
}
theta+=0.1
direction;
xspeed+=0.7*direction;
}

ソースコード

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

thkana

2021/06/02 11:10

著作権上問題があるとかいうことでなければ、画像ファイルも貼り付けていただけませんか? 適当な画像を用意してやらないと試すこともできないので。 それと、プログラムは「あなたの指示したとおりに動く」だけのものです。あなたが「魚がうねるように」というのをちゃんと指示できないとコンピュータはそのようには動きません。また、「魚がうねるように」とだけ言われても私もどう考えていいのか困ります。 どのような動きを期待しているのか、図に描くとかできませんか?
guest

回答1

0

ベストアンサー

Processing:うねうねうごく物体 : PROCESSING入門

こちらが元ネタですね。
参考コードがある場合は質問に明示してください。

魚自体がうねりすぎて魚の形すらわからなくなりました。

そのページに「円を多数描いて」とあります。
コードの詳細は分からなくても、位置をずらしながらellipseを100回描いていることはわかると思います。

画像が重なっていけば、当然わけのわからない物体になるでしょう。

文字をうねらせる際にテキスト入力と文字の画像はどちらが扱いやすいでしょうか。

どちらにもメリット・デメリットがあるでしょう。
テキストベースなら文字を簡単に入れ替えられます。
画像ベースなら凝った色使いとか加工(目を入れるとか)も自在です。

魚の文字が魚のようにうねっているプログラミングを作成したいです。

やり方はいろいろあるでしょうが、今のコードを尊重してみました。
画像が重ならないように、縦に細切れにして描きました。

py0nnさんの思っている動きかは、自信がありませんが^^;

Processing

1float theta; 2float xspeed; 3int direction = 1; 4PImage img; 5 6PGraphics g; 7PImage[] images; 8 9void setup() { 10 size(500, 200); 11 smooth(); 12 noStroke(); 13 14 g = createGraphics(31, 31); // PGraphics(描き込めるPImageのようなもの)作成 15 g.beginDraw(); // 描画開始 16 //g.background(255); // 文字の大きさがちょうどいいか確認用 17 g.fill(0); 18 g.textFont(createFont("メイリオ", 20)); 19 g.textSize(20); 20 g.textAlign(CENTER, CENTER); // 上下左右の中央にテキストを描画 21 g.text("魚", 0, 0, g.width, g.height); // 描画範囲を全体に指定 ↑と合わせて大体中央に 22 g.endDraw(); // 描画終了 23 24 images = new PImage[g.width]; // 縦に1pxずつ細切れのPImage配列 25 for (int i = 0; i < g.width; i++) { 26 images[i] = g.get(i, 0, 1, g.height); 27 } 28} 29 30void draw() { 31 background(180, 200, 100); 32 float t = 20 * noise(1, 1); 33 fill(0); 34 35 for (int i = 0; i < 100; i++) { 36 ellipse(i + xspeed, height / 3 + t * sin(theta + 0.1 * i), 31, 31); 37 } 38 39 for (int i = 0; i < images.length; i++) { 40 image(images[i], i + xspeed, height / 3 * 2 + t * sin(theta + 0.1 * i)); 41 } 42 43 theta += 0.1 * direction; 44 xspeed += 0.7 * direction; 45 if (width < xspeed) xspeed = 0; // 画面外に行ったらもう一周 46 47 //image(g, 0, 0); // 文字がちゃんと書けているか確認用 48}

アプリ画像

投稿2021/06/02 10:36

TN8001

総合スコア9387

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

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

退会済みユーザー

退会済みユーザー

2021/06/03 05:30

ありがとうございます。思い描いていた動きです!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問