Javaプログラミング学習サイト ゆるゆるプログラミング

・Javaソースダウンロード(Gradation2.java)

放射状のグラデーション画像を作成するJavaソースコードです。画像の中心を開始位置として色を変化させていきます。画像の横と縦のピクセル、終了する円の半径ピクセル数、開始色と終了色をRGBで指定してPNG画像を作成します。

このソースについての記事はこちら「グラデーション画像(放射状)」です。

Gradation2.javaをダウンロード

ダウンロードしたファイルはzip形式です。解凍して使ってください。Windowsの場合、ダウンロードしたzipファイルをマウスの右ボタンでクリックして表示されるポップアップメニューから「すべて展開(T)」で解凍できます。

import java.awt.image.BufferedImage;
import java.io.File;
import javax.imageio.ImageIO;
import java.io.IOException;

public class Gradation2 {
	public static void main( String[] args ) {
		// 変数宣言
		int rd;		// 半径
		int w, h;	// 画像サイズ
		int cx, cy;	// 円の中心座標
		int r1, g1, b1;	// 開始色
		int r2, g2, b2;	// 終了色
		String outname;	// 出力ファイル名
		BufferedImage img = null;	// 画像格納クラス

		// 入力した引数が8以上かを調べる
		if ( 8 > args.length ) {
			// 入力した引数が8未満の場合、使用方法を表示する
			System.out.println( 
				"Gradation2 [PNG名][半径][R1][G1][B1][R2][G2][B2]" );
			return;
		}

		try {
			// 引数を変換し、半径に代入
			rd =  Integer.valueOf( args[ 1 ] );
			// 引数を変換し、開始色に代入
			r1 =  Integer.valueOf( args[ 2 ] );
			g1 =  Integer.valueOf( args[ 3 ] );
			b1 =  Integer.valueOf( args[ 4 ] );
			// 引数を変換し、終了色に代入
			r2 =  Integer.valueOf( args[ 5 ] );
			g2 =  Integer.valueOf( args[ 6 ] );
			b2 =  Integer.valueOf( args[ 7 ] );
		}
		catch( NumberFormatException ne )
		{
			System.out.println( "引数が不正です" );
			return;
		}
		// 出力PNG名をoutnameに代入(拡張子".png"省略なし)
		outname = args[ 0 ];

		// 画像サイズを半径から計算
		w = rd * 2 + 1;
		h = rd * 2 + 1;

		// 円の中心座標を計算
		cx = rd;
		cy = rd;

		// 新しい画像を作成
		// 24ビットカラーの画像を作成
		try {
			img = new BufferedImage( w, h,
						 BufferedImage.TYPE_INT_RGB );
		} catch ( Exception e ) {
			// 画像作成に失敗したときの処理
			e.printStackTrace();
			return;
		}

		// グラデーション作成
		int    x, y;
		int    color, r, g, b;	// 計算した色
		double l;			// 距離		
		double d;			// 距離		

		for ( y = 0; y < h; ++ y ) {
			for ( x = 0; x < w; ++ x ) {
				// 円の中心(cx,cy)と(x,y)との距離lを計算
				l = Math.sqrt( ( x - cx ) * ( x - cx ) + ( y - cy ) * ( y - cy ) );
				// 距離dを計算
				d = (double)l / (double)rd;

				// 色を計算
				r = (int)( (double)( r2 - r1 ) * d + (double)r1 );
				g = (int)( (double)( g2 - g1 ) * d + (double)g1 );
				b = (int)( (double)( b2 - b1 ) * d + (double)b1 );

				// 色を0~255の範囲に収める
				if ( 0 > r ) r = 0;
				if ( 255 < r ) r = 255;
				if ( 0 > g ) g = 0;
				if ( 255 < g ) g = 255;
				if ( 0 > b ) b = 0;
				if ( 255 < b ) b = 255;

				// r,g,bの色を合成
				color = ( r << 16 ) + ( g << 8 ) + b;

				// 合成した色を(x,y)に設定
				img.setRGB( x, y, color );
			}
		}

		try {
			// imgをoutname(出力PNG)に保存
			boolean result;
			result = ImageIO.write( img, "PNG", new File( outname ) );
		} catch ( Exception e ) {
			// outname(出力PNG)の保存に失敗したときの処理
			e.printStackTrace();
			return;
		}

		// 正常に終了
		System.out.println( "正常に終了しました" );
	}
}

このソースについての記事はこちら「グラデーション画像(放射状)」です。

 

■新着情報

2022.07.07 外部プログラムの実行 exeファイル実行
2022.07.06 完全数 6=1+2+3

■広告

 

 

 

 

Topへ