http://csharpimage.blog60.fc2.com/blog-entry-18. …
をみて、単純間引きによる拡大縮小を C言語風に書こうとしているのですが、
rescale[i+j] =layer[(int)xpos+(int)ypos];部分がよくわかりません。
24bppのRawファイル(RGB)を拡大縮小しようとしています。
rescale[i+j] =layer[(int)xpos+(int)ypos];の
layer[(int)xpos+(int)ypos];部分をどうしたらいいのか悩んでいます。
layer:24bppRawを読み込むメモリ
アドバイスお願い致します。m(___)m
FILE *fpt_output;
int width=Common_Data_Raw->width;
int height=Common_Data_Raw->height;
// 拡大縮小後の画像サイズ
int hxSize=Common_Data_Raw->width_rescale;
int hySize=Common_Data_Raw->height_rescale;
// 拡大縮小用
int xSize=width;
int ySize=height;
double xpos, ypos;
double hokanX = (double)xSize / hxSize;
double hokanY = (double)ySize / hySize;
unsigned char *layer,*rescale;
//読み込み
layer=(unsigned char*)malloc(3*width*height*sizeof(unsigned char));
fread(&layer[0],sizeof(unsigned char),3*width*height,fpt);
//拡大縮小後のサイズ
rescale=(unsigned char*)malloc(3*hxSize*hySize*sizeof(unsigned char));
ypos = 0.0;
for (int i = 0; i < 3*hxSize*hySize; i+= 3*hxSize)
{
xpos = 0.0;
for (int j=0;j<3*hxSize;j+=3)
{
// 単純補間・間引き
rescale[i+j] =layer[(int)xpos+(int)ypos];
rescale[i+j+1]=layer[(int)xpos, (int)ypos];
rescale[i+j+2]=layer[(int)xpos, (int)ypos];
xpos += hokanX;
}
ypos += hokanY;
}
_wfopen_s(&fpt_output,L"output.raw",L"wb");
fwrite(&rescale[0],sizeof(unsigned char),3*width*height,fpt_output);
fclose(fpt);
fclose(fpt_output);
free(layer);
free(rescale);
return 0;
No.1ベストアンサー
- 回答日時:
二次元配列を使っている元のプログラムのrescaleから、一次元配列のこのプログラムにするのにどうしましたか?
rescale[x,y] を rescale[ y * hxsize + x ]にしてますよね?
( 実際には、RGB3プレーン分で 3*(i * hxsize + j)ですが)
同じように、layer[x.y]は layer[y * width +x]です
(同様に3プレーンで3倍です)
注意しなければいけないのは、yposがdoubleである点です。
小数点以下があると、 その分だけ横にずれてしまいます。なので、*widthの前にintにしておく必要があります
rescale[i+j] =layer[((int)xpos+((int)ypos)* width)*3];
rescale[i+j+1] =layer[((int)xpos+((int)ypos)* width)*3+1];
rescale[i+j+2] =layer[((int)xpos+((int)ypos)* width)*3+2];
ちなみに、私なら
・画像の座標の計算をやりやすくために、0≦i<hySize,0≦j<hxSizeにする
・doubleを足していくと誤差がたまるので、その都度xpos,yposを計算する
ということで
for (int i = 0; i < hySize; ++ i)
{
ypos = i * hokanY ;
for (int j=0;j<hxSize; ++ j)
{
// 単純補間・間引き
xpos = j * hokanX;
int rescalep=3*(i * hxSize +j);
int layerp=3*((int)ypos * width+ (int)xpos);
rescale[rescalep] =layer[layerp];
rescale[rescalep+1] =layer[layerp+1];
rescale[rescalep+2] =layer[layerp+2];
}
}
はじめまして!こんにちは!
分かりやすい説明ありがとうございました!!
とってもよくわかりました。><
無事に実装できました☆
ありがとうございます!m(__)m
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# 並列プログラミングのπ計算について 1 2022/07/16 22:30
- C言語・C++・C# C言語 共用体について コマンドライン引数で値を2つ入力したときに、argv[2]の値をUNI u1 4 2022/04/25 20:34
- C言語・C++・C# バイナリファイルをコピーするのにかかる時間を測りたいのですが実行するとFatel error:gli 2 2022/11/03 01:10
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
- C言語・C++・C# Cのdoubleの浮動小数点表示について 3 2023/04/17 13:14
- C言語・C++・C# このプログラミング誰か教えてくれませんか 1 2022/06/02 15:27
- C言語・C++・C# c言語配列の結合についてです。 なぜうまくいかないのでしょうか。 #include <stdio.h 4 2022/05/30 22:42
- C言語・C++・C# #include <stdio.h>int main(void) { int buf[100] = 6 2022/11/01 22:45
- C言語・C++・C# c言語の問題です 課題1 (二分探索木とセット) 大きさ size の配列 array を考える。す 2 2023/01/10 21:08
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C言語での引数の省略方法
-
「指定されたキャストは有効で...
-
#define _CRT_SECURE_NO_WARNIN...
-
【C++】関数ポインタの使い方
-
C言語 エラーの原因がわからな...
-
複数桁10進数の*桁目だけを抽出...
-
if と配列の組み合わせ
-
実数の整数部,小数部の取得
-
Arduinoのプログラムにエラーが...
-
数字列を3桁ごとにカンマで区切...
-
system関数がうまくいかない
-
アスタリスクでダイヤ型を作る
-
main関数以外での結果の表示?
-
read関数をノンブロッキングで...
-
プログラミング☆
-
c++でテンプレートのコードでわ...
-
ラップ関数とはどんなものですか?
-
c言語の配列を使ってサイコロを...
-
このプログラミング誰か教えて...
-
ファイル操作を教えてください
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
複数桁10進数の*桁目だけを抽出...
-
へんな現象
-
【C++】関数ポインタの使い方
-
C言語 エラーの原因がわからな...
-
if と配列の組み合わせ
-
C言語での奇数の和
-
C言語 配列と関数の練習問題
-
ラップ関数とはどんなものですか?
-
(int *)の意味
-
C言語
-
実数の整数部,小数部の取得
-
足して100になるような乱数のア...
-
卒業研究でよく分からないとこ...
-
数字列を3桁ごとにカンマで区切...
-
c言語
-
std::set<int> で、ある値が何...
-
比較回数と交換回数表示について
おすすめ情報