2020.03.23
画像の新規作成
はじめに
Javaソースコード
以下がそのソースコード例です。
CreateImage.java
001 002 003 004 005 006 007 008 009 010 011 012 013 014 015 016 017 018 019 020 021 022 023 024 025 026 027 028 029 030 031 032 033 034 035 036 037 038 039 040 041 042 043 044 045 046 047 048 049 050 051 052 053 054 055 056 057 058 059 060 061 062 063 064 065 066 067 068
import java.awt.image.BufferedImage; import java.io.File; import javax.imageio.ImageIO; import java.io.IOException; public class CreateImage { public static void main( String[] args ) { // 結果格納フラグ boolean result; // 画像サイズ int width, height; // ファイル名 String outname; // 画像格納クラス BufferedImage img = null; // 入力した引数が3つ以上かを調べる if ( 3 > args.length ) { // 入力した引数が3つ未満の場合、使用方法を表示する System.out.println( "CreateImage [出力PNG名] [幅] [高さ]" ); return; } // 出力PNG名をoutnameに代入(拡張子".png"省略なし) outname = args[ 0 ]; try { // 幅ピクセルをwidthに代入 width = Integer.parseInt( args[ 1 ] ); // 高さピクセルをheightに代入 height = Integer.parseInt( args[ 2 ] ); } catch ( NumberFormatException e ) { // 引数をwidth、heightの変換に失敗したときの処理 e.printStackTrace(); return; } // 画像サイズの検査 if ( ( 1 > width ) || ( 1 > height ) ) { // 画像のサイズに1より小さい値が指定されたとき処理 System.out.println( "画像サイズが範囲外です" ); return; } // 24ビットカラーの画像を作成 try { img = new BufferedImage( width, height, BufferedImage.TYPE_INT_RGB ); } catch ( Exception e ) { // 画像作成に失敗したときの処理 e.printStackTrace(); return; } // 24ビットカラーの画像を作成 try { // imgをoutname(出力PNG)に保存 result = ImageIO.write( img, "png", new File( outname ) ); } catch ( Exception e ) { // outname(出力PNG)の保存に失敗したときの処理 e.printStackTrace(); return; } // 正常に終了 System.out.println( "正常に終了しました" ); } }
コンパイル ソースコードが「ANSI」の場合
C:\talavax\javasample>javac -encoding sjis CreateImage.java
コンパイル ソースコードが「UTF-8」の場合
C:\talavax\javasample>javac CreateImage.java
実行
C:\talavax\javasample>java CreateImage createimage.png 256 128
・作成した画像(createimage.png)
Javaソースコードの解説
ここからは、このソースコードを上から順番に解説していきます。
001 002 003 004
import java.awt.image.BufferedImage; import java.io.File; import javax.imageio.ImageIO; import java.io.IOException;
Javaのクラスライブラリの中から「java.awt.image.BufferedImage」と「java.io.File」と「javax.imageio.ImageIO」と「java.io.IOException」というパッケージにあるクラスを、このプログラム内で使うために記述します。 この記述により、ImageIOクラスとBufferedImageクラスが利用できるようになります。
006
public class CreateImage {
クラス名を、CreateImageとしています。
007
public static void main( String[] args ) {
このmainメソッドからプログラムを実行します。
008 009 010 011 012 013 014 015
// 結果格納フラグ boolean result; // 画像サイズ int width, height; // ファイル名 String outname; // 画像格納クラス BufferedImage img = null;
017 018 019 020 021 022
// 入力した引数が3つ以上かを調べる if ( 3 > args.length ) { // 入力した引数が3つ未満の場合、使用方法を表示する System.out.println( "CreateImage [出力PNG名] [幅] [高さ]" ); return; }
024 025
// 出力PNG名をoutnameに代入(拡張子".png"省略なし)
outname = args[ 0 ];
027 028 029 030 031 032 033 034 035 036
try { // 幅ピクセルをwidthに代入 width = Integer.parseInt( args[ 1 ] ); // 高さピクセルをheightに代入 height = Integer.parseInt( args[ 2 ] ); } catch ( NumberFormatException e ) { // 引数をwidth、heightの変換に失敗したときの処理 e.printStackTrace(); return; }
038 039 040 041 042 043
// 画像サイズの検査 if ( ( 1 > width ) || ( 1 > height ) ) { // 画像のサイズに1より小さい値が指定されたとき処理 System.out.println( "画像サイズが範囲外です" ); return; }
045 046 047 048 049 050 051 052 053
// 24ビットカラーの画像を作成 try { img = new BufferedImage( width, height, BufferedImage.TYPE_INT_RGB ); } catch ( Exception e ) { // 画像作成に失敗したときの処理 e.printStackTrace(); return; }
BufferedImageコンストラクタ
BufferedImage( int width, int height, int imageType )
・新しい BufferedImage を構築します。 パラメータ width : 構築する画像の横ピクセル height : 構築する画像の縦ピクセル imageType : 構築する画像のイメージ形式
try { ~ } catchは、失敗する可能性がある処理を波括弧で囲み、その処理に失敗したときにcatch { ~ }の波括弧で囲まれた処理を実行するということです。この場合は、PNGファイル名が不正であったり、存在していなかったり、フォーマットが違っているなどが原因で処理が失敗する可能性があります。処理が失敗するとreturnによってmainメソッドを抜けるようにしています。
055 056 057 058 059 060 061 062 063
// 24ビットカラーの画像を作成 try { // imgをoutname(出力PNG)に保存 result = ImageIO.write( img, "png", new File( outname ) ); } catch ( Exception e ) { // outname(出力PNG)の保存に失敗したときの処理 e.printStackTrace(); return; }
BufferedImageクラスのimgのメモリ内のデータを、出力PNG名の変数(outname)に格納されているファイル名で保存します。この場合は、PNGファイル名が不正であったり、保存先のHDDなどが存在していなかったり、空き容量が少ないなどが原因で処理が失敗する可能性があります。
ImageIO.wrireメソッド
public static boolean write( RenderedImage im, String formatName, File output ) throws IOException
・BufferedImageを画像ファイルに保存します。 パラメータ RenderedImage : 保存するRenderedImage formatName : 画像ファイルのフォーマット(png/jpeg/bmp/gifなど) output : Fileオブジェクト 戻り値 保存に成功するとtrue、失敗するとfalseを返します。
065 066
// 正常に終了 System.out.println( "正常に終了しました" );
全ての処理が正常終了すると、ここまで処理が実行されます。
以上です。
関連コンテンツ
一般に使われている画像フォーマットには、いろいろな種類があります。画像フォーマットBMP、JPEG、PNG、GIF、TIFFの特徴を知ってますか?
ファイルは、データを取り扱うとき管理単位の一つで、ハードディスク、SSD,USBメモリ、CD/DVD/ブルーレイなどの記憶媒体に保存するときに使われます。詳しくは、記事をご覧ください。
数値を2進数で表したときの各桁の「0」と「1」に対して演算を行えます。4種類の演算、AND(論理積)、OR(論理和)、XOR(排他的論理和)、NOT(否定)を詳しく説明しています。