//// ここから呼んでる ///////////////////////////////////////////////////////////////
DialogBox( hInst, ( LPCTSTR) IDD_CONTROLS, hWnd, ( DLGPROC) Controls) ;
//// ダイアログの処理全部 ///////////////////////////////////////////////////////////////
LRESULT CALLBACK Controls( HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
{
static HBITMAP hbm = 0 ;
static int curDevice = 0 ;
static HWND tabs = NULL ;
switch ( message)
{
case WM_INITDIALOG:
W32Util:: CenterWindow ( hDlg) ;
{
// TODO: connect to keyboard device instead
{
HBITMAP hResBM = LoadImageFromResource( hInst, MAKEINTRESOURCE( IDB_IMAGE_PSP) , "IMAGE" ) ;
HDC hDC = GetDC( hDlg) ;
RECT clientRect;
GetClientRect( hDlg, & clientRect) ;
//TabCtrl_AdjustRect(, TRUE, &clientRect);
HBITMAP hMemBM = CreateCompatibleBitmap( hDC, clientRect.right , clientRect.bottom ) ;
HDC hResDC = CreateCompatibleDC( hDC) ;
HDC hMemDC = CreateCompatibleDC( hDC) ;
SelectObject( hResDC, hResBM) ;
SelectObject( hMemDC, hMemBM) ;
BITMAP bm;
GetObject( hResBM, sizeof ( BITMAP) , & bm) ;
SetStretchBltMode( hMemDC, HALFTONE) ;
StretchBlt( hMemDC, clientRect.left , clientRect.top , ( clientRect.right - clientRect.left ) ,
( clientRect.bottom - clientRect.top ) , hResDC, 0 , 0 , bm.bmWidth , bm.bmHeight , SRCCOPY) ;
if ( hbm)
DeleteObject( hbm) ;
hbm = hMemBM;
DeleteDC( hMemDC) ;
DeleteDC( hResDC) ;
ReleaseDC( hDlg, hDC) ;
DeleteObject( hResBM) ;
}
int key_pad_size = ( IDC_EDIT_KEYRIGHT - IDC_EDIT_KEY_TURBO + 1 ) ;
for ( u32 i = 0 ; i <= IDC_EDIT_KEY_ANALOG_RIGHT - IDC_EDIT_KEY_TURBO; i++ ) {
HWND hEdit = GetDlgItem( hDlg, IDC_EDIT_KEY_TURBO + i) ;
if ( IDC_EDIT_KEY_TURBO + i <= IDC_EDIT_KEYRIGHT)
control_map[ i] = key_pad_map[ i * 2 ] ;
else
control_map[ i] = analog_ctrl_map[ ( i - key_pad_size) * 2 ] ;
SetWindowTextA( hEdit, getVirtualKeyName( control_map[ i] ) ) ;
}
ComboBox_AddString( GetDlgItem( hDlg, IDC_FORCE_INPUT_DEVICE) , "None" ) ;
ComboBox_AddString( GetDlgItem( hDlg, IDC_FORCE_INPUT_DEVICE) , "XInput" ) ;
ComboBox_AddString( GetDlgItem( hDlg, IDC_FORCE_INPUT_DEVICE) , "DirectInput" ) ;
if ( ( g_Config.iForceInputDevice < 0 ) || ( g_Config.iForceInputDevice > 1 ) )
{
ComboBox_SetCurSel( GetDlgItem( hDlg, IDC_FORCE_INPUT_DEVICE) , 0 ) ;
}
else
{
ComboBox_SetCurSel( GetDlgItem( hDlg, IDC_FORCE_INPUT_DEVICE) , ( g_Config.iForceInputDevice + 1 ) ) ;
}
tabs = GetDlgItem( hDlg, IDC_CONTROLTAB) ;
TCITEM tcItem;
ZeroMemory( & tcItem, sizeof ( tcItem) ) ;
tcItem.mask = TCIF_TEXT;
tcItem.dwState = 0 ;
tcItem.pszText = "Keyboard" ;
tcItem.cchTextMax = ( int ) strlen ( tcItem.pszText ) + 1 ;
tcItem.iImage = 0 ;
TabCtrl_InsertItem( tabs, TabCtrl_GetItemCount( tabs) ,& tcItem) ;
tcItem.pszText = "DirectInput" ;
tcItem.cchTextMax = ( int ) strlen ( tcItem.pszText ) + 1 ;
TabCtrl_InsertItem( tabs, TabCtrl_GetItemCount( tabs) ,& tcItem) ;
tcItem.pszText = "XInput" ;
tcItem.cchTextMax = ( int ) strlen ( tcItem.pszText ) + 1 ;
TabCtrl_InsertItem( tabs, TabCtrl_GetItemCount( tabs) ,& tcItem) ;
DWORD dwThreadID = GetWindowThreadProcessId( hDlg, NULL ) ;
pKeydownHook = SetWindowsHookEx( WH_KEYBOARD,KeyboardProc, NULL , dwThreadID) ;
}
return TRUE;
case WM_NOTIFY:
{
switch ( ( ( NMHDR * ) lParam) - > code) {
case TCN_SELCHANGE:
//InvalidateRect(hDlg, NULL, TRUE);
curDevice = TabCtrl_GetCurSel( tabs) ;
break ;
case TCN_SELCHANGING:
curDevice = TabCtrl_GetCurSel( tabs) ;
break ;
default :
break ;
}
break ;
}
case WM_PAINT:
{
PAINTSTRUCT pst;
HDC hdc = BeginPaint( hDlg, & pst) ;
BITMAP bm;
GetObject( hbm, sizeof ( BITMAP) , & bm) ;
//RECT rect;
//GetClientRect(hDlg, &rect);
RECT rect = { 0 , 0 , bm.bmWidth , bm.bmHeight } ;
//TabCtrl_AdjustRect(hDlg, TRUE, &rect);
BitBlt( hbm, hdc, rect.left , rect.top , rect.right - rect.left , rect.bottom - rect.top , 0 , 0 ) ;
//BitBlt(hbm, hdc, 0, 0, bm.bmWidth, bm.bmHeight, 0 , 0);
EndPaint( hDlg, & pst) ;
return TRUE;
}
case WM_CTLCOLORSTATIC:
{
HDC hdc= ( HDC) wParam;
SetBkMode( hdc, TRANSPARENT) ;
return ( LRESULT) GetStockObject( NULL_BRUSH) ;
}
case WM_CTLCOLOREDIT:
{
if ( ( HWND) lParam == GetDlgItem( hDlg, IDC_FORCE_INPUT_DEVICE) )
return FALSE;
HDC hdc = ( HDC) wParam;
SetBkMode( hdc, TRANSPARENT) ;
SetTextColor( hdc, RGB( 255 , 0 , 0 ) ) ;
HWND hEdit = ( HWND) lParam;
RECT rc = getRedrawRect( hEdit) ;
RECT clientrc;
GetClientRect( hEdit, & clientrc) ;
BitBlt( hbm, hdc, 0 , 0 , rc.right - rc.left , rc.bottom - rc.top , rc.left , rc.top ) ;
char str[ 11 ] ;
GetWindowTextA( hEdit, str, 10 ) ;
DrawTextA( hdc, str, ( int ) strlen ( str) , & clientrc, DT_CENTER| DT_SINGLELINE) ;
return ( LRESULT) GetStockObject( NULL_BRUSH) ;
}
case WM_COMMAND:
if ( LOWORD( wParam) == IDOK || LOWORD( wParam) == IDCANCEL)
{
if ( LOWORD( wParam) == IDOK) {
g_Config.iForceInputDevice = ( ComboBox_GetCurSel( GetDlgItem( hDlg, IDC_FORCE_INPUT_DEVICE) ) - 1 ) ;
int key_pad_size = ( IDC_EDIT_KEYRIGHT - IDC_EDIT_KEY_TURBO + 1 ) ;
for ( u32 i = 0 ; i <= IDC_EDIT_KEY_ANALOG_RIGHT - IDC_EDIT_KEY_TURBO; i++ ) {
if ( IDC_EDIT_KEY_TURBO + i <= IDC_EDIT_KEYRIGHT)
key_pad_map[ i * 2 ] = control_map[ i] ;
else
analog_ctrl_map[ ( i - key_pad_size) * 2 ] = control_map[ i] ;
}
saveControlsToFile( ) ;
}
UnhookWindowsHookEx( pKeydownHook) ;
EndDialog( hDlg, LOWORD( wParam) ) ;
curDevice = 0 ;
tabs = NULL ;
if ( hbm) {
DeleteObject( hbm) ;
hbm = 0 ;
}
return TRUE;
}
break ;
}
return FALSE;
}
///////////////////////////////////////////////////////////////////
// *.rc
IDD_CONTROLS DIALOGEX 0 , 0 , 495 , 239
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | WS_POPUP | WS_CAPTION | WS_SYSMENU
CAPTION "Controls"
FONT 9 , "MS Shell Dlg" , 0 , 0 , 0x1
BEGIN
DEFPUSHBUTTON "OK" ,IDOK,188 ,217 ,50 ,14
PUSHBUTTON "Cancel" ,IDCANCEL,242 ,217 ,50 ,14
LTEXT "Turbo Mode:" ,IDC_STATIC,386 ,220 ,42 ,8
EDITTEXT IDC_EDIT_KEYUP,56 ,79 ,34 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEYLEFT,34 ,100 ,34 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEYRIGHT,78 ,100 ,34 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEYDOWN,56 ,123 ,34 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_TRIANGLE,406 ,73 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_RECTANGLE,380 ,100 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_CIRCLE,433 ,100 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_CROSS,406 ,126 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_LEFT_THUMB,55 ,24 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_RIGHT_THUMB,406 ,24 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_SELECT,326 ,192 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_START,356 ,192 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_ANALOG_UP,57 ,145 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_ANALOG_LEFT,40 ,159 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_ANALOG_RIGHT,75 ,159 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_ANALOG_DOWN,57 ,173 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
EDITTEXT IDC_EDIT_KEY_TURBO,430 ,220 ,33 ,14 ,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
LTEXT "Force device:" ,IDC_STATIC,14 ,220 ,45 ,11
COMBOBOX IDC_FORCE_INPUT_DEVICE,62 ,218 ,84 ,140 ,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
CONTROL "" ,IDC_CONTROLTAB,"SysTabControl32" , TCS_FORCEICONLEFT | TCS_FIXEDWIDTH,0 ,0 ,495 ,239 ,WS_EX_TRANSPARENT
END
//////////////////////////////////////////////////////////////////////
//// ここから呼んでる ///////////////////////////////////////////////////////////////
DialogBox(hInst, (LPCTSTR)IDD_CONTROLS, hWnd, (DLGPROC)Controls);
//// ダイアログの処理全部 ///////////////////////////////////////////////////////////////
	LRESULT CALLBACK Controls(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
	{
		static HBITMAP hbm = 0;
		static int curDevice = 0;
		static HWND tabs = NULL;
		switch (message)
		{
		case WM_INITDIALOG:
			W32Util::CenterWindow(hDlg);
			{
				// TODO: connect to keyboard device instead
				{
					
					HBITMAP hResBM = LoadImageFromResource(hInst, MAKEINTRESOURCE(IDB_IMAGE_PSP), "IMAGE");
					HDC hDC = GetDC(hDlg);
					RECT clientRect;
					GetClientRect(hDlg, &clientRect);
					//TabCtrl_AdjustRect(, TRUE, &clientRect);
					HBITMAP hMemBM = CreateCompatibleBitmap(hDC, clientRect.right, clientRect.bottom);
					HDC hResDC = CreateCompatibleDC(hDC);
					HDC hMemDC = CreateCompatibleDC(hDC);
					SelectObject(hResDC, hResBM);
					SelectObject(hMemDC, hMemBM);

					BITMAP bm;
					GetObject(hResBM, sizeof(BITMAP), &bm);
					SetStretchBltMode(hMemDC, HALFTONE);
					StretchBlt(hMemDC, clientRect.left, clientRect.top, (clientRect.right - clientRect.left),
						(clientRect.bottom - clientRect.top), hResDC, 0, 0, bm.bmWidth, bm.bmHeight, SRCCOPY); 
					if (hbm)
						DeleteObject(hbm);
					hbm = hMemBM;

					DeleteDC(hMemDC);
					DeleteDC(hResDC);
					ReleaseDC(hDlg, hDC);
					DeleteObject(hResBM);
				}

				int key_pad_size = (IDC_EDIT_KEYRIGHT - IDC_EDIT_KEY_TURBO + 1);
				for (u32 i = 0; i <= IDC_EDIT_KEY_ANALOG_RIGHT - IDC_EDIT_KEY_TURBO; i++) {
					HWND hEdit = GetDlgItem(hDlg, IDC_EDIT_KEY_TURBO + i);
					if (IDC_EDIT_KEY_TURBO + i <= IDC_EDIT_KEYRIGHT)
						control_map[i] = key_pad_map[i * 2];
					else
						control_map[i] = analog_ctrl_map[(i - key_pad_size) * 2];
					SetWindowTextA(hEdit, getVirtualKeyName(control_map[i]));
				}
				ComboBox_AddString(GetDlgItem(hDlg, IDC_FORCE_INPUT_DEVICE), "None");
				ComboBox_AddString(GetDlgItem(hDlg, IDC_FORCE_INPUT_DEVICE), "XInput");
				ComboBox_AddString(GetDlgItem(hDlg, IDC_FORCE_INPUT_DEVICE), "DirectInput");
				if ((g_Config.iForceInputDevice < 0) || (g_Config.iForceInputDevice > 1))
				{
					ComboBox_SetCurSel(GetDlgItem(hDlg, IDC_FORCE_INPUT_DEVICE), 0);
				}
				else
				{
					ComboBox_SetCurSel(GetDlgItem(hDlg, IDC_FORCE_INPUT_DEVICE), (g_Config.iForceInputDevice + 1));
				}
				tabs = GetDlgItem(hDlg, IDC_CONTROLTAB);
				TCITEM tcItem;
				ZeroMemory(&tcItem, sizeof(tcItem));
				tcItem.mask			= TCIF_TEXT;
				tcItem.dwState		= 0;
				tcItem.pszText		= "Keyboard";
				tcItem.cchTextMax	= (int)strlen(tcItem.pszText)+1;
				tcItem.iImage		= 0;
				TabCtrl_InsertItem(tabs, TabCtrl_GetItemCount(tabs),&tcItem);
				tcItem.pszText		= "DirectInput";
				tcItem.cchTextMax	= (int)strlen(tcItem.pszText)+1;
				TabCtrl_InsertItem(tabs, TabCtrl_GetItemCount(tabs),&tcItem);
				tcItem.pszText		= "XInput";
				tcItem.cchTextMax	= (int)strlen(tcItem.pszText)+1;
				TabCtrl_InsertItem(tabs, TabCtrl_GetItemCount(tabs),&tcItem);
				

				DWORD dwThreadID = GetWindowThreadProcessId(hDlg, NULL);
				pKeydownHook = SetWindowsHookEx(WH_KEYBOARD,KeyboardProc, NULL, dwThreadID);
			}
			return TRUE;
		case WM_NOTIFY:
			{
				switch (((NMHDR *)lParam)->code) {
					case TCN_SELCHANGE:
						//InvalidateRect(hDlg, NULL, TRUE);
						curDevice = TabCtrl_GetCurSel(tabs);
						break;
					case TCN_SELCHANGING:
						curDevice = TabCtrl_GetCurSel(tabs);
						break;
					default:
						break;
				}
				break;
			}
		case WM_PAINT:
			{
				
				PAINTSTRUCT pst;	
				HDC hdc = BeginPaint(hDlg, &pst);
				
				BITMAP bm;
				GetObject(hbm, sizeof(BITMAP), &bm);
				//RECT rect;
				//GetClientRect(hDlg, &rect);
				RECT rect = {0, 0, bm.bmWidth, bm.bmHeight};
				//TabCtrl_AdjustRect(hDlg, TRUE, &rect);
				BitBlt(hbm, hdc, rect.left, rect.top, rect.right - rect.left, rect.bottom - rect.top, 0, 0);
				//BitBlt(hbm, hdc, 0, 0, bm.bmWidth, bm.bmHeight, 0 , 0);
				EndPaint(hDlg, &pst);
				
				return TRUE;
			}
		case WM_CTLCOLORSTATIC:
			{
				HDC hdc=(HDC)wParam;
				SetBkMode(hdc, TRANSPARENT);
				return (LRESULT)GetStockObject(NULL_BRUSH); 
			}
		case WM_CTLCOLOREDIT:
			{
				if ((HWND)lParam == GetDlgItem(hDlg, IDC_FORCE_INPUT_DEVICE))
					return FALSE;
				HDC hdc = (HDC)wParam;
				SetBkMode(hdc, TRANSPARENT);
				SetTextColor(hdc, RGB(255, 0, 0));
				HWND hEdit = (HWND)lParam;
				RECT rc = getRedrawRect(hEdit);
				RECT clientrc;
				GetClientRect(hEdit, &clientrc);
				BitBlt(hbm, hdc, 0, 0, rc.right - rc.left, rc.bottom - rc.top, rc.left, rc.top);
				char str[11];
				GetWindowTextA(hEdit, str, 10);
				DrawTextA(hdc, str, (int)strlen(str), &clientrc, DT_CENTER|DT_SINGLELINE);
				return (LRESULT)GetStockObject(NULL_BRUSH);
			}
		case WM_COMMAND:
			if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL) 
			{
				if (LOWORD(wParam) == IDOK) {
					g_Config.iForceInputDevice = (ComboBox_GetCurSel(GetDlgItem(hDlg, IDC_FORCE_INPUT_DEVICE)) - 1);
					int key_pad_size = (IDC_EDIT_KEYRIGHT - IDC_EDIT_KEY_TURBO + 1);
					for (u32 i = 0; i <= IDC_EDIT_KEY_ANALOG_RIGHT - IDC_EDIT_KEY_TURBO; i++) {
						if (IDC_EDIT_KEY_TURBO + i <= IDC_EDIT_KEYRIGHT)
							key_pad_map[i * 2] = control_map[i];
					else
						analog_ctrl_map[(i - key_pad_size) * 2] = control_map[i];
					}
					saveControlsToFile();
				}
				UnhookWindowsHookEx(pKeydownHook);
				EndDialog(hDlg, LOWORD(wParam));
				curDevice = 0;
				tabs = NULL;
				if (hbm) {
					DeleteObject(hbm);
					hbm = 0;
				}
				return TRUE;
			}
			break;
		}
		return FALSE;
	}
///////////////////////////////////////////////////////////////////
// *.rc
IDD_CONTROLS DIALOGEX 0, 0, 495, 239
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | WS_POPUP | WS_CAPTION | WS_SYSMENU
CAPTION "Controls"
FONT 9, "MS Shell Dlg", 0, 0, 0x1
BEGIN
    DEFPUSHBUTTON   "OK",IDOK,188,217,50,14
    PUSHBUTTON      "Cancel",IDCANCEL,242,217,50,14
    LTEXT           "Turbo Mode:",IDC_STATIC,386,220,42,8
    EDITTEXT        IDC_EDIT_KEYUP,56,79,34,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEYLEFT,34,100,34,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEYRIGHT,78,100,34,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEYDOWN,56,123,34,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_TRIANGLE,406,73,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_RECTANGLE,380,100,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_CIRCLE,433,100,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_CROSS,406,126,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_LEFT_THUMB,55,24,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_RIGHT_THUMB,406,24,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_SELECT,326,192,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_START,356,192,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_ANALOG_UP,57,145,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_ANALOG_LEFT,40,159,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_ANALOG_RIGHT,75,159,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_ANALOG_DOWN,57,173,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    EDITTEXT        IDC_EDIT_KEY_TURBO,430,220,33,14,ES_CENTER | ES_AUTOHSCROLL | NOT WS_BORDER
    LTEXT           "Force device:",IDC_STATIC,14,220,45,11
    COMBOBOX        IDC_FORCE_INPUT_DEVICE,62,218,84,140,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
    CONTROL         "",IDC_CONTROLTAB,"SysTabControl32", TCS_FORCEICONLEFT | TCS_FIXEDWIDTH,0,0,495,239,WS_EX_TRANSPARENT
END
//////////////////////////////////////////////////////////////////////