Как создать файл BMP из данных RGB, хранящихся в файле TXT?
-
19-09-2019 - |
Вопрос
Я создаю изображение BMP из двух файлов TXT. Первый - это массив MXN:
* * * * * * * *
мнч
C11 C21 .. CM1
...
c1n C2n .. cmn
* * * * * * * *
* * * * * * * *
6 5
.7 .7 .6 1.0 1.2 .1
.9 .3 .7 1.1 .7 .2
1 1.1 1.2 1.3 1.7 .6
.5 .6 .5 .4 .9 .1101
2 .1 .1 .1 2.1 1.1
* * * * * * * *
Второй файл TXT - это цветовая шкала, как это
* * * * * * * *
min1 max1 r1 g1 b1
min2 max2 r2 g2 b2
...
Minx Maxx RX GX BX
* * * * * * * *
* * * * * * * *
0 .5 255 128 64
.5 .75 128 255 32
.75 1.25 64 64 225
01.50 5 128 128 0
* * * * * * * *
Итак, я читаю из этих двух файлов. Я пытался создать массив из первого файла TXT с использованием класса StringTokenizer, но я вообще потерян. Из двух файлов я создаю изображение BMP. Кто -нибудь может мне каким -то образом помочь?
Решение
Вздох ... Пока я написал программу, @jarnbjo объяснил ту же идею. Но здесь у вас есть код:
import java.awt.Graphics;
import java.awt.Image;
import java.awt.image.BufferedImage;
import java.util.NavigableMap;
import java.util.TreeMap;
import javax.swing.JFrame;
import javax.swing.JPanel;
public class ImageParser {
public static void main(String[] args) {
String dataContent =
"6 5\n" +
".7 .7 .6 1.0 1.2 .1\n" +
".9 .3 .7 1.1 .7 .2\n" +
"1 1.1 1.2 1.3 1.7 .6\n" +
".5 .6 .5 .4 .9 .1101\n" +
"2 .1 .1 .1 2.1 1.1";
String colorContent =
"0 .5 255 128 64\n" +
".5 .75 128 255 32\n" +
".75 1.25 64 64 225\n" +
"01.50 5 128 128 0";
int width = 0;
int height = 0;
BufferedImage image = null;
NavigableMap<Double, Integer> colorMap = new TreeMap<Double, Integer>();
for (String colorLine : colorContent.split( "\n" )) {
String[] colorValues = colorLine.split( " " );
colorMap.put( Double.parseDouble( colorValues[1] ),
Integer.parseInt( colorValues[2] ) << 16 |
Integer.parseInt( colorValues[3] ) << 8 |
Integer.parseInt( colorValues[4] ) );
}
boolean headerParsed = false;
int y = 0;
for( String dataLine : dataContent.split( "\n" ) ) {
String[] dataArray = dataLine.split( " " );
if( !headerParsed ) {
width = Integer.parseInt( dataArray[ 0 ] );
height = Integer.parseInt( dataArray[ 1 ] );
image = new BufferedImage( width, height, BufferedImage.TYPE_INT_RGB );
headerParsed = true;
}
else {
int x = 0;
for( String data : dataArray ) {
Integer rgbValue = colorMap.higherEntry( Double.parseDouble( data ) ).getValue();
image.setRGB( x, y, rgbValue );
x++;
}
y++;
}
}
JFrame frame = new JFrame();
frame.getContentPane().add( new Viewer( image, width, height, 20 ) );
frame.pack();
frame.setVisible( true );
}
static class Viewer extends JPanel {
Image m_image;
int m_width;
int m_height;
int m_zoom;
public Viewer( Image image, int width, int height, int zoom ) {
m_image = image;
m_width = width;
m_height = height;
m_zoom = zoom;
}
@Override
public void paint(Graphics g) {
g.drawImage( m_image, 0, 0, m_width * m_zoom, m_height * m_zoom, this );
}
};
}
Другие советы
Если цветовые диапазоны непрерывны (ваш пример отсутствует 1,25-1,5) и гарантированно охватывает все значения SOPPL в файле матрицы, я бы сначала построил TreeMap<Double, java.awt.Color>
, используя максимальное значение из цветового файла в качестве ключа карты. Затем вы можете использовать TreeMap#ceilingEntry(K)
Метод для получения цвета для любого значения матрицы. Например, если правильно заполнены вашими тестовыми данными, CeilingEntry (0,2) .getValue () вернет цвет (255,128,64).
Вместо того, чтобы читать матричный файл в массив, вы можете с легкостью напрямую использовать java.awt.BufferedImage
Чтобы нарисовать, а затем использовать javax.imageio.ImageIO
Чтобы написать буферное изображение как файл BMP.
В то же время (мне нужно больше времени, лол), я написал только код, чтобы сохранить в массиве первый файл матрицы :( Вот код, если вы хотите посмотреть, и это работает. Но на самом деле я на вашем . Я дам вам знать, чего я доберусь. Спасибо, ребята ...
import java.io.*;<br>
import java.util.StringTokenizer;
public class TokenizerUser4 {
public static double[][] matrix;
public static void main(String[] args) throws IOException {
FileReader reader = new FileReader
("D:\\sonenos\\java\\FlussiIO\\new\\matrix.txt");
BufferedReader br = new BufferedReader(reader);
String line;
int rowIndex = 0;
int counter = 0;
int[] dim = new int[3];
while ((line = br.readLine()) != null){
counter++;
if (counter == 1) {
StringTokenizer dimensioni = new StringTokenizer(line);
//int[] dim = new int[3];
int i = 0;
while(dimensioni.hasMoreTokens()){
dim[i] = Integer.parseInt(dimensioni.nextToken());
//System.out.println(dim[i] + " i=" + i);
i++;
}
matrix = new double[dim[0]][dim[1]];
}
if (counter != 1){
StringTokenizer theLine = new StringTokenizer(line);
int colIndex = 0;
while (theLine.hasMoreTokens()){
String st = theLine.nextToken();
matrix[rowIndex][colIndex] = Double.parseDouble(st);
colIndex = colIndex + 1;
}
rowIndex = rowIndex + 1;
}
}
for (int x = 0; x<dim[0];x++){
for (int y = 0; y<dim[1]; y++){
System.out.print(matrix[x][y] + " ");
}
System.out.println("\n");
}
br.close();
}
}