その他の関数 - BootROMフォント関数

syBtFntGet

フォントアドレスの取得

書式

void *syBtFntGet( void )

引数

なし

戻値

BootROM内のフォントデータの先頭アドレス

解説

ブートロム内フォントデータの格納アドレスを取得します。

この関数で取得したフォントデータの先頭アドレスと以下の定数を用いて 必要なフォントのアドレスを求める必要があります。

セクションの先頭データへのオフセット

SYD_BT_FNT_ASCII_24_OFSASCII アスキー
SYD_BT_FNT_WEST_24_OFSISO 8859-1 海外用8ビットコード後半
SYD_BT_FNT_JISX_24_OFSJIS X 0201 国内用8ビットコード後半
SYD_BT_FNT_KANA_24_OFSShift JIS part1 全角日本語非漢字部分
SYD_BT_FNT_LVL1_24_OFSShift JIS part2 日本語漢字第一水準部分
SYD_BT_FNT_LVL2_24_OFSShift JIS part3 日本語漢字第二水準部分
SYD_BT_FNT_GAIJ_24_OFSGAIJI 特製外字
SYD_BT_FNT_VMSICON_OFSVMデフォルトラベルアイコン

セクションのデータサイズ

SYD_BT_FNT_ASCII_24_SIZEASCII アスキー
SYD_BT_FNT_WEST_24_SIZEISO 8859-1 海外用8ビットコード後半
SYD_BT_FNT_JISX_24_SIZEJIS X 0201 国内用8ビットコード後半
SYD_BT_FNT_KANA_24_SIZEShift JIS part1 全角日本語非漢字部分
SYD_BT_FNT_LVL1_24_SIZEShift JIS part2 日本語漢字第一水準部分
SYD_BT_FNT_LVL2_24_SIZEShift JIS part3 日本語漢字第二水準部分
SYD_BT_FNT_GAIJ_24_SIZEGAIJI特製外字
SYD_BT_FNT_VMSICON_SIZEVMデフォルトラベルアイコン

各セクションでの代表的な文字コード(2byte日本語はシフトJISコード)

SYD_BT_FNT_CODE_ASCII_MINアスキーの初めのコード
SYD_BT_FNT_CODE_ASCII_MAXアスキーの最後のコード
SYD_BT_FNT_CODE_8BIT_MIN8ビットコードの初めのコード
SYD_BT_FNT_CODE_8BIT_MAX8ビットコードの最後のコード
SYD_BT_FNT_CODE_KANA_MIN2byteコードの最初のコード
SYD_BT_FNT_CODE_KANA_MAX日本語非漢字部分の最後のコード
SYD_BT_FNT_CODE_LVL1_MIN漢字第一水準の最初のコード
SYD_BT_FNT_CODE_LVL1_MAX漢字第一水準の最後のコード
SYD_BT_FNT_CODE_LVL2_MIN漢字第二水準の最初のコード
SYD_BT_FNT_CODE_LVL2_MAX漢字第二水準の最後のコード
SYD_BT_FNT_GAIJ_MIN外字の最初のコード
SYD_BT_FNT_GAIJ_MAX外字の最後のコード
SYD_BT_FNT_ICON_MINビジュアルメモリアイコンの最初のコード
SYD_BT_FNT_ICON_MAXビジュアルメモリアイコンの最後のコード


用例

#define SMD_WRK_ADDR  (0x0c020000)
main()
{
	void *smFntAddr, *smTheFntAddr;
	void *smWrkAddr;
	Uint8 smTheCode;
         
	smFntAddr = syBtFntGet();
	smWrkAddr = (void *)SMD_WRK_ADDR;
	smTheCode = '?';
         
	/* evaluate the font address in Boot ROM */
	smTheFntAddr = (void *)((Uint8)smFntAddr + SYD_BT_FNT_WORK_ASCII_24_OFS
		+ (smTheCode - SYD_BT_FNT_CODE_ASCII_MIN) * SYD_BT_FNT_24_SIZE_HAN );
         
	/* font semaphore check */
	if( syBtFntChkSmph() == SYD_BT_FNT_SMPH_SUCCESS ) {
		/* copy 1 letter to work RAM from Boot ROM */
		memcpy( smTheFntAddr, smWrkAddr, SYD_BT_FNT_24_SIZE_HAN );
		/* font semaphore clear */
		syBtFntClrSmph();
	}
}

備考

制御用番号には現在SYD_BT_FNTINIを入れて置く必要があります。 セマフォを獲得せずに、フォントデータの取得を行った場合には、不定の値が返る可能性があります。 この関数はアドレスを取得するものであって、フォントデータをアプリケーション内に取り込むものではありません。 フォントデータのアプリケ−ションへのコピーは、アプリケーション自身が行うようにしてください。

syBtFntGet
COPYRIGHT © SEGA ENTERPRISES, LTD., 1998