/* * ***************************************************************** * * * * * Copyright (c) Fast Corporation, 1997 * * * * * * All Rights Reserved. Unpublished rights reserved under * * * the copyright laws of the Japan. * * * * * * The software contained on this media is proprietary to * * * and embodies the confidential technology of Fast * * * Corporation. Possession, use, duplication or * * * dissemination of the software and media is authorized only * * * pursuant to a valid written license from Fast Corporation. * * * * * ***************************************************************** */ /* CSC90X 指定領域の画像拡大表示     ENLARGE .C */ /*[作成者]H.Yagi */ /* 目的: 関数: 履歴: Ver 1.0 99/01/26 注記: m_menu.hをインクルードして下さい。 m_menu.c及びm_note.cをリンクして下さい。 */ /* * Include compiler runtime library */ #include #include /* * Include CSC90X library */ #include "f_stdlib.h" #include "f_time.h" #include "f_gui.h" #include "f_stdio.h" #include "f_graph.h" #include "f_image.h" #include "f_pinf.h" #include "f_video.h" #include "f_system.h" #include "f_affine.h" #include "f_bgray.h" #include "f_filter.h" /* * Include CSC90X common local */ #include "m_menu.h" /* * プロトタイプ宣言 */ void main( void ); void main_menu_disp( void ); void disp_help( void ); void set( void ); void wind_set( int *, int *, int *, int * ); void back( int * ); void enlarge( int * ); void tool( void ); void ascope( int ); void filter_menu( void ); void filter( int, int * ); extern int message_note( void ); /* * メニュー項目 */ #define LANG_N 2 #define MAIN_MENU_N 4 static const char *str_main_menu[MAIN_MENU_N][LANG_N] = { { "  SET  ", " 設 定 " }, { " BACK ", " 戻 る " }, { " ENLARGE ", " 拡 大 " }, { " TOOL ", " ツール " } }; #define INIT_CUR_POS_X 255 #define INIT_CUR_POS_Y 239 typedef enum { RATE_FIX, RATE_NOT_FIX } dummy1; typedef enum { FILTER_AVERAGE, FILTER_LAPLACIAN, FILTER_MIN, FILTER_MAX, FILTER_1DIFF, FILTER_2DIFF, FILTER_ROBERTS, FILTER_SOBEL, FILTER_MEDIAN, FILTER_SHARP } dummy2; #define MAX_MEM_NO 15 int mem_no[MAX_MEM_NO]; static char ss[70]; int mcount; /*メモリ確保成功面数 */ int disp_idx; /*現在表示中のメモリ番号*/ int rate_mode; /*縦横比の保持モード */ int pad_level_tool; int pad_level_filter; /* * メイン */ void main( void ) { int sts; int xpos; int ypos; int s_xpos; int s_ypos; int i; /* 初期メッセージ表示 */ if( NORMAL_RETURN != message_note() ) return; /* パラメタ初期化 */ xpos = INIT_CUR_POS_X; ypos = INIT_CUR_POS_Y; s_xpos = INIT_CUR_POS_X; s_ypos = INIT_CUR_POS_Y; rate_mode = RATE_NOT_FIX; /* 入力ビデオ制御 */ Lib_input_video_control( GRAY_PLANE ); /* ビデオ出力表示項目制御 */ Lib_display_control( GRAY_PLANE | LINE_PLANE | CHAR_PLANE ); /* ビデオ表示項目クリア */ Lib_memory_clear( LINE_PLANE | CHAR_PLANE ); /* カーソル初期化 */ Lib_init_cursor(); /* グレイメモリ確保 */ mcount = 0; for( i=0; i MENU_1_XS && xpos < MENU_1_XE && ypos > MENU_1_YS && ypos < MENU_1_YE ) { Lib_memory_clear( LINE_PLANE | CHAR_PLANE ); set( ); /*設定*/ main_menu_disp(); } else if ( xpos > MENU_2_XS && xpos < MENU_2_XE && ypos > MENU_2_YS && ypos < MENU_2_YE ) { Lib_memory_clear( LINE_PLANE | CHAR_PLANE ); back( &disp_idx ); /*戻る*/ main_menu_disp(); } else if ( xpos > MENU_3_XS && xpos < MENU_3_XE && ypos > MENU_3_YS && ypos < MENU_3_YE ) { Lib_memory_clear( LINE_PLANE | CHAR_PLANE ); enlarge( &disp_idx ); /*拡大*/ main_menu_disp(); } else if ( xpos > MENU_4_XS && xpos < MENU_4_XE && ypos > MENU_4_YS && ypos < MENU_4_YE ) { Lib_memory_clear( LINE_PLANE | CHAR_PLANE ); tool( ); /*ツール*/ main_menu_disp(); } else if ( xpos > MENU_H_XS && xpos < MENU_H_XE && ypos > MENU_H_YS && ypos < MENU_H_YE ) { Lib_memory_clear( LINE_PLANE | CHAR_PLANE ); disp_help(); /* ヘルプ */ main_menu_disp(); } else if ( xpos > MENU_E_XS && xpos < MENU_E_XE && ypos > MENU_E_YS && ypos < MENU_E_YE ) { break; /* 終了 */ } } } Lib_change_gray_memory( 0 ); for( i=0; i ( m_menu.c ) */ SUB_menu_disp4he( (char *)str_main_menu[0][iLanguage], (char *)str_main_menu[1][iLanguage], (char *)str_main_menu[2][iLanguage], (char *)str_main_menu[3][iLanguage] ); } /* * ヘルプ表示 */ static void disp_help( void ) { Lib_chrdisp( 10, 6, "【機能\概要】 ENLARGE" ); Lib_chrdisp( 11, 8, "指定領域の画像拡大表\示" ); Lib_chrdisp( 11, 10, "線形補間法にて画像拡大します。" ); Lib_chrdisp( 11, 13, "[設 定] 画像拡大時、縦横比を保持する/しないを選択" ); Lib_chrdisp( 11, 15, "    します。" ); Lib_chrdisp( 11, 17, "[戻 る] 1つ前の状態の画像へ戻します。" ); Lib_chrdisp( 11, 19, "[拡 大] 拡大したい領域を指定して画像を拡大します。" ); Lib_chrdisp( 11, 21, "[ツール] Aスコープと画像フィルターが使用できます。" ); Lib_chrdisp( 11, 23, "[ヘルプ] 機能\概要を表\示します。" ); Lib_chrdisp( 11, 25, "    またフリーラン画像にします。" ); Lib_chrdisp( 11, 27, "[終了] 本ソフトウェアを終了し「90Xシステム」へ戻ります。" ); Lib_freerun(); } /***********************************************************************/ /* 設定          */ /***********************************************************************/ static char *select_rate_mode[2] = { "す る", "しない" }; void set( ) { int pad_level; PVAL value[5]; int no; int i; Lib_set_pad_maxstring( 12 ); /*パッド表示文字数変更*/ pad_level = Lib_view_open(); Lib_view_set_title( pad_level, "設定" ); value[0].select_type = rate_mode; i = 0; Lib_view_set_select( pad_level, 5, 5, "縦横比の保持", value[i].select_type, 2, select_rate_mode, i ); i++; Lib_view_set_size( pad_level, 80, 70, 5, 5 ); Lib_draw_menu( pad_level ); if( ERROR_RETURN != ( no = Lib_process_menu( pad_level, value ) ) ) { if ( PAD_EXECUTE == no ) { rate_mode = value[0].select_type; } } else { Lib_chrdisp( 1, 28, "pad_level ERR!" ); } Lib_erase_menu( pad_level ); Lib_view_close( pad_level ); Lib_set_pad_maxstring( 10 ); /*パッド表示文字数初期化*/ Lib_sprintf( ss, "第%d面", disp_idx + 1 ); Lib_chrdisp( 59, 30, ss ); } /*********************************************************************/ /*  ウインド設定                          */ /*********************************************************************/ void wind_set( xs, ys, xe, ye ) int *xs, *ys, *xe, *ye; /*入出力:ウインド位置*/ { int pad_level_wind; PVAL value[3]; int no; int i; pad_level_wind = Lib_view_open(); Lib_view_set_title( pad_level_wind, "処理範囲" ); value[0].box_type.x = *xs; value[0].box_type.y = *ys; value[1].box_type.x = *xe - *xs + 1; value[1].box_type.y = *ye - *ys + 1; i = 0; Lib_view_set_box( pad_level_wind, 5, 5, "始点" , value[i].box_type.x, value[i].box_type.y, 3, 1, i ); i++; Lib_view_set_box( pad_level_wind, 5, 35, "サイズ", value[i].box_type.x, value[i].box_type.y, 3, 0, i ); i++; Lib_view_set_size( pad_level_wind, 230, 370, 5, 5 ); Lib_draw_menu( pad_level_wind ); if( ERROR_RETURN != ( no = Lib_process_menu( pad_level_wind, value ) ) ) { if ( PAD_EXECUTE == no ) { *xs = value[0].box_type.x; *ys = value[0].box_type.y; *xe = value[0].box_type.x + value[1].box_type.x - 1; *ye = value[0].box_type.y + value[1].box_type.y - 1; } } else { Lib_chrdisp( 1, 28, "pad_level_wind ERR!" ); } Lib_erase_menu( pad_level_wind ); Lib_view_close( pad_level_wind ); } /*********************************************************************/ /*  戻る                              */ /*********************************************************************/ void back( disp_idx ) int *disp_idx; /*現在表示中のメモリ番号*/ { if ( 0 < *disp_idx ) { Lib_xvideo_transmit( mem_no[*disp_idx - 1], GRAY_PLANE ); /*1つ前の画像表示*/ (*disp_idx)--; } else Lib_chrdisp( 1, 30, "これ以上戻れません" ); Lib_sprintf( ss, "第%d面", *disp_idx + 1 ); Lib_chrdisp( 59, 30, ss ); } /*********************************************************************/ /*  拡大                              */ /*********************************************************************/ void enlarge( disp_idx ) int *disp_idx; /*現在表示中のメモリ番号*/ { int xs, ys, xe, ye; int xsize, ysize; int fx_size, fy_size; double xrate, yrate, rate; int dst_mem; if ( *disp_idx + 1 < mcount ) { xs = 0; ys = 0; xe = Lib_get_dx_size() - 1; ye = Lib_get_dy_size() - 1; dst_mem = mem_no[*disp_idx + 1]; wind_set( &xs, &ys, &xe, &ye ); /*拡大領域設定 */ if ( 0 == *disp_idx ) Lib_freeze( TRANSMIT ); /*画像取り込み */ Lib_shift( mem_no[*disp_idx], 0, xs, ys ); /*原点へ画像シフト */ xsize = xe - xs + 1; /*X方向拡大前サイズ*/ ysize = ye - ys + 1; /*Y方向拡大前サイズ*/ fx_size = Lib_get_fx_size(); /*X方向拡大後サイズ*/ fy_size = Lib_get_fy_size(); /*Y方向拡大後サイズ*/ xrate = (double)fx_size / (double)xsize; /*X拡大率 */ yrate = (double)fy_size / (double)ysize; /*Y拡大率 */ if ( RATE_FIX == rate_mode ) /*縦横比の保持はする?*/ { if ( xrate < yrate ) /*拡大率は小さい方に合わせる*/ rate = xrate; else rate = yrate; Lib_xscale( 0, dst_mem, rate, rate ); /*画像拡大(線形補間)*/ } else Lib_xscale( 0, dst_mem, xrate, yrate ); /*画像拡大(線形補間)*/ Lib_xvideo_transmit( dst_mem, GRAY_PLANE ); /*拡大画像表示*/ (*disp_idx)++; if ( 15 < *disp_idx + 1 ) (*disp_idx)--; } else Lib_chrdisp( 1, 30, "これ以上拡大できません" ); Lib_sprintf( ss, "第%d面", *disp_idx + 1 ); Lib_chrdisp( 59, 30, ss ); } /*********************************************************************/ /* ツール */ /*********************************************************************/ void tool( ) { int rtn; int i; pad_level_tool = Lib_view_open(); Lib_view_set_title( pad_level_tool, "ツール" ); i = 0; Lib_view_set_null( pad_level_tool, 5, 5, "Aスコープ" , i ); i++; Lib_view_set_null( pad_level_tool, 5, 35, "フィルター" , i ); i++; Lib_view_set_size( pad_level_tool, 50, 80, 30, 5 ); Lib_draw_command( pad_level_tool ); for (;;) { if ( ERROR_RETURN != ( rtn = Lib_process_command( pad_level_tool ) ) ) { switch( rtn ) { case 0: Lib_erase_command( pad_level_tool ); ascope( disp_idx ); /*Aスコープ*/ Lib_draw_command( pad_level_tool ); break; case 1: Lib_erase_command( pad_level_tool ); filter_menu( ); /*フィルター*/ Lib_draw_command( pad_level_tool ); break; case PAD_QUIT: /* 「終了」をクリック? */ Lib_erase_command( pad_level_tool ); Lib_view_close( pad_level_tool ); break; } } if ( PAD_QUIT == rtn ) break; } } /*********************************************************************/ /* Aスコープ */ /*********************************************************************/ void ascope( disp_idx ) int disp_idx; /*現在表示中のメモリ番号*/ { int curr_mem; curr_mem = Lib_get_gray_memory( ); if ( 0 == disp_idx ) Lib_freeze( TRANSMIT ); /*画像取り込み */ Lib_ascope( mem_no[disp_idx] ); /*Aスコープ表示*/ Lib_change_gray_memory( curr_mem ); Lib_sprintf( ss, "第%d面", disp_idx + 1 ); Lib_chrdisp( 59, 30, ss ); } /*********************************************************************/ /* フィルター */ /*********************************************************************/ void filter_menu( ) { int rtn; int i; int width, height; Lib_get_key_size( 12, &width, &height ); pad_level_filter = Lib_view_open(); Lib_view_set_title( pad_level_filter, "フィルター" ); i = 0; Lib_view_set_null( pad_level_filter, 5, 5, "平均化", i ); i++; Lib_view_set_null( pad_level_filter, 10+width, 5, "ラプラシアン", i ); i++; Lib_view_set_null( pad_level_filter, 5, 35, "最小値", i ); i++; Lib_view_set_null( pad_level_filter, 10+width, 35, "最大値", i ); i++; Lib_view_set_null( pad_level_filter, 5, 65, "1次微分",i ); i++; Lib_view_set_null( pad_level_filter, 10+width, 65, "2次微分",i ); i++; Lib_view_set_null( pad_level_filter, 5, 95, "ロバーツ", i ); i++; Lib_view_set_null( pad_level_filter, 10+width, 95, "ソーベル", i ); i++; Lib_view_set_null( pad_level_filter, 5, 125, "メディアン", i ); i++; Lib_view_set_null( pad_level_filter, 10+width, 125, "鮮鋭化", i ); i++; Lib_view_set_size( pad_level_filter, 50, 80, 5, 5 ); Lib_draw_command( pad_level_filter ); for (;;) { if ( ERROR_RETURN != ( rtn = Lib_process_command( pad_level_filter ) ) ) { switch( rtn ) { case 0: case 1: case 2: case 3: case 4: case 5: case 6: case 7: case 8: case 9: Lib_erase_command( pad_level_filter ); filter( rtn, &disp_idx ); /*フィルター*/ Lib_draw_command( pad_level_filter ); break; case PAD_QUIT: /* 「終了」をクリック? */ Lib_erase_command( pad_level_filter ); Lib_view_close( pad_level_filter ); break; } } if ( PAD_QUIT == rtn ) break; } } /*********************************************************************/ /* フィルター */ /*********************************************************************/ void filter( no, disp_idx ) int no; /*フィルター番号 */ int *disp_idx; /*現在表示中のメモリ番号*/ { int dst_mem; if ( 0 == *disp_idx ) Lib_freeze( TRANSMIT ); /*画像取り込み */ if ( *disp_idx + 1 < mcount ) { dst_mem = mem_no[*disp_idx + 1]; if ( FILTER_AVERAGE == no ) Lib_averaging( mem_no[*disp_idx], dst_mem ); /*平均化 */ else if ( FILTER_LAPLACIAN == no ) Lib_laplacian( mem_no[*disp_idx], dst_mem ); /*ラプラシアン */ else if ( FILTER_MIN == no ) Lib_min_filter( mem_no[*disp_idx], dst_mem ); /*最小値 */ else if ( FILTER_MAX == no ) Lib_max_filter( mem_no[*disp_idx], dst_mem ); /*最大値 */ else if ( FILTER_1DIFF == no ) Lib_fdefferential( mem_no[*disp_idx], dst_mem, XY_DIRECTION ); /*1次微分 */ else if ( FILTER_2DIFF == no ) Lib_sdefferential( mem_no[*disp_idx], dst_mem ); /*1次微分 */ else if ( FILTER_ROBERTS == no ) Lib_roberts( mem_no[*disp_idx], dst_mem ); /*ロバーツ */ else if ( FILTER_SOBEL == no ) Lib_sobel( mem_no[*disp_idx], dst_mem, XY_DIRECTION ); /*ソーベル */ else if ( FILTER_MEDIAN == no ) Lib_median( mem_no[*disp_idx], dst_mem ); /*メディアン */ else if ( FILTER_SHARP == no ) Lib_sharp( mem_no[*disp_idx], dst_mem ); /*鮮鋭化 */ Lib_xvideo_transmit( dst_mem, GRAY_PLANE ); /*結果画像表示*/ (*disp_idx)++; } else Lib_chrdisp( 1, 30, "使用可能\なメモリがありません" ); Lib_sprintf( ss, "第%d面", *disp_idx + 1 ); Lib_chrdisp( 59, 30, ss ); }