人に聞けない痔の悩み、これでスッキリ >>

添付画像のように、サイズ(X,Y)の画像があったとします。
その画像のある座標(X',Y')とサイズを指定してできた短形領域を、IplImageとして保存するにはどうすればいいのでしょうか?
OpenCVを使ってるのですが、そういった関数はなかったでしょうか?
よろしくお願いします。

「OpenCVを使った画像の切り抜き」の質問画像

A 回答 (1件)

 こんにちは。



 cvSetImageROI()で領域指定です。以下参考程度に。
 http://opencv.jp/sample/initialization.html

int main()
{
//イメージをロード
IplImage* ipl = ::cvLoadImage("test.bmp", CV_LOAD_IMAGE_ANYDEPTH | CV_LOAD_IMAGE_ANYCOLOR);

//x=10, y=10から64x32でROIを設定
::cvSetImageROI(ipl, ::cvRect(10, 10, 64, 32));

//ROIを設定した状態でセーブ
::cvSaveImage("result.bmp", ipl);

//ROIの解除
::cvResetImageROI(ipl);

//イメージの解放
::cvReleaseImage(&ipl);

return 0;
}
    • good
    • 1
この回答へのお礼

できました!
そういえばcvSetImageROIという関数がありましたね。
ありがとうございました!

お礼日時:2009/11/28 22:57

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

このQ&Aを見た人はこんなQ&Aも見ています

このQ&Aを見た人が検索しているワード

このQ&Aと関連する良く見られている質問

QOpenCV でのROIの指定方法について

いつもお世話になっております.
OpenCVに関する質問です.
FastFeatureDetectorやGoodFeaturesToTrackDetector等の特徴点検出器を入力画像の特定の部分に対して行うために,入力画像に対してROIを設定したのですが上手くいかない場合があって困っています.

たとえば,
入力画像(640*480)に対して,
左上(0,0)右下(640,480)や左上(0,0)右下(320,240)を矩形領域を指定すれば上手くいくのですが,
左上(10,10)右下(640,480)や左上(320,240)右下(640,480)だと,結果がズレてしまいます.

下記のソースコードで
---------------------------------------------------------------
cv::Rect* roi = new cv::Rect(roi_x, roi_y, roi_w, roi_h);
cv::Mat* InuptImage = new cv::Mat(640, 480, CV_8UC1, data);//dataはbyte型
InuptImage = new cv::Mat(*InuptImage, *roi);
---------------------------------------------------------------
(roi_x, roi_y, roi_w, roi_y)が
(0, 0, 640, 480)や(0, 0, 320, 240)の場合は上手くいくのですが,
(10, 10, 630, 470)や(320, 240, 320, 240)の場合には,特徴点の位置がずれたり,全体的に縮小されたりします.

どこに問題があるのでしょうか?

OpenCVは2.3で,言語はC++です.
アドバイス宜しくお願い致します.

いつもお世話になっております.
OpenCVに関する質問です.
FastFeatureDetectorやGoodFeaturesToTrackDetector等の特徴点検出器を入力画像の特定の部分に対して行うために,入力画像に対してROIを設定したのですが上手くいかない場合があって困っています.

たとえば,
入力画像(640*480)に対して,
左上(0,0)右下(640,480)や左上(0,0)右下(320,240)を矩形領域を指定すれば上手くいくのですが,
左上(10,10)右下(640,480)や左上(320,240)右下(640,480)だと,結果がズレてしまいます.

下記のソースコードで
---...続きを読む

Aベストアンサー

オフセットは必ず必要です。ROIを指定する前の画像の全体のサイズと、本来の画像の左上から、ROIの左上の座標のオフセットは、locateROI メソッドで取得することができます。

実際には、オフセットを考慮して点群座標を変換するか、特徴点を描画したい場合などでは、元の画像ではなく ROI で切り取った画像に対して描画を行います。


参考まで。



// okwave01.cpp : コンソール アプリケーションのエントリ ポイントを定義します。
//

#include "stdafx.h"
#include <opencv2/opencv.hpp>

