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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

2回答

3765閲覧

円が重なっているかの判定がよくわかりません

KonnRori

総合スコア8

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2016/07/31 17:16

###前提・実現したいこと
円が衝突したら円の色が変わるプログラムの実行がうまくできません。どうしたらいいですか。

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

エラーメッセージ

###該当のソースコード
package l;

public class MyOval {
private int xPosition; //円の始点のx座標を保持するフィールド変数
private int yPosition; //円の始点のy座標を保持するフィールド変数
private int radius; //円の半径を保持するフィールド変数
private int colorRed; //円の色(赤の要素)を保持するフィールド変数
private int colorGreen; //円の色(緑の要素)を保持するフィールド変数
private int colorBlue; //円の色(青の要素)を保持するフィールド変数

//コンストラクタ public MyOval(int x,int y,int radius1,int red,int green,int blue){ xPosition=x; yPosition=y; radius=radius1; colorRed=red; colorGreen=green; colorBlue=blue; } //コンストラクタ public MyOval(int x2,int y2,int radius2){ xPosition=x2; yPosition=y2; radius=radius2; colorRed=0; colorGreen=0; colorBlue=255; } //円の始点のX座標を返す public int getX(){ return xPosition; } //円の始点のY座標を返す public int getY(){ return yPosition; } //円の半径を返す public int getR(){ return radius; } //赤色の要素を返す public int getRed(){ return colorRed; } //緑色の要素を返す public int getGreen(){ return colorGreen; } //青色の要素を返す public int getBlue(){ return colorBlue; } //赤色の要素を設定する public void setRed(int red){ colorRed=red; } //緑色の要素を設定する public void setGreen(int green){ colorGreen=green; } //青色の要素を設定する public void setBlue(int blue){ colorBlue=blue; } //円が重なっているかの判定 public boolean isCollision(MyOval MyOval){ int x1=MyOval.getX(); int y1=MyOval.getY(); int r1=MyOval.getR(); int x2=MyOval.getX(); int y2=MyOval.getY(); int r2=MyOval.getR(); if((x1-x2)*2+(y1-y2)*2<=(r1+r2)*2){ return true; } return false; }

}

package p3;

import java.applet.Applet;
import java.awt.Color;
import java.awt.Graphics;

import l.MyOval;
public class Applett extends Applet{
public void paint(Graphics g){

MyOval o2= new MyOval(30,20,80);//一つ目の円の設定 //色が青なら if(o2.getBlue()==255){ g.setColor(Color.blue);//青色を設定 } g.fillOval(o2.getX(), o2.getY(), o2.getR(), o2.getR());//一つ目の円を描画 MyOval o1= new MyOval(100,10,80,50,50,50);//二つ目の円の設定 MyOval k = o2; //円が重なっている場合 if(o1.isCollision(k)==true){ g.setColor(Color.red);//赤色を設定 g.fillOval(o1.getX(), o1.getY(), o1.getR(), o1.getR());//二つ目の円を描画 } //円が重なっていない場合 if(o1.isCollision(k)==false){ g.setColor(Color.green);//緑色を設定 g.fillOval(o1.getX(), o1.getY(), o1.getR(), o1.getR());//二つ目の円を描画 } }

}

###試したこと
課題に対してアプローチしたことを記載してください

###補足情報(言語/FW/ツール等のバージョンなど)
より詳細な情報

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

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

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

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

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

kei344

2016/07/31 17:21

コードはコードブロックで囲んでいただけませんか? ```(バッククオート3つ)で囲み、前後に改行をいれるか、コードを選択して「</>」ボタンを押すとコードブロックになります。
guest

回答2

0

単純な高校数学ですね。
「2つの円が重なる」条件は、2つの円の中心同士の距離が、2つの円の半径の和よりも小さく、差よりも大きいことです。

「一方が他方に完全に取り込まれている」状態も考えるのであれば後半の「差より大きい」は不要です。

投稿2016/07/31 17:21

編集2016/07/31 17:25
swordone

総合スコア20651

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

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

0

うまくいかないとはどううまくいかないのでしょう?
コードをちゃんと見たわけではありませんが、常に赤になってます?

java

1int x1=MyOval.getX(); 2int y1=MyOval.getY(); 3int r1=MyOval.getR(); 4int x2=MyOval.getX(); 5int y2=MyOval.getY(); 6int r2=MyOval.getR();

チェック関数内で、同じオブジェクトからデータを取っているからじゃないでしょうか?
これだと x1=x2, y1=y2, r1=r2 ではないかと思います。
そうすると常にtureが返ると思います。

投稿2016/07/31 17:36

hirohiro

総合スコア2068

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問