int main(int argc, char argv[])
{
const std::string FILE_PATH("lena.jpg");
//sample.bmpは640*480のRGBの画像

cv::Mat rgb_img = cv::imread(FILE_PATH);
// 画像読み込み

cv::Mat gray_img;
cv::cvtColor(rgb_img, gray_img, CV_BGR2GRAY);
// グレースケール画像に変換

const cv::Point ROI_TL(rgb_img.rows * 0.25, rgb_img.cols * 0.25);
const cv::Rect RECT(
rgb_img.rows * 0.25, rgb_img.cols * 0.25,
rgb_img.rows * 0.5, rgb_img.cols * 0.5);
// 中心 だけを切り取る ROI を作成。

cv::Mat rgbimage_roi = rgb_img(RECT);
cv::Mat grayimage_roi = gray_img(RECT);
// ROI による切り取り。


std::vector<cv::KeyPoint> corners;
// FAST 頂点座標の保存用変数

cv::FAST(grayimage_roi, corners, 10, true);

for (auto it = corners.begin(); it != corners.end(); ++it) {
cv::circle(grayimage_roi, it->pt, 1, cv::Scalar(255), 2);
// ROI を通してグレイスケール画像に書き込む

cv::circle(rgb_img, ROI_TL + cv::Point2i(it->pt), 1, cv::Scalar(0, 0xff, 0), 2);
// オフセットを考慮して直接RGB画像に書き込む
}

cv::imshow("RGB IMAGE", rgb_img);
cv::imshow("GRAY IMAGE", gray_img);
return cv::waitKey();
}

オフセットは必ず必要です。ROIを指定する前の画像の全体のサイズと、本来の画像の左上から、ROIの左上の座標のオフセットは、locateROI メソッドで取得することができます。

実際には、オフセットを考慮して点群座標を変換するか、特徴点を描画したい場合などでは、元の画像ではなく ROI で切り取った画像に対して描画を行います。


参考まで。



// okwave01.cpp : コンソール アプリケーションのエントリ ポイントを定義します。
//

#include "stdafx.h"
#include <opencv2/opencv.hpp>

int main(int argc...続きを読む

QOpenCVによる連続静止画保存

OpenCVとVisual Studio 2005を使ってカメラ画像を出力し、キーを押すことで画像をファイルに保存しています。しかし、キーを押すたびに画像が上書きされてしまい、結局保存ファイルは一つだけになってしまい連続して画像ファイルが取得できません。下記のプログラムで下のほうに書いてあるcvSaveImage()関数にうまくカウンタを使ってやればいいと思うのですが、私の技量ではできませんでした。知っている方がいたら教えてください。よろしくお願いします。

//---------------------------------------------------------
// 概要 : カメラからの入力画像をそのまま表示
// File Name : image.c
// Library : OpenCV for MS-Windows 1.0
//---------------------------------------------------------

#include <stdio.h>
#include <highgui.h>

int main( int argc, char** argv ){
int key;//キー入力用の変数
CvCapture *capture;//カメラキャプチャ用の構造体
IplImage *frameImage;//キャプチャ画像用IplImage
char windowNameCapture[] = "Capture";//キャプチャした画像を表示するウィンドウの名前

//カメラを初期化する
if ( ( capture = cvCreateCameraCapture( -1 ) ) == NULL ) {
//カメラが見つからなかった場合
printf( "カメラが見つかりません\n" );
return -1;
}

//ウィンドウを生成する
cvNamedWindow( windowNameCapture, CV_WINDOW_AUTOSIZE );

//メインループ
while ( 1 ) {
//カメラからの入力画像1フレームをframeImageに格納する
frameImage = cvQueryFrame( capture );

//画像を表示する
cvShowImage( windowNameCapture, frameImage );

//'q'キーが入力されたらループを抜ける
key = cvWaitKey( 1 );
if ( key == 'q' ) {
break;
}else if( key == 'c'){
cvSaveImage("picture.bmp", frameImage );
}


}

//キャプチャを解放する
cvReleaseCapture( &capture );
//ウィンドウを破棄する
cvDestroyWindow( windowNameCapture );

return 0;
}

OpenCVとVisual Studio 2005を使ってカメラ画像を出力し、キーを押すことで画像をファイルに保存しています。しかし、キーを押すたびに画像が上書きされてしまい、結局保存ファイルは一つだけになってしまい連続して画像ファイルが取得できません。下記のプログラムで下のほうに書いてあるcvSaveImage()関数にうまくカウンタを使ってやればいいと思うのですが、私の技量ではできませんでした。知っている方がいたら教えてください。よろしくお願いします。

//------------------------------------------------...続きを読む

Aベストアンサー

OpenCV というよりも単に文字列の問題ですよね?
例えば以下のようにします。


int main( int argc, char** argv ){
  // 以下二行追加
  int counter = 0;
  char str[32];

  /* 省略 */

    key = cvWaitKey( 1 );
    if ( key == 'q' ) {
      break;
    } else if( key == 'c'){

      // 以下二行追加、修正
      sprintf(str, "img_%04d.bmp", counter++);
      cvSaveImage(str, frameImage );
    }

  /* 省略 */


VC2005 では sprintf() に警告が出るかもしれませんので、
問題があれば sprintf_s() などを使って下さい。

QLNK2019: 未解決の外部シンボルのエラーが出る

Microsoft Visual Studio 2008
Version 9.0.21022.8 RTM
Microsoft .NET Framework
Version 3.5 SP1
----------------------------------------------------------------
新しいプリジェクト→Win32 コンソール アプリケーション(ソリューションのディレクトリを作成 チェック外す)→Windows アプリケーション(空のプロジェクト チェック外す)
----------------------------------------------------------------
 プログラム

 mymain.cpp
#include "myhelper.h"
#include "mymain.h"

//自キャラのデータ
Point2D g_jikipos = {40, 400};//自キャラの座標

//画像ハンドル
int g_jikiimage[11];

//色々なファイルの読み込み
int LoadFiles(){
//画像ファイル読み込み
if(LoadDivGraph("media\\player01.bmp",
11,11,1,64,64,g_jikiimage) == -1) return -1;

return 1;
}


 mymain.h
//他から呼び出させるMyMainの関数
void MyMain();
int LoadFiles();


 myhelper.h(サンプルなので打ちミスはない)
#include "DxLib.h"
#include <limits.h>
#include <math.h>

//構造体宣言
//座標またはベクトルを記録する構造体
struct Vector{
float x,y;
};
typedef Vector Point2D;
//線を記録する構造体
struct Line2D{
Point2D startpos, endpos;
float katamuki;//傾きをラジアン値で記録
Vector speed;//移動している場合は速度をセット
};
//球体を記録する構造体
struct Ball2D{
Point2D position;
float hankei;//半径
};
//四角形を記録する構造体
struct Rect2D{
Point2D lefttop;
Point2D rightbottom;
float width;
float height;
};


//ライブラリ関数
Point2D PosInView(Point2D in);
int XInView(float inx);
int YInView(float iny);
void ScrollToLeft(float jikiposx);
void ScrollToRight(float jikiposx);
void ScrollToUp(float jikiposy);
void ScrollToDown(float jikiposy);
void DrawLineInView(float x1, float y1, float x2, float y2, int Color, int Thickness);
void DrawCircleInView(float x, float y, float r, int Color, int FillFlag);
void DrawAnimation(float x, float y, double ExtRate, double Angle,int TurnFlag,
int *imgarray, int allframe, float fps);
//ベクトル関数
Vector CreateVector(Vector in, float veclen);
Vector AddVector(Vector v1, Vector v2);
Vector SubVector(Vector v1, Vector v2);
Vector AddVectorInFrameTime(Vector pos, Vector speed);
Vector AddVectorInFrameTime2(Vector pos, Vector speed, Vector accel);
Vector Normalize(Vector in);
Vector RotateVector(Vector in, float radian);
float VectorLengthSquare(Vector in);
float DotProduct(Vector v1, Vector v2);
float CrossProduct(Vector v1, Vector v2);
void SetLine2DKatamuki(Line2D *in);
void DrawLine2D(Line2D in, int Color, int Thickness);
void DrawBall2D(Ball2D in, int Color, int Fill);
//当たり判定関数
bool HitTestLineAndBall(Line2D linein, Ball2D ballin);
bool IsPointAtLineFace(Line2D linein, Point2D ptin);
bool HitTestLineAndLine(Line2D line1, Line2D line2);
bool HitTestBallAndBall(Ball2D a, Ball2D b);
bool HitTestPointAndBox(Rect2D rect, Point2D pt);
//タイマー関数
void SetSimpleTimer(int idx, int time);
int GetPassedTime(int idx);


//グローバル変数
extern float g_frametime;
extern Rect2D g_framerect;//画面領域(当たり判定)
extern Point2D g_current_field_pos;//現在の左上座標
extern Rect2D g_stagesize;//ステージサイズ

//定数宣言
const float ZEROVALUE = 1e-10f;
const float PIE = 3.1415926f;
const int SCROLL_LIMIT = 200;
----------------------------------------------------------------
 エラー内容
1>myhelper.obj : error LNK2019: 未解決の外部シンボル "void __cdecl MyMain(void)" (?MyMain@@YAXXZ) が関数 _WinMain@16 で参照されました
1>C:\Documents and Settings\Owner\My Documents\Visual Studio 2008\Projects\my\Debug\my.exe : fatal error LNK1120: 外部参照 1 が未解決です
1>my - エラー 2、警告 0
ビルド: 0 正常終了、1 失敗、0 更新不要、0 スキップ
----------------------------------------------------------------
画像を貼り付けときます
(見えにくい場合→http://www.dotup.org/uploda/www.dotup.org154142.jpg.html)
初心者なのでわかりやすくお願いします

Microsoft Visual Studio 2008
Version 9.0.21022.8 RTM
Microsoft .NET Framework
Version 3.5 SP1
----------------------------------------------------------------
新しいプリジェクト→Win32 コンソール アプリケーション(ソリューションのディレクトリを作成 チェック外す)→Windows アプリケーション(空のプロジェクト チェック外す)
----------------------------------------------------------------
 プログラム

 mymain.cpp
#include "myhelper.h"
#include "mymain.h"

//自...続きを読む

Aベストアンサー

ファイル構成から推測するに
mymain.cpp というファイルに
void MyMain(void) {
// ここに処理を書く
}
という関数が必要なようです。

QOpenCVを使用してある物体だけの輪郭を抽出したいです。

OpenCVを使用してある物体だけの輪郭を抽出したいです。
下の画像だと赤い円を抽出したいのに、線も含めた輪郭が抽出されます。
なにか良い方法はありまあせんか?

Aベストアンサー

http://www.amazon.co.jp/dp/4839931593
に肌色を検出する方法として
色空間の変更(RGB→HSV)
→色相を「肌色に近い」と「肌色から遠い」に分けて2値化
→各種処理
というのが出ています。

赤を抽出するなら、同様にできるのではないでしょうか

Qfatal error LNK1120: 外部参照 1 が未解決です

またわからないことが・・・
教えて下さい。
以下をVC++2005でコンパイルすると、

MSVCRTD.lib(crtexew.obj) : error LNK2019: 未解決の外部シンボル _WinMain@16 が関数 ___tmainCRTStartup で参照されました。
C:\Documents and Settings\tomato\My Documents\Visual Studio 2005\Projects\a\Debug\a.exe : fatal error LNK1120: 外部参照 1 が未解決です。

と警告がでて通りません。
何のことでしょうか。

#include<stdio.h>
#include<process.h>

struct meibo{
  char name[20];
  char tel[20];
  char address[20];
};

void message( void );
void input( FILE *fp, int cnt , struct meibo *a, int *end );

void main( void )
{
  struct meibo a[20];
  FILE *fp;
  int cnt, end;

  if( (fp=fopen( "meibo.dat", "w" ) ) == NULL ){
    printf( "Can not open the meibo.dat.\n" );
    exit( 1 );
  }

  message();

  fprintf( fp, "番号, 名前, TEL, 住所\n" );
  fflush( fp );

  cnt = 0;
  end = 0;
  while( end == 0 ){
    input( fp, cnt, &a[cnt], &end );
    cnt++;
    fflush( fp );
    if( cnt == 20 ){
      printf( "人数が一杯です.終了します.\n" );
      end = 1;
    }
  }
  fclose( fp );
}

void message( void )
{
  printf( "名前, TEL, 住所, endを入力してください.\n" );
  printf( "継続の時はend=0," );
  printf( "中止の時は,end=1と入力してください.\n" );
}

void input( FILE *fp, int cnt, struct meibo *a, int *end )
{
  printf( "名前-->" );
  scanf( "%s", a->name );
  printf( "TEL -->" );
  scanf( "%s", a->tel );
  printf( "住所-->" );
  scanf( "%s", a->address );
  printf( "Exit? Continue:0 Exit:1 -->" );
  scanf( "%d", end );
  printf( "\n" );
  fprintf( fp, "%2d, %s, %s, %s\n",
    cnt+1, a->name, a->tel, a->address );
}

またわからないことが・・・
教えて下さい。
以下をVC++2005でコンパイルすると、

MSVCRTD.lib(crtexew.obj) : error LNK2019: 未解決の外部シンボル _WinMain@16 が関数 ___tmainCRTStartup で参照されました。
C:\Documents and Settings\tomato\My Documents\Visual Studio 2005\Projects\a\Debug\a.exe : fatal error LNK1120: 外部参照 1 が未解決です。

と警告がでて通りません。
何のことでしょうか。

#include<stdio.h>
#include<process.h>

struct meibo{
  char name[20];
...続きを読む

Aベストアンサー

http://www.a.math.ryukoku.ac.jp/~hig/course/compsci2_2005/man/faq.html
にある現象と同じではないでしょうか、一度お試しください。

QOpenCVでの画像サイズ取得について教えてください。

OpenCVでの画像サイズ取得について教えてください。
rawデータをjpgにして取得し、その画像を4分割したいのですがエラーが3つ出てしまいます。
環境はVisual Studio2008です。
いろいろと調べたのですが、原因や対策がはっきりわからず、書き変えてもNGで困っています。

エラー:その1
「error LNK2028:未解決のトークン(0A00007B)"extern "C" struct IplImage *_cdecl cvLoadImage(char const roi.obj*.int)"(cvLoadImage@@$$J0YAPAU IplImage@@PBDH@Z)が関数"int _codecl main(int,char * *)"(?main@@$$HYAHHPAPAD@Z)で参照されました。」
エラー:その2
「error LNK2019: 未解決の外部シンボル"extern "C" struct IplImage * codecl cvLoadImage(char const *.int)" (?cvLoadImage@@$$J0YAPAU IplImage@@PBDH@Z)が関数"int_codecl main(int, char * *)" (?main@@$$HYAHHPAPAD@Z)で参照されました。」
エラー:その3
「fatal error LNK1120: 外部参照2が未解決です]

'==================
#pragma warning(disable : 4819)
#include <cv.h>
#include <highgui.h>
#include <stdio.h>
#define DIVX (4)
#define DIVY (4)
#define DIVXY (DIVX*DIVY)

int main (int argc, char **argv)
{
int w, h

IplImage *img=0;
img=cvLoadImage("C:\・・・\\testfile.jpg, CV_LOAD_IMAGE_GRAYSCALE);

w = img->width - img->width % DIVX + DIVX;
h = img->height - img->height % DIVY + DIVY;

printf("幅は%w, 高さは%h です。 \n");
}
'===============================================

画像サイズを取得し、画像を4分割したあと、画素値を変更したいと思っています。
できればjpgに変換せず、rawデータそのものの精度の画像を直接扱いたいのですが、
その場合、cvLoadImageでどう表記すると実現できるのでしょうか。
また、OpenCVのグレースケールは、何チャンネルなのでしょうか。

プログラム経験はありますが、OpenCVを使うため、C言語の勉強も始めたばかりです。
なにか見当違いな質問をしていたら申し訳ありません。
お忙しいところすみませんが、もしどなたか解決策をアドバイスいただける方がいらっしゃると
大変助かります。
どうぞ宜しくお願い致します。

OpenCVでの画像サイズ取得について教えてください。
rawデータをjpgにして取得し、その画像を4分割したいのですがエラーが3つ出てしまいます。
環境はVisual Studio2008です。
いろいろと調べたのですが、原因や対策がはっきりわからず、書き変えてもNGで困っています。

エラー:その1
「error LNK2028:未解決のトークン(0A00007B)"extern "C" struct IplImage *_cdecl cvLoadImage(char const roi.obj*.int)"(cvLoadImage@@$$J0YAPAU IplImage@@PBDH@Z)が関数"int _codecl main(int,char * *)"(?main@@$$HYAHH...続きを読む

Aベストアンサー

>より幅のある数字の情報を元に、機械がもう少し緻密な判断ができるようにするには、
>通常は何チャンネルを使うのがいいでしょうか。

それは「チャンネル数」ではなく「深さ/精度」です。
グレースケールは「明るさ」というチャンネル1つで表わすものです。その数値の範囲に、たとえば8bit整数(0~255)とか16bit整数(0~65535)とかの「深さ」があります。
また、浮動小数点を使った表現もできます。32bit(float型相当)と64bit(double型相当)のものが使えます。

チャンネル数は例えば、明るさの他に色相,彩度の3チャンネルとか、RGBの3チャンネルとかです。

>(グレースケールにもRGBで表現させるなど、何パターンかあるようですが)
すべての色をR=G=Bにすれば、実質グレースケールです。RGBカラーにしか対応していないフォーマットでグレースケールを表現するときに使います。

>チャンネル数の問題ではなく、その後どういう処理をするか、がポイントでしょうか。

浮動小数点を使って精度を上げた方がよいケースも、逆に、2値化した方がいいケースもあります。

>より幅のある数字の情報を元に、機械がもう少し緻密な判断ができるようにするには、
>通常は何チャンネルを使うのがいいでしょうか。

それは「チャンネル数」ではなく「深さ/精度」です。
グレースケールは「明るさ」というチャンネル1つで表わすものです。その数値の範囲に、たとえば8bit整数(0~255)とか16bit整数(0~65535)とかの「深さ」があります。
また、浮動小数点を使った表現もできます。32bit(float型相当)と64bit(double型相当)のものが使えます。

チャンネル数は例えば、明るさの他に色相,彩度の3...続きを読む

QOpenCv 透明度について

OpenCv 透明度について

透明度を表すRGBAのA(アルファチャネル)をいじって画像の透明にしたいのですが、いじってみてもなにも変化がありません。
なにが悪いのかわかりません


↓こんな感じでやってます。

// 画像を読み込む
src_img = cvLoadImage(src_imgfile,CV_LOAD_IMAGE_COLOR);

//RGBA変換
dst_img = cvCreateImage(cvGetSize(bg_img),IPL_DEPTH_8U,4);
cvCvtColor(bg_img,dst_img,CV_RGB2RGBA);

//透明度をいじる
for ( int y = 0 ; y < dst_img->height ; y++ )
{
for ( int x = 0 ; x < dst_img->width ; x++ )
{

dst_img->imageData[dst_img->widthStep * y + x * 4 + 3] = -255;

}
}

Aベストアンサー

http://opencv.jp/opencv-2.1/c/drawing_functions.html
>また,この関数は,アルファ透過をサポートしません.目的画像が4チャンネルである場合でも color[3] には,単に新たなピクセル値がコピーされるだけです.したがって,もし半透明な形状を描画したい場合は,それを別のバッファに描画してから画像とブレンドするとよいでしょう.

http://opencv.jp/opencv-2.1/c/reading_and_writing_images_and_video.html
> cv::LoadImage
> 現在の実装では,アルファチャンネルがもしあったとしても,出力画像からは取り除かれることに注意してください.例えば,4チャンネルRGBA画像は,RGB画像として読み込まれます

>cv::SaveImage
> この関数では,8ビットシングルチャンネル,あるいは3チャンネル(チャンネルは ‘BGR’ の順番)画像のみを保存することができます


以上のように、4チャンネルの画像を作ることはできますが、それをファイルに読み書きしたり、画面表示したりはできません。
アルファチャンネルに対応した別のライブラリを使うなどの工夫が必要です。

http://opencv.jp/opencv-2.1/c/drawing_functions.html
>また,この関数は,アルファ透過をサポートしません.目的画像が4チャンネルである場合でも color[3] には,単に新たなピクセル値がコピーされるだけです.したがって,もし半透明な形状を描画したい場合は,それを別のバッファに描画してから画像とブレンドするとよいでしょう.

http://opencv.jp/opencv-2.1/c/reading_and_writing_images_and_video.html
> cv::LoadImage
> 現在の実装では,アルファチャンネルがもしあったとしても,出力画像からは取...続きを読む

Qopencvでの画像貼り付け

OpenCVを用いて,入力画像の右半分をコピーし、入力画像の右側に貼り付ける方法はどのようなものがあるのでしょうか。
コピーはROIだと思うのですが、貼り付ける方法が分かりません。

分かる方、よろしくお願いします。

こんな感じです。
入力画像が[1|2]とすると、
右半分[2]をコピーし、入力画像に貼り付け[1|2|2]

Aベストアンサー

 こんばんは。

 cvResize()ですと、
 http://opencv.jp/sample/sampling_and_geometricaltransforms.html
 イメージの拡大も行う為、[1|2a|2b]の出力画像を作成するしか無いかもしれません。
 手順としては、

(1)[1|2a|2b]の出力画像を作成。
(2)出力画像にROIを設定して[1|2a]の領域に制限。
(3)出力画像に向かって入力画像[1|2]をコピー。
(4)入力画像にROIを設定して[2]の領域に制限。
(5)出力画像に向かってROIを設定して[2b]の領域に制限。
(6)出力画像に向かって入力画像[2]をコピー。
(7)入力、出力画像のROIを解除してセーブ。

 です。
 以下は[1|2]で64x32、[1|2a|2b]で96x32です。もっと良い方法があるかもしれませんので、参考程度に。
 
int main()
{
//読み込み
IplImage* pSrc = ::cvLoadImage("test.bmp", CV_LOAD_IMAGE_ANYDEPTH | CV_LOAD_IMAGE_ANYCOLOR);

//(1)
IplImage* pNew = ::cvCreateImage(::cvSize(pSrc->width + 32, pSrc->height), pSrc->depth, pSrc->nChannels);

//(2)
::cvSetImageROI(pNew, ::cvRect(0, 0, pSrc->width, pSrc->height));

//(3)
::cvCopy(pSrc, pNew);

//(4)
::cvSetImageROI(pSrc, ::cvRect(32, 0, pSrc->width, pSrc->height));

//(5)
::cvSetImageROI(pNew, ::cvRect(pSrc->width, 0, 32, pSrc->height));

//(6)
::cvCopy(pSrc, pNew);

//(7)
::cvResetImageROI(pSrc);
::cvResetImageROI(pNew);
::cvSaveImage("result.bmp", pNew);

//後始末
::cvReleaseImage(&pNew);
::cvReleaseImage(&pSrc);
return 0;
}
 尚、プログラム内で使用を継続する場合は、pSrcを開放し、pNewを使用します。

 こんばんは。

 cvResize()ですと、
 http://opencv.jp/sample/sampling_and_geometricaltransforms.html
 イメージの拡大も行う為、[1|2a|2b]の出力画像を作成するしか無いかもしれません。
 手順としては、

(1)[1|2a|2b]の出力画像を作成。
(2)出力画像にROIを設定して[1|2a]の領域に制限。
(3)出力画像に向かって入力画像[1|2]をコピー。
(4)入力画像にROIを設定して[2]の領域に制限。
(5)出力画像に向かってROIを設定して[2b]の領域に制限。
(6)出力画像に向かって入力画像[2]をコピー。
...続きを読む

Q#include というヘッダファイルについて

お早う御座います。
Cの初心者です、宜しくお願いします。
「#include <Windows.h>」というヘッダファイルはどのようなプログラムを書いたときにincludeしてやる必要があるのでしょうか。
宜しくお願いします。

Aベストアンサー

VisualStudioなら、<Windows.h>の部分を右クリックして
「定義ファイルに移動」のような項目で中身を見れたと思います。
そこに定義されている関数や定数を使う場合にincludeしてあげる必要があります。
※Windows.hの中身は弄らないでください

QガウシアンフィルタのCプログラム

画像を平滑化する手法にガウシアンフィルタというものがあります。
現在、このガウシアンフィルタをCで作成しようとしていますが、いまいち分かりません。

自分なりに調べてみたところ、平滑化の移動平均フィルタやメディアンフィルタに関しては様々な書籍やサイトがあるのですが、ガウシアンフィルタに関してはあまり見つかりませんでした。

行いたい処理は、簡単に次の通りです。
画像ファイルの読み込み

フィルタ処理

処理後の画像をファイル出力

ガウシアンフィルタに関して詳しく書いてある書籍やサイトがあればお教え願います。できれば、ソースプログラムも書いてあると助かります。

当方、参考書籍として、「C言語で学ぶ実践画像処理-井上他」という本を使用しています。

Aベストアンサー

ググってみたところ
http://teo.sourceforge.jp/doc/TeoProgrammingGuide/section5-2.html
ここが最も分かりやすかったです。

f(x,y)=exp(-(x^2+y^2)/(2*sigma^2))
で、x,yはそれぞれ整数座標で計算すればよいようです。
上webページの説明だと、x,yそれぞれ-1~1の3x3座標、つまり注目座標の9近傍で打ち切っています。
その9個のf(x,y)の加算値をaとすると、ゲインが1となるようにf(x,y)/aを用います。(これを正規化と呼びます)


このQ&Aを見た人がよく見るQ&A

人気Q&Aランキング