JunkBox_Win_Lib 1.5.3
Loading...
Searching...
No Matches
jbxwl Namespace Reference

Classes

struct  BVHSaveParam
 
class  CAppCallBack
 
class  CBaseFrameTool
 
class  CContrastDLG
 
class  CDx2DView
 
class  CDx3DDirectView
 
class  CDxBaseView
 
class  CDxDirectView
 
class  CDxGraphDoc
 
class  CDxMGRView
 
class  CDxSRenderView
 
class  CDxVScrollView
 
class  CDxVTXBaseView
 
class  CExDocument
 
class  CExFrame
 
class  CExSMPLDisp
 
class  CExTextFrame
 
class  CExTextView
 
class  CExToolBar
 
class  CExView
 
class  CInputFloatNumDLG
 
class  CInputMultiFloatNumDLG
 
class  CInputNumDLG
 
class  CLogWndDoc
 
class  CLogWndFrame
 
class  CLogWndView
 
class  CMessageBoxDLG
 
class  CNiBVHTool
 
class  CNiFileTool
 
class  CNiJoints
 
class  CNiJTextTool
 
class  CNiVMDTool
 
class  CProgressBarDLG
 
class  CProgressTextDLG
 
class  CReadFilesDLG
 
class  CRwGRDoc
 
class  CSetHeaderDLG
 
class  CvThumbNailDoc
 
class  CvThumbNailFrame
 
class  CWinAudioStream
 
class  CWinAudioTool
 
class  CWinMediaBuffer
 
class  CWinSharedMem
 
class  CWriteFilesDLG
 
class  DLLModule
 
class  DLLModuleTBL
 
class  EventHandler
 

Typedefs

typedef char *(* FUNC_STRING) (int)
 
typedef std::stack< CWinMediaBuffer * > MediaBufferStack
 
typedef std::queue< CWinMediaBuffer * > MediaBufferQueue
 

Enumerations

enum  SENDKEY_Action { SENDKEY_TapAction , SENDKEY_DownAction , SENDKEY_UpAction }
 
enum  NiSDK_Lib {
  NiSDK_Default , NiSDK_None , NiSDK_Kinect , NiSDK_OpenNI ,
  NiSDK_OpenNI2
}
 

Functions

BOOL InputNumDLG (LPCTSTR title, int *val)
 
BOOL InputFloatNumDLG (LPCTSTR title, double *val)
 
BOOL InputMultiFloatNumDLG (LPCTSTR t0, double *v0, LPCTSTR t1=NULL, double *v1=NULL, LPCTSTR t2=NULL, double *v2=NULL, LPCTSTR t3=NULL, double *v3=NULL, LPCTSTR t4=NULL, double *v4=NULL, LPCTSTR t5=NULL, double *v5=NULL)
 
CMessageBoxDLGMessageBoxDLG (int ttl, int msg, CWnd *wnd=NULL)
 
CMessageBoxDLGMessageBoxDLG (LPCTSTR ttl, int msg, CWnd *wnd=NULL)
 
CMessageBoxDLGMessageBoxDLG (int ttl, LPCTSTR msg, CWnd *wnd=NULL)
 
CMessageBoxDLGMessageBoxDLG (LPCTSTR ttl, LPCTSTR msg, CWnd *wnd=NULL)
 
int MessageBoxDLG (int ttl, int msg, UINT type, CWnd *wnd=NULL)
 
int MessageBoxDLG (LPCTSTR ttl, int msg, UINT type, CWnd *wnd=NULL)
 
int MessageBoxDLG (int ttl, LPCTSTR msg, UINT type, CWnd *wnd=NULL)
 
int MessageBoxDLG (LPCTSTR ttl, LPCTSTR msg, UINT type, CWnd *wnd=NULL)
 
HRESULT ResetDx9Device (LPDIRECT3DDEVICE9, D3DPRESENT_PARAMETERS *, CDxBaseView *pviw=NULL)
 
int ExecTemplate (CMultiDocTemplate *ptemp, ExMSGraph< sWord > *pmsGraph=NULL, ExCmnHead *pcmnHead=NULL, CExFrame *prntFrm=NULL, int vPoint=0)
 
CExFrameCreateDocFrmView (CMultiDocTemplate *pDocTemp, CAppCallBack *papp=NULL)
 
int ExecDocFrmView (CExFrame *pfrm, LPCTSTR fname=NULL)
 
void ExecDocFrmViewError (HWND hwnd, int ret)
 
BOOL InitialDocView (CExFrame *pfrm, LPCTSTR fname)
 
bool SetExLink (CExDocument *pdoc, CExFrame *pfrm, CExView *pview, CAppCallBack *papp)
 
CString EasyGetOpenFileName (LPCTSTR title=NULL, HWND hWnd=NULL)
 
CString EasyGetSaveFileName (LPCTSTR title=NULL, LPCTSTR extnt=NULL, HWND hWnd=NULL)
 
CString EasyGetSaveFolderName (LPCTSTR folder=_T(""), LPCTSTR title=NULL, HWND hWnd=NULL)
 
int CALLBACK EasyGetSaveFolderNameCallBack (HWND hwnd, UINT uMsg, LPARAM lParam, LPARAM lpData)
 
int copyFileWithCounter (LPCTSTR src, LPCTSTR dst)
 
int copyFPWithCounter (FILE *src, FILE *dst, unsigned long int sz)
 
int writeGraphicFileWithCounter (LPCTSTR fname, MSGraph< sWord > vp, int kind, BOOL mlt=FALSE, int fn=0, int tn=0)
 
CMenu * GetMenu_byID (CMenu *pMenu, UINT id)
 
CMenu * GetMenu_byStringID (CMenu *pMenu, UINT id)
 
CMenu * GetMenu_byName (CMenu *pMenu, LPCTSTR name)
 
void RebootProgram (void)
 
BOOL WaitPidTerm (int tm)
 
CLogWndFrameExecLogWnd (CMultiDocTemplate *pDocTempl, LPCTSTR title, CAppCallBack *app)
 
BOOL Dx9CreateInterface (CWinApp *wapp)
 
void Dx9ReleaseInterface ()
 
LPDIRECT3DDEVICE9 Dx9CreateGraphic (LPDIRECT3D9, D3DPRESENT_PARAMETERS *, HWND)
 
LPDIRECTINPUTDEVICE8 Dx9CreateMouse (LPDIRECTINPUT8, HWND)
 
LPDIRECTINPUTDEVICE8 Dx9CreateKeyBoard (LPDIRECTINPUT8, HWND)
 
POINT Dx9GetBackBuffer (LPDIRECT3DDEVICE9, LPDIRECT3DSURFACE9 *)
 
BOOL Dx9SurfaceFromMemory (LPDIRECT3DDEVICE9, LPDIRECT3DSURFACE9 *, CmnHead)
 
BOOL Dx9TextureFromMemory (LPDIRECT3DDEVICE9, LPDIRECT3DTEXTURE9 *, CmnHead)
 
BOOL Dx9SurfaceFromByteMemory (LPDIRECT3DDEVICE9, LPDIRECT3DSURFACE9 *, CmnHead)
 
BOOL Dx9SurfaceFromMemoryFile (LPDIRECT3DDEVICE9, LPDIRECT3DSURFACE9 *, CmnHead)
 
BOOL Dx9TextureFromByteMemory (LPDIRECT3DDEVICE9, LPDIRECT3DTEXTURE9 *, CmnHead)
 
BOOL Dx9TextureFromMemoryFile (LPDIRECT3DDEVICE9, LPDIRECT3DTEXTURE9 *, CmnHead)
 
HRESULT Dx9DrawPrimitive (LPDIRECT3DDEVICE9, D3DPRIMITIVETYPE, UINT, UINT)
 
POINT Dx9GetSurfaceSize (LPDIRECT3DSURFACE9 *lpsf)
 
D3DCOLOR Dx9Word2RGBA (uWord pp)
 
D3DCOLOR Dx9Word2ARGB (uWord pp)
 
D3DCOLOR Dx9Word2RGB (uWord pp)
 
void open_shm_debuger (void)
 
void close_shm_debuger (void)
 
Buffer tc2Buffer (TCHAR *tchar, int size=-1)
 locale が正しくないと,日本語の変換は失敗する. ex.) setlocale(LC_CTYPE,"jpn") or setSystemLocale()
 
Buffer ts2Buffer (LPCTSTR str, int size=-1)
 
Buffer String2Buffer (CString str)
 
CString mbs2ts (char *str)
 
char * ts2mbs (LPCTSTR str)
 
int copy_ts2Buffer (LPCTSTR str, Buffer *buf)
 
int cat_ts2Buffer (LPCTSTR str, Buffer *buf)
 
unsigned long int file_size_t (LPCTSTR fn)
 
BOOL file_exist_t (LPCTSTR fn)
 
CString get_file_name_t (LPCTSTR str)
 
CString make_file_path_t (LPCTSTR str)
 
CString cut_file_extension_t (LPCTSTR str)
 
tList * read_index_tList_file_t (LPCTSTR fn, char cc)
 
tList * get_dir_files_t (LPCTSTR dirn)
 
tList * get_dir_files_rcsv_t (LPCTSTR dirn)
 
CString numbering_name_t (LPCTSTR fmt, int n)
 
CString get_tstr_param_tList (tList *lt, char *key, LPCTSTR dflt)
 
void setResourceLocale (void)
 
CString getResourceLocale (void)
 
void setSystemLocale (LPCTSTR locale=_T(""))
 
Buffer utf8_to_sjis_byStr (CString str)
 
Buffer utf8_to_sjis (void *ptr, size_t len)
 
Buffer sjis_to_utf8_byStr (CString str)
 
Buffer sjis_to_utf8 (void *ptr, size_t len)
 
CString GetCurrentUserHomeFolder (void)
 
CString GetDefaultUserHomeFolder (void)
 
CString MakeWorkingFolderPath (LPCTSTR fnm, BOOL local, LPCTSTR dir=NULL, BOOL make=FALSE)
 
CString GetProgramFolder (void)
 
char * GetProgramFolderA (void)
 
CString GetCurrentFolder (void)
 
void SendWinMessage (UINT mesg, WPARAM wparam=NULL, LPARAM lparam=NULL)
 
int MessageDLG (LPCTSTR ttl, LPCTSTR msg, UINT type, HWND hWnd)
 
void SaveToClipboard_byStr (CString data)
 
void SaveToClipboard (void *ptr, size_t len)
 
void SendKeyAction (WORD key, SENDKEY_Action action)
 
void SendKeyActionTap (WORD key)
 
void SendKeyActionTap (WORD key1, WORD key2)
 
void SendKeyActionTap (WORD key1, WORD key2, WORD key3)
 
void SendKeyActionTapAlt (WORD key)
 
void SendKeyActionTapShift (WORD key)
 
void SendKeyActionTapCtrl (WORD key)
 
BOOL DoSystemKeyAction (LPCTSTR com, BOOL child=FALSE)
 
TCHAR * GetMouseCursorType (void)
 
unsigned short GetMsecondsTimer (void)
 
unsigned short GetMsecondsLapTimer (unsigned short pm, unsigned short *nt=NULL)
 
CString LoadString_byID (UINT id)
 
void WinSystem (char *command, DWORD flag, BOOL wait)
 
template<class T >
void releaseNull (T *&ptr)
 
template<class T >
void deleteNull (T *&ptr)
 
tList * setBVHJointName (void)
 
tList * addBVHJointName (char *fname, tList *lt)
 
int BVHJoint2NiJointNum (tList *lt, Buffer joint_name)
 
tTree * makeBVH_SLHierarchy (void)
 
tTree * makeBVH_QAvHierarchy (void)
 
tTree * makeBVH_NiHierarchy (void)
 
vector getQAvBVHOffset (int joint)
 
std::string NiJointName (int n)
 
int NiJointNum (char *name)
 
std::string NiSDK2JointName (int joint, NiSDK_Lib lib)
 
int NiSDKMirrorJointNum (int joint, NiSDK_Lib lib)
 
int JointName2NiSDK (char *jname, NiSDK_Lib lib)
 
int Ni2SDKPosJointNum (int joint, NiSDK_Lib lib)
 
int Ni2SDKRotJointNum (int joint, NiSDK_Lib lib)
 
void NiSetKinectJointNums (void)
 
void NiSetOpenNIJointNums (void)
 
void NiSetOpenNI2JointNums (void)
 
NiFrameDatamakeFramesData (int frame, int joint_num, int *frame_num)
 
void freeFramesData (NiFrameData *frmdata, int frm_num)
 
void NiInitRBoundJointsRotation (void)
 
void NiCorrectJointsRotation (Quaternion< double > *quat, NiSDK_Lib lib)
 
void NiCorrectJointEuler (int joint, Quaternion< double > *quat, RBound< double > rb)
 
void NiGetJointEuler (int joint, Quaternion< double > *quat, Vector< double > *vect)
 
void NiSetJointEuler (int joint, Vector< double > *vect, Quaternion< double > *quat)
 
void NiSetUserColor (int label, uByte *ptr, BOOL use_image=TRUE)
 
unsigned int NiGetSkeletonColor (int label)
 
std::string VMDJointName (int n)
 
int VMDJointNum (char *name)
 
int VMD2NiJointNum (int joint)
 

Variables

CSetHeaderDLG SetHeaderDLG
 
UINT TimerID = 1
 
LPDIRECT3D9 GpD3D = NULL
 
LPDIRECTINPUT8 GpDInput = NULL
 
LPDIRECTINPUTDEVICE8 GpDMouse = NULL
 
LPDIRECTINPUTDEVICE8 GpDKeyBoard = NULL
 
BOOL Dx9DividePrimitiveMode = TRUE
 
BOOL Dx9ReverseZMode = FALSE
 
static const WORD WinAudioToolFormat = WAVE_FORMAT_PCM
 
static const WORD WinAudioToolChannels = 1
 
static const DWORD WinAudioToolSamplesPerSec = 16000
 
static const WORD WinAudioToolBitsPerSample = 16
 
CWinSharedMem_Debug_SHM = NULL
 ////////////////////////////////////////////////////////////
 

Detailed Description

pview->vMin 〜 pview->vMax の間で,pview->cMin, pview->cMin を変更する.

呼び出しウィンドウをレンダリングする場合は,pview->cMin, pview->cMinの値が変更される度に 呼び出しウィンドウを再描画する.

マルチスライス読み込み設定ダイアログ

CExDocument クラス

ファイルを読み込むためのテンプレートクラス.

制御用変数
    BOOL hasReadData;   // 読み込みデータを持っているか?
    BOOL hasViewData;   // 表示用データに加工済みか?

予め cmnHeadにデータがある場合は,hasReadData=TRUE にしてOnNewDocument(void)を呼び出す.
データを読み込む場合は OnOpenDocument(LPCTSTR) を呼ぶ.

OnOpenDocument(LPCTSTR) で実際にデータを読み込むためには ReadDataFile(LPCTSTR) をオーバーライドする.
この際データは msGraph, cmnHeadの両方(別々の領域)に読み込むようにすると良い.

データ加工用の関数は MakeData(void) である.これをオーバーライドして,cmnHeadを表示用データ
に加工し,CExViewに渡す.

データの書き込みは  未実装.

CExFrame クラス

CExView とCExDocument を繋ぐためのフレームテンプレートクラス.

マウス制御機能(簡易版)あり.  GetMousePos() (クライアント領域でのマウスの座標)
デフォルトで最大化ボックスは無効である.

CExTextFrame クラス

CExTextView とCExDocument を繋ぐためのフレームテンプレートクラス.

マウス制御機能(簡易版)あり.  GetMousePos() (クライアント領域でのマウスの座標)
デフォルトで最大化ボックスは無効である.

CExToolBar

ウィンドウのリサイズ時,移動時のちらつき防止効果付きツールバー

MFCLib 用入出力関数

CDx2DView クラス

CDxBaseViewクラスからの継承クラス.
対応する Document の cmnHead (pDoc->cmnHead) からデータを受け取り
DirectXの機能を使って 2D画像表示を行う.静止画用.

cmnHead.kind==UN_KNOWN の場合は,ExDocumentクラスで DirectXの機能を
使用して,画像フォーマットの解析を行っておかなければならない.

また,cmnHead.kind が既知(CT_ADAT, CT_3DX, RAS_DATA)の場合に対しては,
depthが 8bitにしか対応していないので,Documentクラスで 8bit化して
おく必要がある.

CDxDirectView クラス

 Viewの viewDataを直接操作して 2D画像を更新するためのクラス.  16/24/32bit カラー対応.  動画用.

CDxGraphDoc クラス

CExDocumentクラスからの継承クラス.
DirectXの機能を利用して,読み込んだ画像のフォーマットを解析する.

画像データは cmnHead, msGraph メンバに格納される.ただし,画像ファイル
のフォーマットが未知の場合は,cmnHead.kind==UN_KNOWN となり,msGraphには
画像は格納されない.画像ファイルのフォーマットが未知の場合(UN_KNOWN)は,
DirectXの機能を使用して,フォーマット解析を行う(msGraphにはデータは無し).

ここで言う「画像データのフォーマットが未知」とは作者が画像フォーマットを
知らないということ.jpeg, bmp等も含む.

画像ファイルのフォーマットが既知の場合(CT_DATA, CT_3DM, RAS_DATAなど),
画像データは msGraphにもコピーされ,cmnHeadの画像データ自体は 8bit化
される.

通常は cmnHead が Viewにわたされる.

    OnOpenDocument(LPCTSTR) -> ReadDataFile(LPCTSTR);
                            -> MakeViewData(void);

CDxMGRView クラス

CDxBaseViewクラスからの継承クラス.マルチ画像表示.16/24/32bit カラー対応.

対応する Document の cmnHead (pDoc->cmnHead) からデータ(3Dデータ可)を受け取り
DirectXの機能を使って 2D表示を行う.対直スクロールバー付き.

現在サポートしているカラー処理は Planeモード (Z方向をRGBの各色に割り当てるモード)のみ

CDxSRenderView クラス (サーフェイスレンダリング)

CDxVTXBaseViewクラスからの継承クラス
対応する Document の msGraph (pDoc->msGraph) からデータを受け取り
(cmnHeadではないので注意),(簡易)サーフェイスレンダリングを行い,
DirectXの機能を使って 3D表示する.

3D表示する場合の色は,ボクセルの輝度値(16bit)に対して,ARGB16(各4bit)
と解釈する.輝度値(16bit)の設定には
    uWord  ARGB2Word(uWord a, uWord r, uWord g, uWord b)    (要 #include "Gdata.h")
    uWord  RGBA2Word(uWord r, uWord g, uWord b, uWord a)    (要 #include "Gdata.h")
    uWord  RGB2Word (uWord r, uWord g, uWord b)             (要 #include "Gdata.h")
を使用すると良い.因みに逆の関数は
    D3DCOLOR  Dx9Word2RGBA(uWord pp)                        (要 #include "Dx9.h")
    D3DCOLOR  Dx9Word2ARGB(uWord pp)                        (要 #include "Dx9.h")
    D3DCOLOR  Dx9Word2RGB (uWord pp)                        (要 #include "Dx9.h")                  

CDxVScrollView クラス

対応する Document の cmnHead (pDoc->cmnHead) からデータを受け取り
縦スクロール付き(画像の伸張なし)の画像を表示する.
DirectXの機能を使用する.

cmnHead.zsize にクライアント領域の初期サイズ(Yサイズ)が格納され
ている必要がある(Zサイズではない).つまり,
    (cmnHead.xsize, cmnHead.ysize) は全体の画像サイズ
    (cmnHead.xsize, cmnHead.zsize) は表示用サイズ

縦スクロールだから,Xサイズ(cmnHead.xsize)は同じ

CLogWndFrame クラス

CDxMGRView クラス用フレーム

ExSMPLDisp.h : ヘッダー ファイル

簡易画像表示

CRwGRDoc クラス

画像ファイルを読み込む.CExDocumentクラスを継承.

予め cmnHeadにデータがある場合は,hasReadData=TRUE にする.
multiSliceData==TRUE の場合は,マルチスライス読み込みモードになり3Dデータとして読み込む.

画像データは 最初 msGraphに読み込まれ, MakeViewData()により cmnHeadへコピーされ(別の
データ領域) 8bit化される.
ただしメモリを節約したい場合,nonCmanHead==TRUEにすれば,データはcmnHeadにはコピーされない.
また,MakeViewData()をオーバーライドしてもよい.

通常は cmnHead が Viewにわたされる.

CvThumbNailFrame クラス

縦スクロールサムネイル画像の表示用フレーム

vThumbNailDoc と DxVScrollView を繋ぐ

Tools for ExWindows ライブラリ

Typedef Documentation

◆ FUNC_STRING

typedef char *(* FUNC_STRING) (int)

サンプル:

Definition at line 47 of file WinDLLTool.h.

◆ MediaBufferQueue

typedef std::queue<CWinMediaBuffer*> MediaBufferQueue

Definition at line 85 of file WinMediaBuffer.h.

◆ MediaBufferStack

typedef std::stack<CWinMediaBuffer*> MediaBufferStack

Definition at line 84 of file WinMediaBuffer.h.

Enumeration Type Documentation

◆ NiSDK_Lib

enum NiSDK_Lib
Enumerator
NiSDK_Default 
NiSDK_None 
NiSDK_Kinect 
NiSDK_OpenNI 
NiSDK_OpenNI2 

Definition at line 34 of file NiToolWin.h.

35{
41};
@ NiSDK_Kinect
Definition NiToolWin.h:38
@ NiSDK_Default
Definition NiToolWin.h:36
@ NiSDK_OpenNI2
Definition NiToolWin.h:40
@ NiSDK_OpenNI
Definition NiToolWin.h:39
@ NiSDK_None
Definition NiToolWin.h:37

◆ SENDKEY_Action

Enumerator
SENDKEY_TapAction 
SENDKEY_DownAction 
SENDKEY_UpAction 

Definition at line 134 of file WinTools.h.

135{
139};
@ SENDKEY_UpAction
Definition WinTools.h:138
@ SENDKEY_TapAction
Definition WinTools.h:136
@ SENDKEY_DownAction
Definition WinTools.h:137

Function Documentation

◆ addBVHJointName()

tList * addBVHJointName ( char * fname,
tList * lt )

Definition at line 103 of file NiBVHName.cpp.

104{
105 tList* pp = dup_tList(nl);
106 tList* lt = pp;
107
108 tList* tl = read_index_tList_file(fname, ' ');
109 if (tl==NULL) return pp;
110
111 //
112 // PELVIS, WAIST, TORSO, ....., R_TOE see NiJointsTool.cpp
113 for (int j=0; j<NI_NORML_JOINT_NUM; j++) {
114 char* joint_name = get_str_param_tList(tl, (char*)NiJointName(j).c_str(), NULL);
115 if (joint_name!=NULL) {
116 pp = add_bvh_name(pp, j, joint_name);
117 free(joint_name);
118 }
119 }
120
121 del_tList(&tl);
122
123 return lt;
124}
#define add_bvh_name(p, n, j)
Definition NiBVHName.h:17
#define NI_NORML_JOINT_NUM
std::string NiJointName(int n)

References add_bvh_name, NI_NORML_JOINT_NUM, and NiJointName().

Referenced by CNiBVHTool::readFile().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ BVHJoint2NiJointNum()

int BVHJoint2NiJointNum ( tList * lt,
Buffer joint_name )

Definition at line 128 of file NiBVHName.cpp.

129{
130 tList* pp = lt;
131
132 if (pp==NULL) return -1;
133
134 while(pp!=NULL) {
135 if (!strcasecmp((char*)joint_name.buf, (char*)pp->ldat.key.buf)) {
136 return pp->ldat.id;
137 }
138 pp = pp->next;
139 }
140
141 return -1;
142}

Referenced by CNiBVHTool::readFile(), and CNiFileTool::writeBVHFile().

Here is the caller graph for this function:

◆ cat_ts2Buffer()

int cat_ts2Buffer ( LPCTSTR str,
Buffer * buf )

int jbxwl::cat_ts2Buffer(LPCTSTR str, Buffer* buf)

Return values
0以上dstのバッファにコピーされた文字数.
-1srcまたは dstが NULL
-2メモリの確保に失敗した.何も実行されなかった.

Definition at line 161 of file WinTools.cpp.

162{
163 if (buf==NULL) return -1;
164 int cc = 0;
165
166#ifdef _UNICODE
167 char* mbstr = ts2mbs(str);
168 cat_s2Buffer(mbstr, buf);
169 ::free(mbstr);
170 cc = buf->vldsz;
171#else
172 cc = cat_s2Buffer((char*)str, buf);
173#endif
174
175 return cc;
176}
char * ts2mbs(LPCTSTR str)
Definition WinTools.h:57

References ts2mbs().

Referenced by get_dir_files_t().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ close_shm_debuger()

void close_shm_debuger ( void )

Definition at line 112 of file WinSMTool.cpp.

113{
114 if (jbxwl::_Debug_SHM != NULL) delete(jbxwl::_Debug_SHM);
115 jbxwl::_Debug_SHM = NULL;
116}
CWinSharedMem * _Debug_SHM
////////////////////////////////////////////////////////////

References _Debug_SHM.

◆ copy_ts2Buffer()

int copy_ts2Buffer ( LPCTSTR str,
Buffer * buf )

int jbxwl::copy_ts2Buffer(LPCTSTR str, Buffer* buf)

Return values
0以上dstのバッファにコピーされた文字数.
-1srcまたは dstが NULL
-2メモリの確保に失敗した.何も実行されなかった.

Definition at line 136 of file WinTools.cpp.

137{
138 if (buf==NULL) return -1;
139 int cc = 0;
140
141#ifdef _UNICODE
142 char* mbstr = ts2mbs(str);
143 copy_s2Buffer(mbstr, buf);
144 ::free(mbstr);
145 cc = buf->vldsz;
146#else
147 cc = copy_s2Buffer((char*)str, buf);
148#endif
149
150 return cc;
151}

References ts2mbs().

Here is the call graph for this function:

◆ copyFileWithCounter()

int copyFileWithCounter ( LPCTSTR src,
LPCTSTR dst )

int jbxwl::copyFileWithCounter(char* src, char* dst)

戻り値: 正数 正常終了
         -1   読み込みファイルが存在しない.またはサイズが 0.
         -2   読み込みファイルをオープンできない.
         -3   書き込みファイルをオープンできない.

         copyFPWithCounter からの戻り値 -10 処理失敗(何も処理されていない?) -11 キャンセル -12 読み込み/書き込みに失敗 -13 指定されたバイト数まで処理されていない

Definition at line 24 of file MFCio.cpp.

25{
26 unsigned long int sz = file_size_t(src);
27 if (sz<=0) return -1;
28
29 FILE* sfp = tfopen(src, _T("rb"));
30 if (sfp==NULL) return -2;
31
32 FILE* dfp = tfopen(dst, _T("wb"));
33 if (dfp==NULL) {
34 fclose(sfp);
35 return -3;
36 }
37
38 int ret = copyFPWithCounter(sfp, dfp, sz);
39
40 fclose(dfp);
41 fclose(sfp);
42
43 if (ret<=0) ret -= 10;
44 return ret;
45}
int copyFPWithCounter(FILE *src, FILE *dst, unsigned long int sz)
Definition MFCio.cpp:58
unsigned long int file_size_t(LPCTSTR fn)
Definition WinTools.cpp:250

References copyFPWithCounter(), and file_size_t().

Referenced by CNiFileTool::saveJTextfromFile().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ copyFPWithCounter()

int copyFPWithCounter ( FILE * src,
FILE * dst,
unsigned long int sz )

int jbxwl::copyFPWithCounter(FILE* src, FILE* dst, unsigned long int sz)

戻り値: 正数 正常終了
          0   処理失敗(何も処理されていない?)
         -1   キャンセル
         -2  読み込み/書き込みに失敗
         -3   指定されたバイト数まで処理されていない

Definition at line 58 of file MFCio.cpp.

59{
60 //
61 // グローバルカウンタの生成
62 CProgressBarDLG* counter = NULL;
63
64 int count_max = 20;
65 int count_intvl = sz/MAXBUFSZ/count_max;
66
67 if (sz>MAXBUFSZ && count_intvl>0) { // 64kByte
68 counter = new CProgressBarDLG(IDD_PROGBAR, NULL, TRUE); // ディスパッチャー有効
69 if (counter!=NULL) {
70 SetGlobalCounter(counter);
71 CString mesg;
72 mesg.LoadString(IDS_STR_WRTNG_FILE);
73 //
74 char* mbstr = ts2mbs(mesg);
75 counter->Start(0, mbstr);
76 ::free(mbstr);
77 }
78 }
79
80 if (counter!=NULL) {
81 counter->SetMax(count_max);
82 counter->SetPos(0);
83 }
84
85 //
86 unsigned char buf[MAXBUFSZ];
87 int sum = 0;
88 int cnt = 0;
89 size_t rsz = 0;
90 size_t wsz = 0;
91
92 //
93 do {
94 rsz = fread(buf, 1, MAXBUFSZ, src);
95 wsz = fwrite(buf, rsz, 1, dst);
96 sum += (int)rsz;
97
98 cnt++;
99 if (counter!=NULL) {
100 if (cnt%count_intvl==0) {
101 counter->StepIt();
102 if (counter->isCanceled()) {
103 sum = -1;
104 break; // キャンセル
105 }
106 }
107 }
108 } while (!feof(src) && rsz>0 && wsz>0);
109
110 // グローバルカウンタの削除
111 if (counter!=NULL) {
112 counter->Stop();
113 ClearGlobalCounter();
114 delete counter;
115 }
116
117 //
118 if (sum!=0) {
119 if (!feof(src) && (rsz==0||wsz==0)) sum = -2;
120 else if (sum!=sz) {
121 DEBUG_ERROR("jbxwl::copyFPWithCounter(): WARNING: File Size is %d, but Write Size is %d\n", sz, sum);
122 sum = -3;
123 }
124 }
125
126 return sum;
127}
virtual void StepIt(int n=1)
virtual void SetPos(int pos)
virtual void Start(int m=100, char *tn=NULL)
virtual void SetMax(int max)
#define IDS_STR_WRTNG_FILE
Definition resource.h:106
#define IDD_PROGBAR
Definition resource.h:6

References IDD_PROGBAR, IDS_STR_WRTNG_FILE, CProgressBarDLG::isCanceled(), CProgressBarDLG::SetMax(), CProgressBarDLG::SetPos(), CProgressBarDLG::Start(), CProgressBarDLG::StepIt(), CProgressBarDLG::Stop(), and ts2mbs().

Referenced by copyFileWithCounter().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ CreateDocFrmView()

CExFrame * CreateDocFrmView ( CMultiDocTemplate * pDocTempl,
CAppCallBack * papp = NULL )

CExFrame* jbxwl::CreateDocFrmView(CMultiDocTemplate* pDocTempl, CAppCallBack* papp)

Document, Frame, View の組み合わせを作成する.

Definition at line 38 of file ExClass.cpp.

39{
40 // クラスの取得
41 CExDocument* pdoc = (CExDocument*)pDocTempl->CreateNewDocument();
42 CExFrame* pfrm = (CExFrame*)pDocTempl->CreateNewFrame(pdoc, NULL);
43 CExView* pviw = (CExView*)pdoc->GetView();
44
45 bool rslt = SetExLink(pdoc, pfrm, pviw, papp);
46 if (!rslt) {
47 if (pdoc!=NULL) {
48 DEBUG_ERROR("jbxwl::CreateDocFrmView(): ERROR: Document is NULL\n");
49 deleteNull(pdoc);
50 }
51 if (pviw!=NULL) {
52 DEBUG_ERROR("jbxwl::CreateDocFrmView(): ERROR: View is NULL\n");
53 deleteNull(pviw);
54 }
55 if (pfrm!=NULL) {
56 DEBUG_ERROR("jbxwl::CreateDocFrmView(): ERROR: Frame is NULL\n");
57 deleteNull(pfrm);
58 }
59 return NULL;
60 }
61 pfrm->pTempl = pDocTempl;
62
63 return pfrm;
64}
CExView * GetView()
CMultiDocTemplate * pTempl
Definition ExFrame.h:44
void deleteNull(T *&ptr)
Definition WinTools.h:229
bool SetExLink(CExDocument *pdoc, CExFrame *pfrm, CExView *pview, CAppCallBack *papp)
Definition ExClass.cpp:18

References deleteNull(), CExDocument::GetView(), CExFrame::pTempl, and SetExLink().

Referenced by ExecTemplate().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ cut_file_extension_t()

CString cut_file_extension_t ( LPCTSTR str)

Definition at line 317 of file WinTools.cpp.

318{
319 CString buf = _T("");
320
321#ifdef _UNICODE
322 char* mbstr = ts2mbs(str);
323 char* pn = cut_file_extension(mbstr); // 要free
324 buf = mbs2ts(pn);
325 ::free(mbstr);
326 ::free(pn);
327#else
328 char* pn = cut_file_extension((char*)str);
329 buf = (LPTSTR)pn;
330 ::free(pn);
331#endif
332
333 return buf;
334}
CString mbs2ts(char *str)
Definition WinTools.cpp:79

References mbs2ts(), and ts2mbs().

Here is the call graph for this function:

◆ deleteNull()

template<class T >
void deleteNull ( T *& ptr)
inline

Definition at line 229 of file WinTools.h.

230{
231 if (!jbxl::isNull(ptr)) {
232 delete ptr;
233 ptr = NULL;
234 }
235}

Referenced by CreateDocFrmView(), CWinAudioTool::free(), and CDxSRenderView::PrepareVB().

Here is the caller graph for this function:

◆ DoSystemKeyAction()

BOOL DoSystemKeyAction ( LPCTSTR com,
BOOL child = FALSE )

return TRUE: com の処理は完了した. FALSE: com の処理はまだ完了していない.

Definition at line 671 of file WinTools.cpp.

672{
673 if (com==NULL) return TRUE;
674
675 //
676 if (!tcscmp(com, _T("UP"))) {
677 SendKeyActionTap(VK_UP);
678 }
679 else if (!tcscmp(com, _T("DOWN"))) {
680 SendKeyActionTap(VK_DOWN);
681 }
682 else if (!tcscmp(com, _T("RIGHT"))) {
683 SendKeyActionTap(VK_RIGHT);
684 }
685 else if (!tcscmp(com, _T("LEFT"))) {
686 SendKeyActionTap(VK_LEFT);
687 }
688 else if (!tcscmp(com, _T("NEXT")) || !tcscmp(com, _T("TAB"))) {
689 SendKeyActionTap(VK_TAB);
690 }
691 else if (!tcscmp(com, _T("BACK"))) {
692 SendKeyActionTap(VK_LSHIFT, VK_TAB);
693 }
694 else if (!tcscmp(com, _T("ENTER"))) {
695 SendKeyActionTap(VK_RETURN);
696 }
697 else if (!tcscmp(com, _T("MENU")) || !tcscmp(com, _T("ALT"))) {
698 SendKeyActionTap(VK_LMENU);
699 }
700 else if (!tcscmp(com, _T("ESC"))) {
701 SendKeyActionTap(VK_ESCAPE);
702 }
703 //
704 else if (!tcscmp(com, _T("CHANGE"))) {
706 }
707 else if (!tcscmp(com, _T("CLOSE"))) {
708 if (child) SendKeyActionTapAlt(VK_F4);
709 else SendKeyActionTapCtrl(VK_F4);
710 }
711 //
712 else {
713 return FALSE;
714 }
715
716 return TRUE;
717}
void SendKeyActionTap(WORD key)
Definition WinTools.h:144
void SendKeyActionTapAlt(WORD key)
Definition WinTools.h:149
void SendKeyActionTapCtrl(WORD key)
Definition WinTools.h:151

References SendKeyActionTap(), SendKeyActionTapAlt(), and SendKeyActionTapCtrl().

Here is the call graph for this function:

◆ Dx9CreateGraphic()

LPDIRECT3DDEVICE9 Dx9CreateGraphic ( LPDIRECT3D9 gpD3D,
D3DPRESENT_PARAMETERS * d3dParam,
HWND hWnd )

機能: DirectX9のグラフィックデバイスを得る. 引数: gpD3D DirectX9のインターフェイス d3dParam デバイス作成のためのパラメータ hWnd デバイスを作成するウィンドウのウィンドウハンドル
戻値: DirectX9デバイス 説明:

Definition at line 93 of file Dx9.cpp.

94{
95 LPDIRECT3DDEVICE9 d3dDevice=NULL;
96 HRESULT hr;
97
98 hr = gpD3D->CreateDevice(D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, hWnd, D3DCREATE_HARDWARE_VERTEXPROCESSING, d3dParam, &d3dDevice);
99 if (FAILED(hr)) {
100 hr = gpD3D->CreateDevice(D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, hWnd, D3DCREATE_SOFTWARE_VERTEXPROCESSING, d3dParam, &d3dDevice);
101 if (FAILED(hr)) {
102 hr = gpD3D->CreateDevice(D3DADAPTER_DEFAULT, D3DDEVTYPE_REF, hWnd, D3DCREATE_SOFTWARE_VERTEXPROCESSING, d3dParam, &d3dDevice);
103 if (FAILED(hr)) return (LPDIRECT3DDEVICE9)NULL;
104 }
105 }
106 return d3dDevice;
107}

Referenced by CDxBaseView::InitDevice().

Here is the caller graph for this function:

◆ Dx9CreateInterface()

BOOL Dx9CreateInterface ( CWinApp * wapp)

機能: DirectX9のデバイスへのインターフェイスを得る. 引数: hinst アプリケーションのインスタンスハンドラ(通常は this->m_hInstanceを指定) 説明:

Definition at line 30 of file Dx9.cpp.

31{
32 GpD3D = Direct3DCreate9(D3D_SDK_VERSION);
33 if (GpD3D==NULL) {
34 DEBUG_INFO("jbxwl::Dx9CreateInterface: ERROR: グラフィックデバイスの取得に失敗しました\n");
35 return FALSE;
36 }
37
38 HRESULT hr = DirectInput8Create(wapp->m_hInstance, DIRECTINPUT_VERSION, IID_IDirectInput8, (void**)&GpDInput, NULL);
39 if (GpDInput==NULL) {
40 DEBUG_INFO("jbxwl::Dx9CreateInterface: ERROR: インプットデバイスの取得に失敗しました\n");
42 return FALSE;
43 }
44 else {
45 GpDMouse = Dx9CreateMouse(GpDInput, wapp->m_pMainWnd->m_hWnd);
46 if (GpDMouse==NULL) {
47 Sleep(1000);
48 GpDMouse = Dx9CreateMouse(GpDInput, wapp->m_pMainWnd->m_hWnd);
49 if (GpDMouse==NULL) {
50 DEBUG_INFO("jbxwl::Dx9CreateInterface(): ERROR: マウスデバイスの取得に失敗しました\n");
53 return FALSE;
54 }
55 }
56 GpDKeyBoard = Dx9CreateKeyBoard(GpDInput, wapp->m_pMainWnd->m_hWnd);
57 if (GpDKeyBoard==NULL) {
58 Sleep(1000);
59 GpDKeyBoard = Dx9CreateKeyBoard(GpDInput, wapp->m_pMainWnd->m_hWnd);
60 if (GpDKeyBoard==NULL) {
61 DEBUG_INFO("jbxwl::Dx9CreateInterface(): ERROR: キーボードデバイスの取得に失敗しました\n");
65 return FALSE;
66 }
67 }
68 }
69
70 return TRUE;
71}
#define DIRECTINPUT_VERSION
Definition Dx9.h:18
#define DXRELEASE(d)
Definition Dx9.h:39
LPDIRECTINPUTDEVICE8 GpDMouse
Definition Dx9.cpp:16
LPDIRECTINPUTDEVICE8 GpDKeyBoard
Definition Dx9.cpp:17
LPDIRECTINPUTDEVICE8 Dx9CreateKeyBoard(LPDIRECTINPUT8, HWND)
Definition Dx9.cpp:151
LPDIRECT3D9 GpD3D
Definition Dx9.cpp:13
LPDIRECTINPUT8 GpDInput
Definition Dx9.cpp:14
LPDIRECTINPUTDEVICE8 Dx9CreateMouse(LPDIRECTINPUT8, HWND)
Definition Dx9.cpp:114

References DIRECTINPUT_VERSION, Dx9CreateKeyBoard(), Dx9CreateMouse(), DXRELEASE, GpD3D, GpDInput, GpDKeyBoard, and GpDMouse.

Here is the call graph for this function:

◆ Dx9CreateKeyBoard()

LPDIRECTINPUTDEVICE8 Dx9CreateKeyBoard ( LPDIRECTINPUT8 gpDInput,
HWND hWnd )

Definition at line 151 of file Dx9.cpp.

152{
153 LPDIRECTINPUTDEVICE8 gpdkeyboard=NULL;
154
155 HRESULT hr = gpDInput->CreateDevice(GUID_SysKeyboard, &gpdkeyboard, NULL);
156 if (FAILED(hr)) return NULL;
157
158 hr = gpdkeyboard->SetDataFormat(&c_dfDIKeyboard);
159 if (FAILED(hr)) return NULL;
160
161 hr = gpdkeyboard->SetCooperativeLevel(hWnd, DISCL_NONEXCLUSIVE | DISCL_FOREGROUND);
162 if (FAILED(hr)) return NULL;
163 else return gpdkeyboard;
164}

Referenced by Dx9CreateInterface().

Here is the caller graph for this function:

◆ Dx9CreateMouse()

LPDIRECTINPUTDEVICE8 Dx9CreateMouse ( LPDIRECTINPUT8 gpDInput,
HWND hWnd )

Definition at line 114 of file Dx9.cpp.

115{
116 LPDIRECTINPUTDEVICE8 gpdmouse=NULL;
117
118 HRESULT hr = gpDInput->CreateDevice(GUID_SysMouse, &gpdmouse, NULL);
119 if (FAILED(hr) || gpdmouse==NULL) return NULL;
120
121 hr = gpdmouse->SetDataFormat(&c_dfDIMouse);
122 if (FAILED(hr)) return NULL;
123
124 hr = gpdmouse->SetCooperativeLevel(hWnd, DISCL_NONEXCLUSIVE | DISCL_FOREGROUND);
125 if (FAILED(hr)) return NULL;
126
127// 軸モード
128/* DIPROPDWORD diprop;
129 diprop.diph.dwSize = sizeof(diprop);
130 diprop.diph.dwHeaderSize = sizeof(diprop.diph);
131 diprop.diph.dwObj = 0;
132 diprop.diph.dwHow = DIPH_DEVICE;
133 diprop.dwData = DIPROPAXISMODE_ABS;
134 hr = gpdmouse->SetProperty(DIPROP_AXISMODE, &diprop.diph);
135 if (FAILED(hr)) {
136 DEBUG_INFO("Dx9CreateMouse: SetProprty\n");
137 return NULL;
138 }
139/**/
140 hr = gpdmouse->Acquire();
141 if (FAILED(hr)) return NULL;
142
143 return gpdmouse;
144}

Referenced by Dx9CreateInterface().

Here is the caller graph for this function:

◆ Dx9DrawPrimitive()

HRESULT Dx9DrawPrimitive ( LPDIRECT3DDEVICE9 gpD3DDevice,
D3DPRIMITIVETYPE ptype,
UINT unit,
UINT bsize )

Definition at line 335 of file Dx9.cpp.

336{
337 HRESULT hr;
338
339 if (Dx9DividePrimitiveMode) { // 分割描画モード
340 UINT iter = bsize / DXMAXPRIMITIVE;
341 UINT imod = bsize % DXMAXPRIMITIVE;
342
343 unsigned int i;
344 for (i=0; i<iter; i++) {
345 hr = gpD3DDevice->DrawPrimitive(ptype, i*unit*DXMAXPRIMITIVE, DXMAXPRIMITIVE);
346 if (FAILED(hr)) return hr;
347 }
348 hr = gpD3DDevice->DrawPrimitive(ptype, i*unit*DXMAXPRIMITIVE, imod);
349 //if (FAILED(hr)) Dx9DividePrimitiveMode = FALSE;
350 }
351 else { // ノーマルモード
352 hr = gpD3DDevice->DrawPrimitive(ptype, 0, bsize);
353 //if (FAILED(hr)) Dx9DividePrimitiveMode = TRUE;
354 }
355
356 return hr;
357}
#define DXMAXPRIMITIVE
Definition Dx9.h:41
BOOL Dx9DividePrimitiveMode
Definition Dx9.cpp:20

References Dx9DividePrimitiveMode, and DXMAXPRIMITIVE.

Referenced by CDxSRenderView::ExecRender().

Here is the caller graph for this function:

◆ Dx9GetBackBuffer()

POINT Dx9GetBackBuffer ( LPDIRECT3DDEVICE9 gpD3DDevice,
LPDIRECT3DSURFACE9 * pgpBackBuffer )

Definition at line 175 of file Dx9.cpp.

176{
177 POINT pt;
178 pt.x = pt.y = -1;
179
180 HRESULT hr = gpD3DDevice->GetBackBuffer(0, 0, D3DBACKBUFFER_TYPE_MONO, pgpBackBuffer);
181 if (FAILED(hr)) return pt;
182
183 pt = Dx9GetSurfaceSize(pgpBackBuffer);
184 return pt;
185}
POINT Dx9GetSurfaceSize(LPDIRECT3DSURFACE9 *lpsf)
Definition Dx9.cpp:361

References Dx9GetSurfaceSize().

Referenced by CDx2DView::InitObject(), CDxDirectView::InitObject(), CDxMGRView::InitObject(), CDxVScrollView::InitObject(), CDx2DView::OnInitialUpdate(), CDxDirectView::OnInitialUpdate(), CDxMGRView::OnInitialUpdate(), and CDxVScrollView::OnInitialUpdate().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ Dx9GetSurfaceSize()

POINT Dx9GetSurfaceSize ( LPDIRECT3DSURFACE9 * lpsf)

Definition at line 361 of file Dx9.cpp.

362{
363 D3DSURFACE_DESC desc;
364 POINT pt;
365
366 (*lpsf)->GetDesc(&desc);
367 pt.x = desc.Width;
368 pt.y = desc.Height;
369
370 return pt;
371}

Referenced by Dx9GetBackBuffer().

Here is the caller graph for this function:

◆ Dx9ReleaseInterface()

void Dx9ReleaseInterface ( )

Definition at line 75 of file Dx9.cpp.

References DXRELEASE, GpD3D, GpDInput, GpDKeyBoard, and GpDMouse.

◆ Dx9SurfaceFromByteMemory()

BOOL Dx9SurfaceFromByteMemory ( LPDIRECT3DDEVICE9 gpD3DDevice,
LPDIRECT3DSURFACE9 * pgpSurface,
CmnHead cmnHead )

Definition at line 236 of file Dx9.cpp.

237{
238 HRESULT hr = gpD3DDevice->CreateOffscreenPlainSurface(cmnHead.xsize, cmnHead.ysize, D3DFMT_R5G6B5, D3DPOOL_DEFAULT, pgpSurface, NULL);
239 if (FAILED(hr)) return FALSE;
240
241 RECT rect;
242 rect.left = 0;
243 rect.top = 0;
244 rect.right = cmnHead.xsize - 1;
245 rect.bottom = cmnHead.ysize - 1;
246 hr = D3DXLoadSurfaceFromMemory(*pgpSurface, NULL, NULL, cmnHead.grptr, D3DFMT_L8, cmnHead.xsize, NULL, &rect, D3DX_FILTER_NONE, 0);
247// hr = D3DXLoadSurfaceFromMemory(*pgpSurface, NULL, NULL, cmnHead.grptr, D3DFMT_L16, cmnHead.xsize*2, NULL, &rect, D3DX_FILTER_NONE, 0);
248 if (FAILED(hr)) return FALSE;
249 return TRUE;
250}

Referenced by Dx9SurfaceFromMemory().

Here is the caller graph for this function:

◆ Dx9SurfaceFromMemory()

BOOL Dx9SurfaceFromMemory ( LPDIRECT3DDEVICE9 gpD3DDevice,
LPDIRECT3DSURFACE9 * pgpSurface,
CmnHead cmnHead )

Definition at line 198 of file Dx9.cpp.

199{
200 BOOL ret;
201
202 if (cmnHead.kind==HEADER_NONE) return FALSE;
203 int chk = cmnHead.kind & 0x00ff;
204
205 if (chk==UN_KNOWN_DATA) ret = Dx9SurfaceFromMemoryFile(gpD3DDevice, pgpSurface, cmnHead);
206 else ret = Dx9SurfaceFromByteMemory(gpD3DDevice, pgpSurface, cmnHead);
207 return ret;
208}
BOOL Dx9SurfaceFromByteMemory(LPDIRECT3DDEVICE9, LPDIRECT3DSURFACE9 *, CmnHead)
Definition Dx9.cpp:236
BOOL Dx9SurfaceFromMemoryFile(LPDIRECT3DDEVICE9, LPDIRECT3DSURFACE9 *, CmnHead)
Definition Dx9.cpp:216

References Dx9SurfaceFromByteMemory(), and Dx9SurfaceFromMemoryFile().

Referenced by CDx2DView::InitObject(), and CDx2DView::OnInitialUpdate().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ Dx9SurfaceFromMemoryFile()

BOOL Dx9SurfaceFromMemoryFile ( LPDIRECT3DDEVICE9 gpD3DDevice,
LPDIRECT3DSURFACE9 * pgpSurface,
CmnHead cmnHead )

Definition at line 216 of file Dx9.cpp.

217{
218 //HRESULT hr = gpD3DDevice->CreateOffscreenPlainSurface(
219 // cmnHead.xsize, cmnHead.ysize, (D3DFORMAT)cmnHead.depth, D3DPOOL_DEFAULT, pgpSurface, NULL);
220
221 HRESULT hr = gpD3DDevice->CreateOffscreenPlainSurface(cmnHead.xsize, cmnHead.ysize, D3DFMT_X8R8G8B8, D3DPOOL_DEFAULT, pgpSurface, NULL);
222 if (FAILED(hr)) return FALSE;
223
224 hr = D3DXLoadSurfaceFromFileInMemory(*pgpSurface, NULL, NULL, cmnHead.grptr, cmnHead.lsize, NULL, D3DX_FILTER_NONE, 0, (D3DXIMAGE_INFO*)cmnHead.buf);
225 if (FAILED(hr)) return FALSE;
226
227 return TRUE;
228}

Referenced by Dx9SurfaceFromMemory().

Here is the caller graph for this function:

◆ Dx9TextureFromByteMemory()

BOOL Dx9TextureFromByteMemory ( LPDIRECT3DDEVICE9 gpD3DDevice,
LPDIRECT3DTEXTURE9 * pgpTexture,
CmnHead cmnHead )

Definition at line 296 of file Dx9.cpp.

297{
298 HRESULT hr;
299 RECT rect;
300 LPDIRECT3DSURFACE9 surface;
301
302 hr = D3DXCreateTexture(gpD3DDevice, cmnHead.xsize, cmnHead.ysize, 0, D3DUSAGE_RENDERTARGET, D3DFMT_L8, D3DPOOL_DEFAULT, pgpTexture);
303 if (FAILED(hr)) return FALSE;
304
305 hr = (*pgpTexture)->GetSurfaceLevel(0, &surface);
306 if (FAILED(hr)) return FALSE;
307
308 rect.left = 0;
309 rect.top = 0;
310 rect.right = cmnHead.xsize - 1;
311 rect.bottom = cmnHead.ysize - 1;
312 hr = D3DXLoadSurfaceFromMemory(surface, NULL, NULL, cmnHead.grptr, D3DFMT_L8, cmnHead.xsize, NULL, &rect, D3DX_FILTER_LINEAR, 0);
313 DXRELEASE(surface);
314
315 if (FAILED(hr)) return FALSE;
316 return TRUE;
317}

References DXRELEASE.

Referenced by Dx9TextureFromMemory().

Here is the caller graph for this function:

◆ Dx9TextureFromMemory()

BOOL Dx9TextureFromMemory ( LPDIRECT3DDEVICE9 gpD3DDevice,
LPDIRECT3DTEXTURE9 * pgpTexture,
CmnHead cmnHead )

Definition at line 263 of file Dx9.cpp.

264{
265 BOOL ret;
266
267 if (cmnHead.kind==HEADER_NONE) return FALSE;
268 int chk = cmnHead.kind & 0x00ff;
269
270 if (chk==UN_KNOWN_DATA) ret = Dx9TextureFromMemoryFile(gpD3DDevice, pgpTexture, cmnHead);
271 else ret = Dx9TextureFromByteMemory(gpD3DDevice, pgpTexture, cmnHead);
272 return ret;
273}
BOOL Dx9TextureFromMemoryFile(LPDIRECT3DDEVICE9, LPDIRECT3DTEXTURE9 *, CmnHead)
Definition Dx9.cpp:281
BOOL Dx9TextureFromByteMemory(LPDIRECT3DDEVICE9, LPDIRECT3DTEXTURE9 *, CmnHead)
Definition Dx9.cpp:296

References Dx9TextureFromByteMemory(), and Dx9TextureFromMemoryFile().

Here is the call graph for this function:

◆ Dx9TextureFromMemoryFile()

BOOL Dx9TextureFromMemoryFile ( LPDIRECT3DDEVICE9 gpD3DDevice,
LPDIRECT3DTEXTURE9 * pgpTexture,
CmnHead cmnHead )

Definition at line 281 of file Dx9.cpp.

282{
283 HRESULT hr = D3DXCreateTextureFromFileInMemoryEx(
284 gpD3DDevice, cmnHead.grptr, cmnHead.lsize, 0, 0, 0, 0, D3DFMT_A8R8G8B8, D3DPOOL_DEFAULT, //D3DPOOL_MANAGED,
285 D3DX_FILTER_LINEAR, D3DX_FILTER_LINEAR, 0, NULL, NULL, pgpTexture);
286 if (FAILED(hr)) return FALSE;
287 return TRUE;
288}

Referenced by Dx9TextureFromMemory().

Here is the caller graph for this function:

◆ Dx9Word2ARGB()

D3DCOLOR Dx9Word2ARGB ( uWord pp)
inline

Definition at line 88 of file Dx9.h.

89{
90 int r, g, b, a;
91
92 if (isBigEndian) {
93 a = (int)((pp&0xf000)>>12);
94 r = (int)((pp&0x0f00)>>8);
95 g = (int)((pp&0x00f0)>>4);
96 b = (int) (pp&0x000f);
97 }
98 else {
99 g = (int)((pp&0xf000)>>12);
100 b = (int)((pp&0x0f00)>>8);
101 a = (int)((pp&0x00f0)>>4);
102 r = (int) (pp&0x000f);
103 }
104
105 return D3DCOLOR_ARGB(a*17, r*17, g*17, b*17);
106}

Referenced by CDxSRenderView::PrepareVB().

Here is the caller graph for this function:

◆ Dx9Word2RGB()

D3DCOLOR Dx9Word2RGB ( uWord pp)
inline

Definition at line 110 of file Dx9.h.

111{
112 int r, g, b;
113
114 if (isLittleEndian) swap_byte(&pp, 2, 2);
115
116 r = (int)((pp&0xf800)>>11);
117 g = (int)((pp&0x07e0)>>5);
118 b = (int) (pp&0x001f);
119
120 return D3DCOLOR_XRGB((int)(r*8.23), (int)(g*4.05), (int)(b*8.23));
121}

Referenced by CDxSRenderView::PrepareVB().

Here is the caller graph for this function:

◆ Dx9Word2RGBA()

D3DCOLOR Dx9Word2RGBA ( uWord pp)
inline

Definition at line 66 of file Dx9.h.

67{
68 int r, g, b, a;
69
70 if (isBigEndian) {
71 r = (int)((pp&0xf000)>>12);
72 g = (int)((pp&0x0f00)>>8);
73 b = (int)((pp&0x00f0)>>4);
74 a = (int) (pp&0x000f);
75 }
76 else {
77 b = (int)((pp&0xf000)>>12);
78 a = (int)((pp&0x0f00)>>8);
79 r = (int)((pp&0x00f0)>>4);
80 g = (int) (pp&0x000f);
81 }
82
83 return D3DCOLOR_RGBA(r*17, g*17, b*17, a*17);
84}

Referenced by CDxSRenderView::PrepareVB().

Here is the caller graph for this function:

◆ EasyGetOpenFileName()

CString EasyGetOpenFileName ( LPCTSTR title = NULL,
HWND hWnd = NULL )

CString jbxwl::EasyGetOpenFileName(LPCWSTR title, HWND hWnd) : UNICODE用 CString jbxwl::EasyGetOpenFileName(LPCTSTR title, HWND hWnd) : マルチバイト用

読み込み用ファイル名を得るためのダイアログを表示する.

Parameters
title: ダイアログのタイトル.
hWnd: ウィンドウハンドル
Return values
CString: ファイルへのパス

Definition at line 271 of file ExClass.cpp.

272{
273 TCHAR fn[LPATH];
274#endif
275 OPENFILENAME ofn;
276
277 bzero(fn, sizeof(fn));
278 bzero(&ofn, sizeof(ofn));
279
280 ofn.lStructSize = sizeof(ofn);
281 ofn.hwndOwner = hWnd;
282 ofn.Flags = OFN_HIDEREADONLY;
283 ofn.lpstrFile = fn;
284 ofn.nMaxFile = sizeof(fn) / sizeof(fn[0]);
285 if (title != NULL) ofn.lpstrTitle = title;
286
287 GetOpenFileName(&ofn);
288 return fn;
289
290 /*
291 CFileDialog fileDialog(true);
292
293 if (fileDialog.DoModal() == IDOK) {
294 return fileDialog.GetPathName();
295 }
296 return _T("");
297 */
298}

Referenced by ExecTemplate().

Here is the caller graph for this function:

◆ EasyGetSaveFileName()

CString EasyGetSaveFileName ( LPCTSTR title = NULL,
LPCTSTR extnt = NULL,
HWND hWnd = NULL )

CString jbxwl::EasyGetSaveFileName(LPCWSTR title, LPCWSTR extnt, HWND hWnd) : UNICODE用 CString jbxwl::EasyGetSaveFileName(LPCTSTR title, LPCTSTR extnt, HWND hWnd) : マルチバイト用

保存用ファイル名を得るためのダイアログを表示する.

Parameters
title: ダイアログのタイトル.
extnt: 保存用ファイルの拡張子
hWnd: ウィンドウハンドル
Return values
CString: ファイルへのパス

Definition at line 317 of file ExClass.cpp.

318{
319 TCHAR fn[LPATH];
320#endif
321 OPENFILENAME ofn;
322
323 bzero(fn, sizeof(fn));
324 bzero(&ofn, sizeof(ofn));
325
326 ofn.lStructSize = sizeof(ofn);
327 ofn.hwndOwner = hWnd;
328 ofn.Flags = 0;
329 ofn.lpstrFile = fn;
330 //ofn.nMaxFile = LPATH;
331 ofn.nMaxFile = sizeof(fn) / sizeof(fn[0]);
332 ofn.lpstrDefExt = extnt;
333 if (title != NULL) ofn.lpstrTitle = title;
334
335 GetSaveFileName(&ofn);
336 return fn;
337}

◆ EasyGetSaveFolderName()

CString EasyGetSaveFolderName ( LPCTSTR folder = _T(""),
LPCTSTR title = NULL,
HWND hWnd = NULL )

CString jbxwl::EasyGetSaveFolderName(LPCTSTR folder, LPCTSTR title, HWND hWnd)

保存用フォルダ名を得るためのダイアログを表示する.

Bug
おそらく UNICODEでは動かない?

Definition at line 352 of file ExClass.cpp.

353{
354 TCHAR fldr[LPATH];
355#endif
356 BROWSEINFO bri;
357 LPITEMIDLIST pilst;
358
359 CString str = _T("");
360
361 bzero(fldr, LPATH);
362 bzero(&bri, sizeof(bri));
363
364 bri.hwndOwner = hWnd;
365 bri.lpszTitle = title;
366 bri.ulFlags = BIF_RETURNONLYFSDIRS;
367
368 bri.lpfn = &EasyGetSaveFolderNameCallBack; // コールバック関数
369 bri.lParam = (LPARAM)folder; // コールバック関数の引数
370
371 pilst = SHBrowseForFolder(&bri);
372 if (pilst!=NULL) {
373 SHGetPathFromIDList(pilst, fldr);
374 str = fldr;
375 CoTaskMemFree(pilst);
376 }
377
378 return str;
379}
int CALLBACK EasyGetSaveFolderNameCallBack(HWND hwnd, UINT uMsg, LPARAM lParam, LPARAM lpData)
Definition ExClass.cpp:387

References EasyGetSaveFolderNameCallBack().

Here is the call graph for this function:

◆ EasyGetSaveFolderNameCallBack()

int CALLBACK EasyGetSaveFolderNameCallBack ( HWND hwnd,
UINT uMsg,
LPARAM lParam,
LPARAM lpData )

int CALLBACK jbxwl::EasyGetSaveFolderNameCallBack(HWND hwnd, UINT uMsg, LPARAM lParam, LPARAM lpData)

EasyGetSaveFolderName() 用コールバック関数.

Definition at line 387 of file ExClass.cpp.

388{
389 if(uMsg==BFFM_INITIALIZED){
390 SendMessage(hwnd, BFFM_SETSELECTION, (WPARAM)TRUE, lpData);
391 }
392 return 0;
393}

Referenced by EasyGetSaveFolderName().

Here is the caller graph for this function:

◆ ExecDocFrmView()

int ExecDocFrmView ( CExFrame * pfrm,
LPCTSTR fname = NULL )

int jbxwl::ExecDocFrmView(CExFrame* pfrm, LPCTSTR fname)

フレームに関連付けれたクラスを使用して,データ読み込み,表示を行う.
データの読み込みには InitialDocView() を使用する

Definition at line 99 of file ExClass.cpp.

100{
101 if (pfrm ==NULL) return 1;
102 if (fname!=NULL) pfrm->pDoc->Title = get_file_name_t(fname);
103
104 //
105 BOOL rslt = InitialDocView(pfrm, fname);
106 if (!rslt) {
107 int ret;
108 // この場所でのメッセージ表示はしない.
109 if ( pfrm->doneErrorMessage) ret = MSG_DFV_NOT_DISP;
110 else if ( pfrm->cancelOperation) ret = MSG_DFV_CANCEL;
111 else if (!pfrm->pDoc->hasReadData) ret = MSG_DFV_ERR_READ;
112 else if (!pfrm->pDoc->hasViewData) ret = MSG_DFV_UNVISIBLE;
113 else if (!pfrm->pView->hasViewData) ret = MSG_DFV_FAIL_VIEW;
114
115 delete pfrm; // Debug構成でコンパイルすると,CDxSRenderViewで頂点数0の場合,ここでセグメンテーションエラーを起こす?
116 return ret;
117 }
118 pfrm->ShowWindow(SW_SHOW);
119 pfrm->SetFocus();
120 pfrm->pView->SetFocus();
121
122 //
123 CString title = pfrm->pDoc->preTitle + pfrm->pDoc->Title + pfrm->pDoc->pstTitle;
124 if (title.IsEmpty()) {
125 pfrm->pDoc->preTitle = _T("Title: ");
126 pfrm->pDoc->Title = _T("Temporary Blank");
127 pfrm->pDoc->pstTitle = _T("");
128 title = pfrm->pDoc->preTitle + pfrm->pDoc->Title + pfrm->pDoc->pstTitle;
129 }
130 if (pfrm->preTitle.IsEmpty()) pfrm->preTitle = pfrm->pDoc->preTitle;
131 if (pfrm->Title.IsEmpty()) pfrm->Title = title;
132 if (pfrm->pView->Title.IsEmpty()) pfrm->pView->Title = title;
133 //
134 pfrm->pView->SetTitle(title);
135 pfrm->pDoc->SetTitle(title);
136 pfrm->SetTitle(title);
137 pfrm->SetWindowText(title);
138
139 return 0;
140}
#define MSG_DFV_FAIL_VIEW
Definition ExClass.h:26
#define MSG_DFV_NOT_DISP
Definition ExClass.h:21
#define MSG_DFV_UNVISIBLE
Definition ExClass.h:25
#define MSG_DFV_CANCEL
Definition ExClass.h:23
#define MSG_DFV_ERR_READ
Definition ExClass.h:24
CString Title
Definition ExFrame.h:37
CExView * pView
Definition ExFrame.h:42
CExDocument * pDoc
Definition ExFrame.h:41
bool cancelOperation
Definition ExFrame.h:52
CString preTitle
Definition ExFrame.h:38
bool doneErrorMessage
Definition ExFrame.h:51
CString Title
Definition ExView.h:83
BOOL hasViewData
Definition ExView.h:81
void SetTitle(LPCTSTR title)
Definition ExView.cpp:348
CString get_file_name_t(LPCTSTR str)
Definition WinTools.cpp:277
BOOL InitialDocView(CExFrame *pfrm, LPCTSTR fname)
Definition ExClass.cpp:73

References CExFrame::cancelOperation, CExFrame::doneErrorMessage, get_file_name_t(), CExDocument::hasReadData, CExDocument::hasViewData, CExView::hasViewData, InitialDocView(), MSG_DFV_CANCEL, MSG_DFV_ERR_READ, MSG_DFV_FAIL_VIEW, MSG_DFV_NOT_DISP, MSG_DFV_UNVISIBLE, CExFrame::pDoc, CExDocument::preTitle, CExFrame::preTitle, CExDocument::pstTitle, CExFrame::pView, CExView::SetTitle(), CExDocument::Title, CExFrame::Title, and CExView::Title.

Referenced by ExecTemplate().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ ExecDocFrmViewError()

void ExecDocFrmViewError ( HWND hwnd,
int ret )

void jbxwl::ExecDocFrmViewError(HWND hwnd, int ret)

jbxwl::ExecDocFrmView() のエラーを処理する.

Definition at line 148 of file ExClass.cpp.

149{
150 if (ret>0) { // !=MSG_DFV_NOT_DISP (-1)
151 CString mesg;
152 int err_flag = false;
153
154 if (ret==MSG_DFV_FR_NULL) {
155 mesg.LoadString(IDS_STR_NULLPT_FRM); // Frameへのポインタが NULLです
156 err_flag = true;
157 }
158 else if (ret==MSG_DFV_CANCEL){
159 mesg.LoadString(IDS_STR_CANCEL_OPRTN); // 操作がキャンセルされました
160 err_flag = true;
161 }
162 else if (ret==MSG_DFV_ERR_READ) {
163 mesg.LoadString(IDS_STR_ERR_OPEN_FILE); // ファイルの読み込みエラーです
164 err_flag = true;
165 }
166 else if (ret==MSG_DFV_UNVISIBLE) {
167 mesg.LoadString(IDS_STR_ERR_UNDISP); // 表示不可能なファイルです
168 err_flag = true;
169 }
170 else if (ret==MSG_DFV_FAIL_VIEW) {
171 mesg.LoadString(IDS_STR_ERR_PREDISP); // 表示の準備に失敗しました
172 err_flag = true;
173 }
174 if (err_flag) MessageBox(hwnd, mesg, NULL, MB_OK);
175 }
176 return;
177}
#define MSG_DFV_FR_NULL
Definition ExClass.h:22
#define IDS_STR_NULLPT_FRM
Definition resource.h:77
#define IDS_STR_CANCEL_OPRTN
Definition resource.h:78
#define IDS_STR_ERR_UNDISP
Definition resource.h:80
#define IDS_STR_ERR_OPEN_FILE
Definition resource.h:79
#define IDS_STR_ERR_PREDISP
Definition resource.h:81

References IDS_STR_CANCEL_OPRTN, IDS_STR_ERR_OPEN_FILE, IDS_STR_ERR_PREDISP, IDS_STR_ERR_UNDISP, IDS_STR_NULLPT_FRM, MSG_DFV_CANCEL, MSG_DFV_ERR_READ, MSG_DFV_FAIL_VIEW, MSG_DFV_FR_NULL, and MSG_DFV_UNVISIBLE.

Referenced by ExecTemplate().

Here is the caller graph for this function:

◆ ExecLogWnd()

CLogWndFrame * ExecLogWnd ( CMultiDocTemplate * pDocTempl,
LPCTSTR title,
CAppCallBack * app )

Definition at line 151 of file LogWndFrame.cpp.

152{
153 // クラスの取得
154 CLogWndDoc* pdoc = (CLogWndDoc*)pDocTempl->CreateNewDocument();
155 CLogWndFrame* pfrm = (CLogWndFrame*)pDocTempl->CreateNewFrame((CDocument*)pdoc, NULL);
156 CLogWndView* pviw = pdoc->GetView();
157 pfrm->pTempl = pDocTempl;
158
159 if (pdoc==NULL || pfrm==NULL || pviw==NULL) return NULL;
160
161 pdoc->pView = pfrm->pView = pviw;
162 pdoc->pFrame = pviw->pFrame = pfrm;
163 pviw->pDoc = pfrm->pDoc = pdoc;
164 pfrm->pApp = pviw->pApp = app;
165 pfrm->Title = title;
166
167 pfrm->CExTextFrame::pView = (CExTextView*) pviw;
168 pfrm->CExTextFrame::pDoc = (CDocument*) pdoc;
169 pviw->CExTextView::pFrame = (CExTextFrame*)pfrm;
170 pviw->CExTextView::pDoc = (CDocument*) pdoc;
171
172 //
173 pfrm->ShowWindow(SW_SHOW);
174 pfrm->SetFocus();
175 pfrm->pView->SetFocus();
176
177 if (!pfrm->Title.IsEmpty()) {
178 pfrm->pView->SetTitle(pfrm->Title);
179 }
180
181 return pfrm;
182}
CAppCallBack * pApp
Definition ExTextFrame.h:43
CMultiDocTemplate * pTempl
Definition ExTextFrame.h:44
CAppCallBack * pApp
Definition ExTextView.h:36
CLogWndView * pView
Definition LogWndDoc.h:37
CLogWndFrame * pFrame
Definition LogWndDoc.h:36
CLogWndView * GetView(void)
CLogWndView * pView
Definition LogWndFrame.h:31
CLogWndDoc * pDoc
Definition LogWndFrame.h:30
CLogWndDoc * pDoc
Definition LogWndView.h:29
CLogWndFrame * pFrame
Definition LogWndView.h:30
void SetTitle(LPCTSTR title)

References CLogWndDoc::GetView(), CExTextFrame::pApp, CExTextView::pApp, CLogWndFrame::pDoc, CLogWndView::pDoc, CLogWndDoc::pFrame, CLogWndView::pFrame, CExTextFrame::pTempl, CLogWndDoc::pView, CLogWndFrame::pView, CLogWndView::SetTitle(), and CExTextFrame::Title.

Here is the call graph for this function:

◆ ExecTemplate()

int ExecTemplate ( CMultiDocTemplate * ptemp,
ExMSGraph< sWord > * pmsGraph = NULL,
ExCmnHead * pcmnHead = NULL,
CExFrame * prntFrm = NULL,
int viewPoint = 0 )

int jbxwl::ExecTemplate(CMultiDocTemplate* ptemp, ExMSGraph<sWord>* pmsGraph, ExCmnHead* pcmnHead, CExFrame* prntFrm, int viewPoint)

テンプレートを起動する.
渡すデータに対してメモリ管理機能あり.
メモリ管理していないデータを渡した場合は,クリアされる.

Definition at line 187 of file ExClass.cpp.

188{
189 int ret, color = GRAPH_COLOR_MONO;
190 BOOL hasReadData = FALSE;
191 BOOL hasViewData = FALSE;
192 HWND hWnd = NULL;
193 CExFrame* pfrm = NULL;
194 CExDocument* prntDoc = NULL;
195
196 if (prntFrm!=NULL) {
197 hWnd = prntFrm->m_hWnd;
198 prntDoc = prntFrm->pDoc;
199 color = prntFrm->colorMode;
200 }
201
202 if (pmsGraph!=NULL) {
203 if (!pmsGraph->isNull()) hasReadData = TRUE;
204 }
205 if (pcmnHead!=NULL) {
206 if (!pcmnHead->isNull()) hasViewData = TRUE;
207 }
208
209 if (hasViewData) {
210 pfrm = CreateDocFrmView(ptemp, NULL);
211 pfrm->pDoc->hasReadData = TRUE;
212 pfrm->pDoc->hasViewData = TRUE;
213 pfrm->pDoc->cmnHead = *pcmnHead;
214 pfrm->pDoc->colorMode = color;
215 pfrm->pDoc->preTitle = _T("");
216 pfrm->pDoc->Title = prntFrm->pDoc->Title;
217 pfrm->pDoc->pstTitle = prntFrm->pDoc->pstTitle;
218 if (prntDoc!=NULL) pfrm->pDoc->ctrlCntrst = prntDoc->ctrlCntrst;
219 pfrm->pView->vSBpos = viewPoint;
220 ret = ExecDocFrmView(pfrm);
221 }
222
223 else if (hasReadData) {
224 pfrm = CreateDocFrmView(ptemp, NULL);
225 pfrm->pDoc->hasReadData = TRUE;
226 pfrm->pDoc->msGraph = *pmsGraph;
227 pfrm->pDoc->colorMode = color;
228 pfrm->pDoc->preTitle = _T("");
229 pfrm->pDoc->Title = prntFrm->pDoc->Title;
230 pfrm->pDoc->pstTitle = prntFrm->pDoc->pstTitle;
231 if (prntDoc!=NULL) pfrm->pDoc->ctrlCntrst = prntDoc->ctrlCntrst;
232 pfrm->pView->vSBpos = viewPoint;
233 ret = ExecDocFrmView(pfrm);
234 }
235
236 else {
237 CString mesg;
238 mesg.LoadString(IDS_STR_OPEN_FILE);
239 CString fname = EasyGetOpenFileName(mesg, hWnd);
240 if (fname.IsEmpty()) return -1;
241
242 pfrm = CreateDocFrmView(ptemp, NULL);
243 pfrm->pDoc->multiSliceData = TRUE;
244 pfrm->pDoc->colorMode = color;
245 if (prntDoc!=NULL) pfrm->pDoc->ctrlCntrst = prntDoc->ctrlCntrst;
246 ret = ExecDocFrmView(pfrm, fname);
247 }
248
249 ExecDocFrmViewError(hWnd, ret);
250
251 return ret;
252}
ExCmnHead cmnHead
Definition ExDocument.h:53
ExMSGraph< sWord > msGraph
Definition ExDocument.h:52
CString EasyGetOpenFileName(LPCTSTR title=NULL, HWND hWnd=NULL)
Definition ExClass.cpp:271
int ExecDocFrmView(CExFrame *pfrm, LPCTSTR fname=NULL)
Definition ExClass.cpp:99
CExFrame * CreateDocFrmView(CMultiDocTemplate *pDocTemp, CAppCallBack *papp=NULL)
Definition ExClass.cpp:38
void ExecDocFrmViewError(HWND hwnd, int ret)
Definition ExClass.cpp:148
#define IDS_STR_OPEN_FILE
Definition resource.h:114

References CExDocument::cmnHead, CExDocument::colorMode, CExFrame::colorMode, CreateDocFrmView(), CExDocument::ctrlCntrst, EasyGetOpenFileName(), ExecDocFrmView(), ExecDocFrmViewError(), CExDocument::hasReadData, CExDocument::hasViewData, IDS_STR_OPEN_FILE, CExDocument::msGraph, CExDocument::multiSliceData, CExFrame::pDoc, CExDocument::preTitle, CExDocument::pstTitle, CExFrame::pView, CExDocument::Title, and CExView::vSBpos.

Referenced by CvThumbNailFrame::onLButtonDBLClick().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ file_exist_t()

BOOL file_exist_t ( LPCTSTR fn)

Definition at line 258 of file WinTools.cpp.

259{
260 BOOL ret = FALSE;
261 if (fn==NULL) return FALSE;
262
263#ifdef _UNICODE
264 FILE* fp = tfopen(fn, _T("rb"));
265 if (fp!=NULL) {
266 ret = TRUE;
267 fclose(fp);
268 }
269#else
270 ret = file_exist((char*)fn);
271#endif
272
273 return ret;
274}

Referenced by CNiFileTool::open_wfile(), and CNiFileTool::saveJTextfromFile().

Here is the caller graph for this function:

◆ file_size_t()

unsigned long int file_size_t ( LPCTSTR fn)

Definition at line 250 of file WinTools.cpp.

251{
252 struct _stat stbuf;
253 _tstat(fn, &stbuf);
254 return stbuf.st_size;
255}

Referenced by copyFileWithCounter().

Here is the caller graph for this function:

◆ freeFramesData()

void freeFramesData ( NiFrameData * frmdata,
int frm_num )

NiFrameData* jbxwl::makeFramesData(int frame, int jnum)

フレームデータの格納先メモリ(ジョイント数固定)を作成,初期化.
フレーム毎のジョイント数,フレーム間隔が一定

Parameters
frameフレームの数
joint_numジョイントの数
Returns
フレームデータを格納するデータ領域へのポインタ

Definition at line 788 of file NiJointsTool.cpp.

789{
790 if (frmdata==NULL || frm_num<=0) return;
791
792 for (int i=0; i<frm_num; i++) {
793 if (frmdata[i].jdat!=NULL) {
794 ::free(frmdata[i].jdat);
795 frmdata[i].jdat = NULL;
796 }
797 }
798
799 ::free(frmdata);
800 return;
801}
NiJointData * jdat

References NiFrameData::jdat.

Referenced by CBaseFrameTool::free_data(), CNiVMDTool::free_data(), and makeFramesData().

Here is the caller graph for this function:

◆ get_dir_files_rcsv_t()

tList * get_dir_files_rcsv_t ( LPCTSTR dirn)

Definition at line 370 of file WinTools.cpp.

371{
372 tList* lp = get_dir_files_t(dirn);
373 if (lp==NULL) return NULL;
374
375 tList* lt = dup_tList(lp);
376 while (lt!=NULL) {
377 tList* lc = get_dir_files_rcsv_t(mbs2ts((char*)lt->ldat.val.buf));
378 if (lc!=NULL) add_tList_end(lp, lc);
379 lt = lt->next;
380 }
381 del_tList(&lt);
382
383 return lp;
384}
tList * get_dir_files_rcsv_t(LPCTSTR dirn)
Definition WinTools.cpp:370
tList * get_dir_files_t(LPCTSTR dirn)
Definition WinTools.cpp:338

References get_dir_files_rcsv_t(), get_dir_files_t(), and mbs2ts().

Referenced by get_dir_files_rcsv_t().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ get_dir_files_t()

tList * get_dir_files_t ( LPCTSTR dirn)

Definition at line 338 of file WinTools.cpp.

339{
340 tList* lp = NULL;
341 tList* ln = NULL;
342
343 WIN32_FIND_DATA FindFileData;
344 HANDLE hFind;
345 CString dirstr = dirn;
346
347 if (dirstr.Right(1)!="\\") dirstr += _T("\\*");
348 hFind = FindFirstFile((LPCTSTR)dirstr, &FindFileData);
349 if (hFind!=INVALID_HANDLE_VALUE) {
350 Buffer tmp;
351 do {
352 char* fn = ts2mbs(FindFileData.cFileName);
353 if (strcmp(".", fn) && strcmp("..", fn)) {
354 tmp = ts2Buffer(dirn);
355 if (tmp.buf[tmp.vldsz-1]!='\\') cat_s2Buffer("\\", &tmp);
356 cat_ts2Buffer(FindFileData.cFileName, &tmp);
357 ln = add_tList_node_str(ln, NULL, tmp.buf);
358 if (lp==NULL) lp = ln;
359 free_Buffer(&tmp);
360 }
361 ::free(fn);
362 } while (FindNextFile(hFind, &FindFileData));
363
364 FindClose(hFind);
365 }
366 return lp;
367}
int cat_ts2Buffer(LPCTSTR str, Buffer *buf)
Definition WinTools.cpp:161
Buffer ts2Buffer(LPCTSTR str, int size=-1)
Definition WinTools.cpp:56

References cat_ts2Buffer(), ts2Buffer(), and ts2mbs().

Referenced by get_dir_files_rcsv_t(), and DLLModuleTBL::get_dir_module().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ get_file_name_t()

CString get_file_name_t ( LPCTSTR str)

Definition at line 277 of file WinTools.cpp.

278{
279 CString buf = _T("");
280
281#ifdef _UNICODE
282 char* mbstr = ts2mbs(str);
283 char* fn = get_file_name(mbstr);
284 buf = mbs2ts(fn);
285 ::free(mbstr);
286#else
287 char* fn = get_file_name((char*)str);
288 buf = (LPTSTR)fn;
289#endif
290
291 return buf;
292}

References mbs2ts(), and ts2mbs().

Referenced by ExecDocFrmView(), and CRwGRDoc::ReadDataFile().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ get_tstr_param_tList()

CString get_tstr_param_tList ( tList * lt,
char * key,
LPCTSTR dflt )

Definition at line 413 of file WinTools.cpp.

414{
415 Buffer buf = buffer_key_tList(lt, key, 1);
416 if (buf.buf!=NULL) {
417 CString ret = mbs2ts((char*)buf.buf);
418 free_Buffer(&buf);
419 return ret;
420 }
421 return (CString)dflt;
422}

References mbs2ts().

Here is the call graph for this function:

◆ GetCurrentFolder()

CString GetCurrentFolder ( void )

Definition at line 539 of file WinTools.cpp.

540{
541#ifdef _UNICODE
542 TCHAR dirn[LMESG];
543 GetCurrentDirectory(LMESG, dirn);
544
545#else
546 char dirn[LMESG];
547 GetCurrentDirectory(LMESG, dirn);
548
549#endif
550
551 CString folder = dirn;
552 return folder;
553}

◆ GetCurrentUserHomeFolder()

CString GetCurrentUserHomeFolder ( void )

Definition at line 460 of file WinTools.cpp.

461{
462 HANDLE token;
463 DWORD size = (DWORD)LMESG;
464 TCHAR dirn[LMESG];
465 CString ret = _T("");
466
467 OpenProcessToken(GetCurrentProcess(), TOKEN_QUERY, &token);
468 BOOL rslt = GetUserProfileDirectory(token, dirn, &size);
469
470 if (rslt && size<=LMESG) ret = dirn;
471 return ret;
472}

Referenced by MakeWorkingFolderPath().

Here is the caller graph for this function:

◆ GetDefaultUserHomeFolder()

CString GetDefaultUserHomeFolder ( void )

Definition at line 475 of file WinTools.cpp.

476{
477 DWORD size = (DWORD)LMESG;
478 TCHAR dirn[LMESG];
479 CString ret = _T("");
480
481 BOOL rslt = GetDefaultUserProfileDirectory(dirn, &size);
482 if (rslt && size<=LMESG) ret = dirn;
483 return ret;
484}

◆ GetMenu_byID()

CMenu * GetMenu_byID ( CMenu * pMenu,
UINT id )

メニューでリソースID id を持つものを探す.

Definition at line 18 of file MFCTool.cpp.

19{
20 if (pMenu==NULL) return NULL;
21
22 UINT n = pMenu->GetMenuItemCount();
23 for (UINT i=0; i<n; i++){
24 if (pMenu->GetMenuItemID(i)==id) return pMenu;
25
26 CMenu* pSub = GetMenu_byID(pMenu->GetSubMenu(i), id);
27 if (pSub!=NULL) return pSub;
28 }
29 return NULL;
30}
CMenu * GetMenu_byID(CMenu *pMenu, UINT id)
Definition MFCTool.cpp:18

References GetMenu_byID().

Referenced by GetMenu_byID().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GetMenu_byName()

CMenu * GetMenu_byName ( CMenu * pMenu,
LPCTSTR name )

Definition at line 46 of file MFCTool.cpp.

47{
48 if (pMenu==NULL) return NULL;
49 CString str;
50
51 UINT n = pMenu->GetMenuItemCount();
52 for (UINT i=0; i<n; i++){
53 pMenu->GetMenuString(i, str, MF_BYPOSITION);
54 if (str==(CString)name) return pMenu->GetSubMenu(i);
55
56 CMenu* pSub = GetMenu_byName(pMenu->GetSubMenu(i), name);
57 if (pSub!=NULL) return pSub;
58 }
59 return NULL;
60}
CMenu * GetMenu_byName(CMenu *pMenu, LPCTSTR name)
Definition MFCTool.cpp:46

References GetMenu_byName().

Referenced by GetMenu_byName(), and GetMenu_byStringID().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GetMenu_byStringID()

CMenu * GetMenu_byStringID ( CMenu * pMenu,
UINT id )

Definition at line 34 of file MFCTool.cpp.

35{
36 if (pMenu==NULL) return NULL;
37
38 CString str = LoadString_byID(id);
39 if (str=="" || str.IsEmpty()) return NULL;
40
41 return GetMenu_byName(pMenu, str);
42}
CString LoadString_byID(UINT id)
Definition WinTools.h:174

References GetMenu_byName(), and LoadString_byID().

Here is the call graph for this function:

◆ GetMouseCursorType()

TCHAR * GetMouseCursorType ( void )

Definition at line 749 of file WinTools.cpp.

750{
751 CURSORINFO ci;
752
753 ci.cbSize = sizeof(CURSORINFO);
754 GetCursorInfo(&ci);
755
756 if (ci.flags!=0) {
757 TCHAR** table = MouseCursolTable;
758 while (*table!=NULL) {
759 if (ci.hCursor==LoadCursor(NULL, (LPTSTR)*table)) return *table;
760 table++;
761 }
762 return NULL;
763 }
764
765 return NULL;
766}
static TCHAR * MouseCursolTable[]
Definition WinTools.cpp:724

References MouseCursolTable.

Referenced by CExTextView::GetWindowReSize(), and CExView::GetWindowReSize().

Here is the caller graph for this function:

◆ GetMsecondsLapTimer()

unsigned short GetMsecondsLapTimer ( unsigned short pm,
unsigned short * nt = NULL )

unsigned short jbxwl::GetMsecondsLapTimer(unsigned short pm, unsigned short* nt)

ラップタイムを返す.

unsigned short ctime;
frame_timer += GetMsecondsLapTimer(lap_timer, &ctime);
lap_timer = ctime;
unsigned short GetMsecondsLapTimer(unsigned short pm, unsigned short *nt=NULL)
Definition WinTools.cpp:799

Definition at line 799 of file WinTools.cpp.

800{
801 SYSTEMTIME tm;
802 GetLocalTime(&tm);
803
804 unsigned short nm = tm.wSecond*(unsigned short)1000 + tm.wMilliseconds;
805 unsigned short ret;
806 if (pm>nm) ret = nm + ((unsigned short)60000 - pm);
807 else ret = nm - pm;
808
809 if (nt!=NULL) *nt = nm;
810 return ret;
811}

Referenced by CNiFileTool::nextFrame().

Here is the caller graph for this function:

◆ GetMsecondsTimer()

unsigned short GetMsecondsTimer ( void )

unsigned short jbxwl::GetMsecondsTimer()

1分計.0-59999ms を返す.

Definition at line 778 of file WinTools.cpp.

779{
780 SYSTEMTIME tm;
781 GetLocalTime(&tm);
782
783 unsigned short nm = tm.wSecond*(unsigned short)1000 + tm.wMilliseconds;
784 return nm;
785}

Referenced by CNiFileTool::startFrame(), and CNiFileTool::writeJTextData().

Here is the caller graph for this function:

◆ GetProgramFolder()

CString GetProgramFolder ( void )

Definition at line 508 of file WinTools.cpp.

509{
510 char* path = GetProgramFolderA();
511
512 CString ret = mbs2ts(path);
513 ::free(path);
514
515 return ret;
516}
char * GetProgramFolderA(void)
Definition WinTools.cpp:519

References GetProgramFolderA(), and mbs2ts().

Here is the call graph for this function:

◆ GetProgramFolderA()

char * GetProgramFolderA ( void )

Definition at line 519 of file WinTools.cpp.

520{
521 TCHAR dirn[LMESG];
522
523 GetModuleFileName(NULL, dirn, (DWORD)LMESG); // エラーは敢えて無視
524 //
525 char* path = ts2mbs(dirn);
526 int len = (int)strlen(path);
527
528 for (int i=1; i<len; i++) {
529 if (path[len-i-1]=='\\') {
530 path[len-i] = '\0';
531 break;
532 }
533 }
534
535 return path;
536}

References ts2mbs().

Referenced by GetProgramFolder().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ getQAvBVHOffset()

vector getQAvBVHOffset ( int joint)

Definition at line 341 of file NiBVHName.cpp.

342{
343 vector vect;
344 memset(&vect, 0, sizeof(vect));
345
346 if (joint<0) return vect;
347
348 vect.x = _QAV_Offset[joint*3];
349 vect.y = _QAV_Offset[joint*3+1];
350 vect.z = _QAV_Offset[joint*3+2];
351
352 return vect;
353}
double _QAV_Offset[]

References _QAV_Offset.

Referenced by CNiFileTool::writeBVHFile().

Here is the caller graph for this function:

◆ getResourceLocale()

CString getResourceLocale ( void )

Definition at line 444 of file WinTools.cpp.

445{
446 CString locale = LoadString_byID(IDS_STR_LOCALE);
447 return locale;
448}
#define IDS_STR_LOCALE
Definition resource.h:125

References IDS_STR_LOCALE, and LoadString_byID().

Here is the call graph for this function:

◆ InitialDocView()

BOOL InitialDocView ( CExFrame * pfrm,
LPCTSTR fname )

BOOL jbxwl::InitialDocView(CExFrame* pfrm, LPCTSTR fname)

Document, View クラスの前処理.
ファイルをオープンし,表示の準備をする.

Definition at line 73 of file ExClass.cpp.

74{
75 BOOL rslt;
76
77 // Document クラスの前処理
78 if (fname==NULL) {
79 rslt = pfrm->pDoc->OnNewDocument();
80 }
81 else {
82 rslt = pfrm->pDoc->OnOpenDocument(fname);
83 }
84 if (!rslt) return FALSE;
85
86 // View クラスの前処理
87 pfrm->pView->OnInitialUpdate();
88 if (!pfrm->pView->hasViewData) return FALSE;
89 return TRUE;
90}
virtual BOOL OnNewDocument()
virtual BOOL OnOpenDocument(LPCTSTR lpszPathName)
virtual void OnInitialUpdate()
Definition ExView.cpp:365

References CExView::hasViewData, CExView::OnInitialUpdate(), CExDocument::OnNewDocument(), CExDocument::OnOpenDocument(), CExFrame::pDoc, and CExFrame::pView.

Referenced by ExecDocFrmView().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ InputFloatNumDLG()

BOOL InputFloatNumDLG ( LPCTSTR title,
double * val )

Definition at line 313 of file InputNumDLG.cpp.

314{
315 CInputFloatNumDLG* inpdlg = new CInputFloatNumDLG(title, *val);
316 if (inpdlg->DoModal()!=IDOK) {
317 delete(inpdlg);
318 return FALSE;
319 }
320
321 *val = inpdlg->val;
322 delete(inpdlg);
323 return TRUE;
324}

References CInputFloatNumDLG::val.

◆ InputMultiFloatNumDLG()

BOOL InputMultiFloatNumDLG ( LPCTSTR t0,
double * v0,
LPCTSTR t1 = NULL,
double * v1 = NULL,
LPCTSTR t2 = NULL,
double * v2 = NULL,
LPCTSTR t3 = NULL,
double * v3 = NULL,
LPCTSTR t4 = NULL,
double * v4 = NULL,
LPCTSTR t5 = NULL,
double * v5 = NULL )

Definition at line 328 of file InputNumDLG.cpp.

330{
331 CString ttl[6];
332 double val[6];
333
334 for (int i=0; i<6; i++) {
335 ttl[i] = _T("");
336 val[i] = 0.0;
337 }
338
339 if (t0!=NULL && v0!=NULL) {
340 ttl[0] = t0;
341 val[0] = *v0;
342 }
343 if (t1!=NULL && v1!=NULL) {
344 ttl[1] = t1;
345 val[1] = *v1;
346 }
347 if (t2!=NULL && v2!=NULL) {
348 ttl[2] = t2;
349 val[2] = *v2;
350 }
351 if (t3!=NULL && v3!=NULL) {
352 ttl[3] = t3;
353 val[3] = *v3;
354 }
355 if (t4!=NULL && v4!=NULL) {
356 ttl[4] = t4;
357 val[4] = *v4;
358 }
359 if (t5!=NULL && v5!=NULL) {
360 ttl[5] = t5;
361 val[5] = *v5;
362 }
363
364 CInputMultiFloatNumDLG* inpdlg = new CInputMultiFloatNumDLG((LPCTSTR)ttl[0], val[0], (LPCTSTR)ttl[1], val[1],
365 (LPCTSTR)ttl[2], val[2], (LPCTSTR)ttl[3], val[3],
366 (LPCTSTR)ttl[4], val[4], (LPCTSTR)ttl[5], val[5]);
367 if (inpdlg->DoModal()!=IDOK) {
368 delete(inpdlg);
369 return FALSE;
370 }
371
372 if (v0!=NULL) *v0 = inpdlg->val[0];
373 if (v1!=NULL) *v1 = inpdlg->val[1];
374 if (v2!=NULL) *v2 = inpdlg->val[2];
375 if (v3!=NULL) *v3 = inpdlg->val[3];
376 if (v4!=NULL) *v4 = inpdlg->val[4];
377 if (v5!=NULL) *v5 = inpdlg->val[5];
378
379 delete(inpdlg);
380 return TRUE;
381}

References CInputMultiFloatNumDLG::val.

◆ InputNumDLG()

BOOL InputNumDLG ( LPCTSTR title,
int * val )

Definition at line 298 of file InputNumDLG.cpp.

299{
300 CInputNumDLG* inpdlg = new CInputNumDLG(title, *val);
301 if (inpdlg->DoModal()!=IDOK) {
302 delete(inpdlg);
303 return FALSE;
304 }
305
306 *val = inpdlg->val;
307 delete(inpdlg);
308 return TRUE;
309}

References CInputNumDLG::val.

◆ JointName2NiSDK()

int JointName2NiSDK ( char * jname,
NiSDK_Lib lib )

Definition at line 459 of file NiJointsTool.cpp.

460{
461 int ret = -1;
462
463 int j;
464 for (j=0; j<NI_TOTAL_JOINT_NUM; j++) {
465 if (!strcasecmp(jname, (char*)_NiJointName[j].c_str())) break;
466 }
467
468 if (j<NI_TOTAL_JOINT_NUM) {
469 ret = Ni2SDKJointNum(j, lib);
470 }
471 else if (j==NI_TOTAL_JOINT_NUM) {
472 //DEBUG_INFO("JointName2NiSDK: Unknown Joint Name = %s\n", jname);
473 }
474
475 return ret;
476}
static std::string _NiJointName[]
#define NI_TOTAL_JOINT_NUM
#define Ni2SDKJointNum(j, l)

References _NiJointName, Ni2SDKJointNum, and NI_TOTAL_JOINT_NUM.

◆ LoadString_byID()

CString LoadString_byID ( UINT id)
inline

Definition at line 174 of file WinTools.h.

175{
176 CString mesg;
177 mesg.LoadString(id);
178 return mesg;
179}

Referenced by GetMenu_byStringID(), getResourceLocale(), and setResourceLocale().

Here is the caller graph for this function:

◆ make_file_path_t()

CString make_file_path_t ( LPCTSTR str)

Definition at line 295 of file WinTools.cpp.

296{
297 CString buf = _T("");
298
299#ifdef _UNICODE
300 char* mbstr = ts2mbs(str);
301 //char* pn = make_file_path(mbstr);
302 char* pn = get_file_path(mbstr);
303 buf = mbs2ts(pn);
304 ::free(mbstr);
305 ::free(pn);
306#else
307 //char* pn = make_file_path((char*)str);
308 char* pn = get_file_path((char*)str);
309 buf = (LPTSTR)pn;
310 ::free(pn);
311#endif
312
313 return buf;
314}

References mbs2ts(), and ts2mbs().

Here is the call graph for this function:

◆ makeBVH_NiHierarchy()

tTree * makeBVH_NiHierarchy ( void )

Definition at line 247 of file NiBVHName.cpp.

248{
249 tTree* root = NULL;
250 tTree* chst = NULL;
251 tTree* head = NULL;
252 tTree* tree = NULL;
253
254 root = add_tTree_node_bystr(NULL, BVH_NODE_ROOT, 6, "PELVIS", "PXPYPZRYRXRZ", NULL, 0);
255
256 tree = add_tTree_node_bystr(root, BVH_NODE_JOINT, 3, "WAIST", "RYRXRZ", NULL, 0);
257 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "TORSO", "RYRXRZ", NULL, 0);
258 chst = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "CHEST", "RYRXRZ", NULL, 0);
259
260 tree = add_tTree_node_bystr(chst, BVH_NODE_JOINT, 3, "NECK", "RYRXRZ", NULL, 0);
261 head = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "HEAD", "RYRXRZ", NULL, 0);
262
263 tree = add_tTree_node_bystr(head, BVH_NODE_JOINT, 3, "SKULL", "RYRXRZ", NULL, 0);
264 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
265
266 tree = add_tTree_node_bystr(head, BVH_NODE_JOINT, 3, "L_EYE", "RYRXRZ", NULL, 0);
267 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
268 tree = add_tTree_node_bystr(head, BVH_NODE_JOINT, 3, "R_EYE", "RYRXRZ", NULL, 0);
269 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
270
271 tree = add_tTree_node_bystr(chst, BVH_NODE_JOINT, 3, "L_BUST", "RYRXRZ", NULL, 0);
272 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
273 tree = add_tTree_node_bystr(chst, BVH_NODE_JOINT, 3, "R_BUST", "RYRXRZ", NULL, 0);
274 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
275
276 tree = add_tTree_node_bystr(chst, BVH_NODE_JOINT, 3, "L_COLLAR", "RYRXRZ", NULL, 0);
277 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "L_SHLDR", "RYRXRZ", NULL, 0);
278 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "L_ELBOW", "RYRXRZ", NULL, 0);
279 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "L_WRIST", "RYRXRZ", NULL, 0);
280 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "L_HAND", "RYRXRZ", NULL, 0);
281 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "L_FNGRTIP","RYRXRZ", NULL, 0);
282 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
283
284 tree = add_tTree_node_bystr(chst, BVH_NODE_JOINT, 3, "R_COLLAR", "RYRXRZ", NULL, 0);
285 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "R_SHLDR", "RYRXRZ", NULL, 0);
286 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "R_ELBOW", "RYRXRZ", NULL, 0);
287 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "R_WRIST", "RYRXRZ", NULL, 0);
288 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "R_HAND", "RYRXRZ", NULL, 0);
289 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "R_FNGRTIP","RYRXRZ", NULL, 0);
290 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
291
292 tree = add_tTree_node_bystr(root, BVH_NODE_JOINT, 3, "L_HIP", "RYRXRZ", NULL, 0);
293 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "L_KNEE", "RYRXRZ", NULL, 0);
294 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "L_ANKLE", "RYRXRZ", NULL, 0);
295 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "L_FOOT", "RYRXRZ", NULL, 0);
296 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "L_TOE", "RYRXRZ", NULL, 0);
297 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
298
299 tree = add_tTree_node_bystr(root, BVH_NODE_JOINT, 3, "R_HIP", "RYRXRZ", NULL, 0);
300 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "R_KNEE", "RYRXRZ", NULL, 0);
301 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "R_ANKLE", "RYRXRZ", NULL, 0);
302 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "R_FOOT", "RYRXRZ", NULL, 0);
303 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "R_TOE", "RYRXRZ", NULL, 0);
304 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
305
306 return root;
307}

Referenced by CNiFileTool::writeBVHFile().

Here is the caller graph for this function:

◆ makeBVH_QAvHierarchy()

tTree * makeBVH_QAvHierarchy ( void )

Definition at line 205 of file NiBVHName.cpp.

206{
207 tTree* root = NULL;
208 tTree* chst = NULL;
209 tTree* tree = NULL;
210
211 root = add_tTree_node_bystr(NULL, BVH_NODE_ROOT, 6, "hip", "PXPYPZRYRXRZ", NULL, 0);
212
213 tree = add_tTree_node_bystr(root, BVH_NODE_JOINT, 3, "abdomen", "RYRXRZ", NULL, 0);
214 chst = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "chest", "RYRXRZ", NULL, 0);
215
216 tree = add_tTree_node_bystr(chst, BVH_NODE_JOINT, 3, "neck", "RYRXRZ", NULL, 0);
217 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "head", "RYRXRZ", NULL, 0);
218 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
219
220 tree = add_tTree_node_bystr(chst, BVH_NODE_JOINT, 3, "lCollar", "RYRXRZ", NULL, 0);
221 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "lShldr", "RYRXRZ", NULL, 0);
222 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "lForeArm", "RYRXRZ", NULL, 0);
223 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "lHand", "RYRXRZ", NULL, 0);
224 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
225
226 tree = add_tTree_node_bystr(chst, BVH_NODE_JOINT, 3, "rCollar", "RYRXRZ", NULL, 0);
227 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "rShldr", "RYRXRZ", NULL, 0);
228 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "rForeArm", "RYRXRZ", NULL, 0);
229 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "rHand", "RYRXRZ", NULL, 0);
230 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
231
232 tree = add_tTree_node_bystr(root, BVH_NODE_JOINT, 3, "lThigh", "RYRXRZ", NULL, 0);
233 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "lShin", "RYRXRZ", NULL, 0);
234 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "lFoot", "RYRXRZ", NULL, 0);
235 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
236
237 tree = add_tTree_node_bystr(root, BVH_NODE_JOINT, 3, "rThigh", "RYRXRZ", NULL, 0);
238 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "rShin", "RYRXRZ", NULL, 0);
239 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "rFoot", "RYRXRZ", NULL, 0);
240 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
241
242 return root;
243}

Referenced by CNiFileTool::writeBVHFile().

Here is the caller graph for this function:

◆ makeBVH_SLHierarchy()

tTree * makeBVH_SLHierarchy ( void )

Definition at line 150 of file NiBVHName.cpp.

151{
152 tTree* root = NULL;
153 tTree* chst = NULL;
154 tTree* head = NULL;
155 tTree* tree = NULL;
156
157 root = add_tTree_node_bystr(NULL, BVH_NODE_ROOT, 6, "hip", "PXPYPZRYRXRZ", NULL, 0);
158
159 tree = add_tTree_node_bystr(root, BVH_NODE_JOINT, 3, "abdomen", "RYRXRZ", NULL, 0);
160 chst = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "chest", "RYRXRZ", NULL, 0);
161
162 tree = add_tTree_node_bystr(chst, BVH_NODE_JOINT, 3, "neck", "RYRXRZ", NULL, 0);
163 head = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "head", "RYRXRZ", NULL, 0);
164
165 tree = add_tTree_node_bystr(head, BVH_NODE_JOINT, 3, "mSkull", "RYRXRZ", NULL, 0);
166 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
167
168 tree = add_tTree_node_bystr(head, BVH_NODE_JOINT, 3, "mEyeLeft", "RYRXRZ", NULL, 0);
169 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
170
171 tree = add_tTree_node_bystr(head, BVH_NODE_JOINT, 3, "mEyeRight", "RYRXRZ", NULL, 0);
172 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
173
174 tree = add_tTree_node_bystr(chst, BVH_NODE_JOINT, 3, "lCollar", "RYRXRZ", NULL, 0);
175 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "lShldr", "RYRXRZ", NULL, 0);
176 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "lForeArm", "RYRXRZ", NULL, 0);
177 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "lHand", "RYRXRZ", NULL, 0);
178 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
179
180 tree = add_tTree_node_bystr(chst, BVH_NODE_JOINT, 3, "rCollar", "RYRXRZ", NULL, 0);
181 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "rShldr", "RYRXRZ", NULL, 0);
182 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "rForeArm", "RYRXRZ", NULL, 0);
183 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "rHand", "RYRXRZ", NULL, 0);
184 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
185
186 tree = add_tTree_node_bystr(root, BVH_NODE_JOINT, 3, "lThigh", "RYRXRZ", NULL, 0);
187 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "lShin", "RYRXRZ", NULL, 0);
188 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "mAnkleLeft", "RYRXRZ", NULL, 0);
189 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "lFoot", "RYRXRZ", NULL, 0);
190 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "mToeLeft", "RYRXRZ", NULL, 0);
191 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
192
193 tree = add_tTree_node_bystr(root, BVH_NODE_JOINT, 3, "rThigh", "RYRXRZ", NULL, 0);
194 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "rShin", "RYRXRZ", NULL, 0);
195 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "mAnkleRight","RYRXRZ", NULL, 0);
196 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "rFoot", "RYRXRZ", NULL, 0);
197 tree = add_tTree_node_bystr(tree, BVH_NODE_JOINT, 3, "mToeRight", "RYRXRZ", NULL, 0);
198 tree = add_tTree_node_bystr(tree, BVH_NODE_END, 0, "Site", NULL, NULL, 0);
199
200 return root;
201}

Referenced by CNiFileTool::writeBVHFile().

Here is the caller graph for this function:

◆ makeFramesData()

NiFrameData * makeFramesData ( int frame,
int jnum,
int * frame_num )

NiFrameData* jbxwl::makeVarFrameData(int frame, int* joint_num, int* frame_num)

フレームデータの格納先メモリ(フレーム毎のジョイント数とフレーム間隔が可変)を作成,初期化.

Parameters
frameフレームの数
joint_numジョイント数
frame_numフレームの番号(時間)の入った配列.NULLならフレーム間隔一定.
Returns
フレームデータを格納するデータ領域へのポインタ

Definition at line 718 of file NiJointsTool.cpp.

719{
720 if (jnum<0) return NULL; // 0 is OK for dummy
721
722 NiFrameData* frmdata = (NiFrameData*)malloc(frame*sizeof(NiFrameData));
723 if (frmdata==NULL) return NULL;
724 memset(frmdata, 0, frame*sizeof(NiFrameData));
725
726 for (int i=0; i<frame; i++) {
727 if (frame_num!=NULL) {
728 frmdata[i].frmn = frame_num[i];
729 frmdata[i].msec = frame_num[i]; // デフォルトはフレーム間 1ms
730 }
731 else {
732 frmdata[i].frmn = i;
733 frmdata[i].msec = i;
734 }
735 frmdata[i].jnum = jnum;
736
737 if (frmdata[i].jnum>0) {
738 frmdata[i].jdat = (NiJointData*)malloc(frmdata[i].jnum*sizeof(NiJointData));
739 if (frmdata[i].jdat==NULL) {
740 freeFramesData(frmdata, frame);
741 return NULL;
742 }
743 //
744 for (int j=0; j<frmdata[i].jnum; j++) {
745 frmdata[i].jdat[j].joint = -1;
746 frmdata[i].jdat[j].index = -1;
747 frmdata[i].jdat[j].vect.init(-1.0);
748 frmdata[i].jdat[j].quat.init(-1.0);
749 }
750 }
751 else {
752 frmdata[i].jdat = NULL; // for dummy
753 }
754 }
755
756 return frmdata;
757}
void freeFramesData(NiFrameData *frmdata, int frm_num)
Quaternion< double > quat
Vector< double > vect

References freeFramesData(), NiFrameData::frmn, NiJointData::index, NiFrameData::jdat, NiFrameData::jnum, NiJointData::joint, NiFrameData::msec, NiJointData::quat, and NiJointData::vect.

Referenced by CNiVMDTool::convert2FrameData(), CNiVMDTool::getFramesData(), CNiBVHTool::readFile(), and CNiJTextTool::readFile().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ MakeWorkingFolderPath()

CString MakeWorkingFolderPath ( LPCTSTR fnm,
BOOL local,
LPCTSTR dir = NULL,
BOOL make = FALSE )

Definition at line 487 of file WinTools.cpp.

488{
489 CString path = GetCurrentUserHomeFolder();
490
491 if (local) path += _T("\\AppData\\Local");
492 else path += _T("\\AppData\\Roaming");
493
494 if (dir!=NULL) path += dir;
495 else path += _T("\\");
496
497 if (make) {
498 char* mbstr = ts2mbs(path);
499 MakeSureDirectoryPathExists(mbstr);
500 ::free(mbstr);
501 }
502 if (fnm!=NULL) path += fnm;
503
504 return path;
505}
CString GetCurrentUserHomeFolder(void)
Definition WinTools.cpp:460

References GetCurrentUserHomeFolder(), and ts2mbs().

Here is the call graph for this function:

◆ mbs2ts()

CString mbs2ts ( char * str)

Definition at line 79 of file WinTools.cpp.

80{
81 CString buf = _T("");
82 if (str==NULL) return buf;
83
84#ifdef _UNICODE
85 //setlocale(LC_ALL, ".UTF8");
86 TCHAR tchar[SBUFSZ];
87 size_t len = 0;
88 size_t size = strlen(str);
89 int err = -1;
90
91 if (size + 1 > SBUFSZ) {
92 TCHAR tchar_recv[RECVBUFSZ];
93 if (size + 1 > RECVBUFSZ) {
94 size_t ptchar_sz = (size + 1) * sizeof(TCHAR);
95 TCHAR* ptchar = (TCHAR*)malloc(ptchar_sz);
96 err = mbstowcs_s(&len, ptchar, ptchar_sz, str, size);
97 if (err == 0) buf = ptchar;
98 ::free(ptchar);
99 }
100 else {
101 err = mbstowcs_s(&len, tchar_recv, RECVBUFSZ, str, size);
102 if (err == 0) buf = tchar_recv;
103 }
104 }
105 else {
106 err = mbstowcs_s(&len, tchar, SBUFSZ, str, size);
107 if (err == 0) buf = tchar;
108 }
109#else
110 buf = (LPTSTR)str;
111#endif
112
113 return buf;
114}

Referenced by cut_file_extension_t(), CWinSharedMem::CWinSharedMem(), get_dir_files_rcsv_t(), DLLModuleTBL::get_dir_module(), get_file_name_t(), DLLModule::get_module_info(), get_tstr_param_tList(), CLogWndView::getCopyData(), GetProgramFolder(), make_file_path_t(), CLogWndView::OnDraw(), CRwGRDoc::ReadDataFile(), CProgressBarDLG::SetTitle(), CProgressTextDLG::SetTitle(), CProgressBarDLG::Start(), and CProgressTextDLG::Start().

Here is the caller graph for this function:

◆ MessageBoxDLG() [1/8]

CMessageBoxDLG * MessageBoxDLG ( int ttl,
int msg,
CWnd * wnd = NULL )

Definition at line 142 of file MessageBoxDLG.cpp.

143{
144 CString mesg, noti;
145 noti.LoadString(ttl);
146 mesg.LoadString(msg);
147
148 CMessageBoxDLG* mesgbox = new CMessageBoxDLG(noti, wnd);
149 if (mesgbox!=NULL) mesgbox->Display(mesg);
150 return mesgbox;
151}
void Display(LPCTSTR mesg=NULL)

References CMessageBoxDLG::Display().

Referenced by CLogWndFrame::OnLogSave(), CNiFileTool::open_wfile(), and CNiFileTool::saveJTextfromFile().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ MessageBoxDLG() [2/8]

int MessageBoxDLG ( int ttl,
int msg,
UINT type,
CWnd * wnd = NULL )

Definition at line 193 of file MessageBoxDLG.cpp.

194{
195 CString mesg, noti;
196 noti.LoadString(ttl);
197 mesg.LoadString(msg);
198
199 int ret;
200 if (wnd!=NULL) ret = ::MessageDLG(noti, mesg, type, wnd->m_hWnd);
201 else ret = ::MessageDLG(noti, mesg, type, (HWND)NULL);
202 return ret;
203}
int MessageDLG(LPCTSTR ttl, LPCTSTR msg, UINT type, HWND hWnd)
Definition WinTools.cpp:576

References MessageDLG().

Here is the call graph for this function:

◆ MessageBoxDLG() [3/8]

CMessageBoxDLG * MessageBoxDLG ( int ttl,
LPCTSTR msg,
CWnd * wnd = NULL )

Definition at line 167 of file MessageBoxDLG.cpp.

168{
169 CString noti;
170 noti.LoadString(ttl);
171
172 CMessageBoxDLG* mesgbox = new CMessageBoxDLG(noti, wnd);
173 if (mesgbox!=NULL) mesgbox->Display(msg);
174 return mesgbox;
175}

References CMessageBoxDLG::Display().

Here is the call graph for this function:

◆ MessageBoxDLG() [4/8]

int MessageBoxDLG ( int ttl,
LPCTSTR msg,
UINT type,
CWnd * wnd = NULL )

Definition at line 220 of file MessageBoxDLG.cpp.

221{
222 CString noti;
223 noti.LoadString(ttl);
224
225 int ret;
226 if (wnd!=NULL) ret = ::MessageDLG(noti, msg, type, wnd->m_hWnd);
227 else ret = ::MessageDLG(noti, msg, type, (HWND)NULL);
228 return ret;
229}

References MessageDLG().

Here is the call graph for this function:

◆ MessageBoxDLG() [5/8]

CMessageBoxDLG * MessageBoxDLG ( LPCTSTR ttl,
int msg,
CWnd * wnd = NULL )

Definition at line 155 of file MessageBoxDLG.cpp.

156{
157 CString mesg;
158 mesg.LoadString(msg);
159
160 CMessageBoxDLG* mesgbox = new CMessageBoxDLG(ttl, wnd);
161 if (mesgbox!=NULL) mesgbox->Display(mesg);
162 return mesgbox;
163}

References CMessageBoxDLG::Display().

Here is the call graph for this function:

◆ MessageBoxDLG() [6/8]

int MessageBoxDLG ( LPCTSTR ttl,
int msg,
UINT type,
CWnd * wnd = NULL )

Definition at line 207 of file MessageBoxDLG.cpp.

208{
209 CString mesg;
210 mesg.LoadString(msg);
211
212 int ret;
213 if (wnd!=NULL) ret = ::MessageDLG(ttl, mesg, type, wnd->m_hWnd);
214 else ret = ::MessageDLG(ttl, mesg, type, (HWND)NULL);
215 return ret;
216}

References MessageDLG().

Here is the call graph for this function:

◆ MessageBoxDLG() [7/8]

CMessageBoxDLG * MessageBoxDLG ( LPCTSTR ttl,
LPCTSTR msg,
CWnd * wnd = NULL )

Definition at line 179 of file MessageBoxDLG.cpp.

180{
181 CMessageBoxDLG* mesgbox = new CMessageBoxDLG(ttl, wnd);
182 if (mesgbox!=NULL) mesgbox->Display(msg);
183 return mesgbox;
184}

References CMessageBoxDLG::Display().

Here is the call graph for this function:

◆ MessageBoxDLG() [8/8]

int MessageBoxDLG ( LPCTSTR ttl,
LPCTSTR msg,
UINT type,
CWnd * wnd = NULL )

Definition at line 233 of file MessageBoxDLG.cpp.

234{
235 int ret;
236 if (wnd!=NULL) ret = ::MessageDLG(ttl, msg, type, wnd->m_hWnd);
237 else ret = ::MessageDLG(ttl, msg, type, (HWND)NULL);
238 return ret;
239}

References MessageDLG().

Here is the call graph for this function:

◆ MessageDLG()

int MessageDLG ( LPCTSTR ttl,
LPCTSTR msg,
UINT type,
HWND hWnd )

Definition at line 576 of file WinTools.cpp.

577{
578 int ret = ::MessageBox(hWnd, msg, ttl, type);
579 return ret;
580}

Referenced by MessageBoxDLG(), MessageBoxDLG(), MessageBoxDLG(), and MessageBoxDLG().

Here is the caller graph for this function:

◆ Ni2SDKPosJointNum()

int Ni2SDKPosJointNum ( int joint,
NiSDK_Lib lib )

Definition at line 342 of file NiJointsTool.cpp.

343{
344 int ret = -1;
345
346 if (lib==NiSDK_OpenNI2) {
347 ret = _Ni2OpenNI2PosJointNum[j];
348 }
349 else if (lib==NiSDK_OpenNI) {
350 ret = _Ni2OpenNIPosJointNum[j];
351 }
352 else if (lib==NiSDK_Kinect) {
353 ret = _Ni2KinectPosJointNum[j];
354 }
355 else if (lib==NiSDK_None) {
356 //ret = _Ni2ValidPosJointNum[j];
357 ret = j;
358 }
359
360 return ret;
361}
static int _Ni2OpenNIPosJointNum[]
static int _Ni2OpenNI2PosJointNum[]
static int _Ni2KinectPosJointNum[]

References _Ni2KinectPosJointNum, _Ni2OpenNI2PosJointNum, _Ni2OpenNIPosJointNum, NiSDK_Kinect, NiSDK_None, NiSDK_OpenNI, and NiSDK_OpenNI2.

Referenced by CNiJoints::copyJoints2NiJoints().

Here is the caller graph for this function:

◆ Ni2SDKRotJointNum()

int Ni2SDKRotJointNum ( int joint,
NiSDK_Lib lib )

Definition at line 419 of file NiJointsTool.cpp.

420{
421 int ret = -1;
422
423 if (lib==NiSDK_OpenNI2) {
424 ret = _Ni2OpenNI2RotJointNum[j];
425 }
426 else if (lib==NiSDK_OpenNI) {
427 ret = _Ni2OpenNIRotJointNum[j];
428 }
429 else if (lib==NiSDK_Kinect) {
430 ret = _Ni2KinectRotJointNum[j];
431 }
432 else if (lib==NiSDK_None) {
433 ret = _Ni2RotJointNum[j];
434 }
435
436 return ret;
437}
static int _Ni2OpenNI2RotJointNum[]
static int _Ni2KinectRotJointNum[]
static int _Ni2RotJointNum[]
static int _Ni2OpenNIRotJointNum[]

References _Ni2KinectRotJointNum, _Ni2OpenNI2RotJointNum, _Ni2OpenNIRotJointNum, _Ni2RotJointNum, NiSDK_Kinect, NiSDK_None, NiSDK_OpenNI, and NiSDK_OpenNI2.

Referenced by CNiJoints::copyJoints2NiJoints(), and NiCorrectJointsRotation().

Here is the caller graph for this function:

◆ NiCorrectJointEuler()

void NiCorrectJointEuler ( int joint,
Quaternion< double > * quat,
RBound< double > rb )

Definition at line 923 of file NiJointsTool.cpp.

924{
925 if (rb.tmin==0.0) return; // 修正しない
926
927 Vector<double> eul[2];
928
929 eul[0].set(0.0, 0.0, 0.0, 0.0, -1.0);
930 NiGetJointEuler(joint, quat, eul);
931 if (eul[0].c==-1.0) return; // オイラー角への変換に失敗
932
933 //
934 BOOL chgf = FALSE;
935 if (eul[0].x<rb.xmin) { eul[0].x = rb.xmin; chgf = TRUE;}
936 else if (eul[0].x>rb.xmax) { eul[0].x = rb.xmax; chgf = TRUE;}
937 if (eul[0].y<rb.ymin) { eul[0].y = rb.ymin; chgf = TRUE;}
938 else if (eul[0].y>rb.ymax) { eul[0].y = rb.ymax; chgf = TRUE;}
939 if (eul[0].z<rb.zmin) { eul[0].z = rb.zmin; chgf = TRUE;}
940 else if (eul[0].z>rb.zmax) { eul[0].z = rb.zmax; chgf = TRUE;}
941 if (!chgf) return;
942
943 //
944 chgf = FALSE;
945 if (eul[1].x<rb.xmin) { eul[1].x = rb.xmin; chgf = TRUE;}
946 else if (eul[1].x>rb.xmax) { eul[1].x = rb.xmax; chgf = TRUE;}
947 if (eul[1].y<rb.ymin) { eul[1].y = rb.ymin; chgf = TRUE;}
948 else if (eul[1].y>rb.ymax) { eul[1].y = rb.ymax; chgf = TRUE;}
949 if (eul[1].z<rb.zmin) { eul[1].z = rb.zmin; chgf = TRUE;}
950 else if (eul[1].z>rb.zmax) { eul[1].z = rb.zmax; chgf = TRUE;}
951 if (!chgf) return;
952
953 //
954 NiSetJointEuler(joint, eul, quat);
955
956 return;
957}
void NiSetJointEuler(int joint, Vector< double > *vect, Quaternion< double > *quat)
void NiGetJointEuler(int joint, Quaternion< double > *quat, Vector< double > *vect)

References NiGetJointEuler(), and NiSetJointEuler().

Referenced by NiCorrectJointsRotation().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ NiCorrectJointsRotation()

void NiCorrectJointsRotation ( Quaternion< double > * quat,
NiSDK_Lib lib )

Definition at line 845 of file NiJointsTool.cpp.

846{
847 int joint;
848
849 // TORSO
850 joint = Ni2SDKRotJointNum(NI_TORSO, lib); // abdomen
851 if (joint>0) NiCorrectJointEuler(NI_TORSO, quat+joint, RBound_NI_TORSO);
852 // CHEST
853 joint = Ni2SDKRotJointNum(NI_CHEST, lib);
854 if (joint>0) NiCorrectJointEuler(NI_CHEST, quat+joint, RBound_NI_CHEST);
855 // NECK
856 joint = Ni2SDKRotJointNum(NI_NECK, lib);
857 if (joint>0) NiCorrectJointEuler(NI_NECK, quat+joint, RBound_NI_NECK);
858 // HEAD
859 joint = Ni2SDKRotJointNum(NI_HEAD, lib);
860 if (joint>0) NiCorrectJointEuler(NI_HEAD, quat+joint, RBound_NI_HEAD);
861
862 // L_COLLAR
863 joint = Ni2SDKRotJointNum(NI_L_COLLAR, lib);
864 if (joint>0) NiCorrectJointEuler(NI_L_COLLAR, quat+joint, RBound_NI_L_COLLAR);
865 // R_COLLAR
866 joint = Ni2SDKRotJointNum(NI_R_COLLAR, lib);
867 if (joint>0) NiCorrectJointEuler(NI_R_COLLAR, quat+joint, RBound_NI_R_COLLAR);
868 // L_SHLDR
869 joint = Ni2SDKRotJointNum(NI_L_SHLDR, lib);
870 if (joint>0) NiCorrectJointEuler(NI_L_SHLDR, quat+joint, RBound_NI_L_SHLDR);
871 // R_SHLDR
872 joint = Ni2SDKRotJointNum(NI_R_SHLDR, lib);
873 if (joint>0) NiCorrectJointEuler(NI_R_SHLDR, quat+joint, RBound_NI_R_SHLDR);
874 // L_ELBOW
875 joint = Ni2SDKRotJointNum(NI_L_ELBOW, lib);
876 if (joint>0) NiCorrectJointEuler(NI_L_ELBOW, quat+joint, RBound_NI_L_ELBOW);
877 // R_ELBOW
878 joint = Ni2SDKRotJointNum(NI_R_ELBOW, lib);
879 if (joint>0) NiCorrectJointEuler(NI_R_ELBOW, quat+joint, RBound_NI_R_ELBOW);
880 // L_WRIST
881 joint = Ni2SDKRotJointNum(NI_L_WRIST, lib);
882 if (joint>0) NiCorrectJointEuler(NI_L_WRIST, quat+joint, RBound_NI_L_WRIST);
883 // R_WRIST
884 joint = Ni2SDKRotJointNum(NI_R_WRIST, lib);
885 if (joint>0) NiCorrectJointEuler(NI_R_WRIST, quat+joint, RBound_NI_R_WRIST);
886 // L_HAND
887 joint = Ni2SDKRotJointNum(NI_L_HAND, lib);
888 if (joint>0) NiCorrectJointEuler(NI_L_HAND, quat+joint, RBound_NI_L_HAND);
889 // R_HAND
890 joint = Ni2SDKRotJointNum(NI_R_HAND, lib);
891 if (joint>0) NiCorrectJointEuler(NI_R_HAND, quat+joint, RBound_NI_R_HAND);
892
893 // L_HIP
894 joint = Ni2SDKRotJointNum(NI_L_HIP, lib);
895 if (joint>0) NiCorrectJointEuler(NI_L_HIP, quat+joint, RBound_NI_L_HIP);
896 // R_HIP
897 joint = Ni2SDKRotJointNum(NI_R_HIP, lib);
898 if (joint>0) NiCorrectJointEuler(NI_R_HIP, quat+joint, RBound_NI_R_HIP);
899 // L_KNEE
900 joint = Ni2SDKRotJointNum(NI_L_KNEE, lib);
901 if (joint>0) NiCorrectJointEuler(NI_L_KNEE, quat+joint, RBound_NI_L_KNEE);
902 // R_KNEE
903 joint = Ni2SDKRotJointNum(NI_R_KNEE, lib);
904 if (joint>0) NiCorrectJointEuler(NI_R_KNEE, quat+joint, RBound_NI_R_KNEE);
905 // L_ANKLE
906 joint = Ni2SDKRotJointNum(NI_L_ANKLE, lib);
907 if (joint>0) NiCorrectJointEuler(NI_L_ANKLE, quat+joint, RBound_NI_L_ANKLE);
908 // R_ANKLE
909 joint = Ni2SDKRotJointNum(NI_R_ANKLE, lib);
910 if (joint>0) NiCorrectJointEuler(NI_R_ANKLE, quat+joint, RBound_NI_R_ANKLE);
911 // L_FOOT
912 joint = Ni2SDKRotJointNum(NI_L_FOOT, lib);
913 if (joint>0) NiCorrectJointEuler(NI_L_FOOT, quat+joint, RBound_NI_L_FOOT);
914 // R_FOOT
915 joint = Ni2SDKRotJointNum(NI_R_FOOT, lib);
916 if (joint>0) NiCorrectJointEuler(NI_R_FOOT, quat+joint, RBound_NI_R_FOOT);
917
918 return;
919}
RBound< double > RBound_NI_R_ELBOW
RBound< double > RBound_NI_L_ANKLE
RBound< double > RBound_NI_L_FOOT
RBound< double > RBound_NI_L_HIP
RBound< double > RBound_NI_NECK
RBound< double > RBound_NI_L_HAND
RBound< double > RBound_NI_L_WRIST
RBound< double > RBound_NI_R_KNEE
RBound< double > RBound_NI_L_SHLDR
RBound< double > RBound_NI_L_KNEE
RBound< double > RBound_NI_HEAD
RBound< double > RBound_NI_R_COLLAR
RBound< double > RBound_NI_R_WRIST
RBound< double > RBound_NI_CHEST
RBound< double > RBound_NI_R_HIP
RBound< double > RBound_NI_L_ELBOW
RBound< double > RBound_NI_TORSO
RBound< double > RBound_NI_R_SHLDR
RBound< double > RBound_NI_R_FOOT
RBound< double > RBound_NI_L_COLLAR
RBound< double > RBound_NI_R_HAND
RBound< double > RBound_NI_R_ANKLE
#define NI_R_ELBOW
#define NI_HEAD
#define NI_R_HIP
#define NI_R_KNEE
#define NI_R_FOOT
#define NI_TORSO
#define NI_L_SHLDR
#define NI_L_FOOT
#define NI_R_SHLDR
#define NI_R_WRIST
#define NI_L_HIP
#define NI_L_ANKLE
#define NI_L_WRIST
#define NI_R_COLLAR
#define NI_L_COLLAR
#define NI_CHEST
#define NI_R_ANKLE
#define NI_L_ELBOW
#define NI_L_HAND
#define NI_NECK
#define NI_L_KNEE
#define NI_R_HAND
void NiCorrectJointEuler(int joint, Quaternion< double > *quat, RBound< double > rb)
int Ni2SDKRotJointNum(int joint, NiSDK_Lib lib)

References Ni2SDKRotJointNum(), NI_CHEST, NI_HEAD, NI_L_ANKLE, NI_L_COLLAR, NI_L_ELBOW, NI_L_FOOT, NI_L_HAND, NI_L_HIP, NI_L_KNEE, NI_L_SHLDR, NI_L_WRIST, NI_NECK, NI_R_ANKLE, NI_R_COLLAR, NI_R_ELBOW, NI_R_FOOT, NI_R_HAND, NI_R_HIP, NI_R_KNEE, NI_R_SHLDR, NI_R_WRIST, NI_TORSO, NiCorrectJointEuler(), RBound_NI_CHEST, RBound_NI_HEAD, RBound_NI_L_ANKLE, RBound_NI_L_COLLAR, RBound_NI_L_ELBOW, RBound_NI_L_FOOT, RBound_NI_L_HAND, RBound_NI_L_HIP, RBound_NI_L_KNEE, RBound_NI_L_SHLDR, RBound_NI_L_WRIST, RBound_NI_NECK, RBound_NI_R_ANKLE, RBound_NI_R_COLLAR, RBound_NI_R_ELBOW, RBound_NI_R_FOOT, RBound_NI_R_HAND, RBound_NI_R_HIP, RBound_NI_R_KNEE, RBound_NI_R_SHLDR, RBound_NI_R_WRIST, and RBound_NI_TORSO.

Here is the call graph for this function:

◆ NiGetJointEuler()

void NiGetJointEuler ( int joint,
Quaternion< double > * quat,
Vector< double > * vect )

Definition at line 961 of file NiJointsTool.cpp.

962{
963 if (vect==NULL) return;
964
965 Vector<double> vt[2];
966 vt[0].set(0.0, 0.0, 0.0, 0.0, -1.0);
967
968 if (joint==NI_L_ANKLE || joint==NI_R_ANKLE) {
969 Quaternion2ExtEulerXZY(*quat, vt);
970 if (vt[0].c!=-1.0) {
971 vect[0].set(vt[0].element1(), vt[0].element3(), vt[0].element2());
972 vect[1].set(vt[1].element1(), vt[1].element3(), vt[1].element2());
973 }
974 }
975 else if (joint==NI_L_COLLAR || joint==NI_R_COLLAR) {
976 Quaternion2ExtEulerYXZ(*quat, vt);
977 if (vt[0].c!=-1.0) {
978 vect[0].set(vt[0].element2(), vt[0].element1(), vt[0].element3());
979 vect[1].set(vt[1].element2(), vt[1].element1(), vt[1].element3());
980 }
981 }
982 else if (joint==NI_L_SHLDR || joint==NI_R_SHLDR) {
983 Quaternion2ExtEulerYZX(*quat, vt);
984 if (vt[0].c!=-1.0) {
985 vect[0].set(vt[0].element3(), vt[0].element1(), vt[0].element2());
986 vect[1].set(vt[1].element3(), vt[1].element1(), vt[1].element2());
987 }
988 }
989 else if (joint==NI_L_ELBOW || joint==NI_R_ELBOW) {
990 Quaternion2ExtEulerYXZ(*quat, vt);
991 if (vt[0].c!=-1.0) {
992 vect[0].set(vt[0].element2(), vt[0].element1(), vt[0].element3());
993 vect[1].set(vt[1].element2(), vt[1].element1(), vt[1].element3());
994 }
995 }
996 else if (joint==NI_L_WRIST || joint==NI_R_WRIST) {
997 Quaternion2ExtEulerYZX(*quat, vt);
998 if (vt[0].c!=-1.0) {
999 vect[0].set(vt[0].element3(), vt[0].element1(), vt[0].element2());
1000 vect[1].set(vt[1].element3(), vt[1].element1(), vt[1].element2());
1001 }
1002 }
1003 else {
1004 Quaternion2ExtEulerZXY(*quat, vt);
1005 if (vt[0].c!=-1.0) {
1006 vect[0].set(vt[0].element2(), vt[0].element3(), vt[0].element1());
1007 vect[1].set(vt[1].element2(), vt[1].element3(), vt[1].element1());
1008 }
1009 }
1010
1011 return;
1012}

References NI_L_ANKLE, NI_L_COLLAR, NI_L_ELBOW, NI_L_SHLDR, NI_L_WRIST, NI_R_ANKLE, NI_R_COLLAR, NI_R_ELBOW, NI_R_SHLDR, and NI_R_WRIST.

Referenced by NiCorrectJointEuler().

Here is the caller graph for this function:

◆ NiGetSkeletonColor()

unsigned int NiGetSkeletonColor ( int label)

Definition at line 45 of file NiToolWin.cpp.

46{
47 unsigned int col;
48
49 if (label==1) {
50 col = BGRA2Int(255, 255, 255-NI_DETECT_COLOR_BRIGHT, 0);
51 }
52 else if (label==2) {
53 col = BGRA2Int(255, 255-NI_DETECT_COLOR_BRIGHT, 255, 0);
54 }
55 else if (label==3) {
56 col = BGRA2Int(255-NI_DETECT_COLOR_BRIGHT, 255, 255, 0);
57 }
58 else if (label==4) {
59 col = BGRA2Int(255-NI_DETECT_COLOR_BRIGHT, 255-NI_DETECT_COLOR_BRIGHT, 255, 0);
60 }
61 else if (label==5) {
62 col = BGRA2Int(255-NI_DETECT_COLOR_BRIGHT, 255, 255-NI_DETECT_COLOR_BRIGHT, 0);
63 }
64 else {
65 col = BGRA2Int(255, 255-NI_DETECT_COLOR_BRIGHT, 255-NI_DETECT_COLOR_BRIGHT, 0);
66 }
67
68/*
69 if (label==1) {
70 col = BGRA2Int(255, 255, 255, 0);
71 }
72 else if (label==2) {
73 col = BGRA2Int(255, 255, 255, 0);
74 }
75 else if (label==3) {
76 col = BGRA2Int(255, 255, 255, 0);
77 }
78 else if (label==4) {
79 col = BGRA2Int(255, 255, 255, 0);
80 }
81 else if (label==5) {
82 col = BGRA2Int(255, 255, 255, 0);
83 }
84 else {
85 col = BGRA2Int(255, 255, 255, 0);
86 }
87 */
88
89 return col;
90}
#define NI_DETECT_COLOR_BRIGHT
Definition NiToolWin.h:22

References NI_DETECT_COLOR_BRIGHT.

◆ NiInitRBoundJointsRotation()

◆ NiJointName()

std::string NiJointName ( int n)

Definition at line 117 of file NiJointsTool.cpp.

118{
119 std::string str = "";
120
121 if (n>=0 && n<NI_TOTAL_JOINT_NUM) {
122 str = _NiJointName[n];
123 }
124
125 return str;
126}

References _NiJointName, and NI_TOTAL_JOINT_NUM.

Referenced by addBVHJointName(), setBVHJointName(), and CNiJTextTool::writeCurrentData().

Here is the caller graph for this function:

◆ NiJointNum()

int NiJointNum ( char * name)

Definition at line 130 of file NiJointsTool.cpp.

131{
132 for (int i=0; i<NI_TOTAL_JOINT_NUM; i++) {
133 if (!strcmp(name, _NiJointName[i].c_str())) return i;
134 }
135 return -1;
136}

References _NiJointName, and NI_TOTAL_JOINT_NUM.

Referenced by CNiJTextTool::readFile().

Here is the caller graph for this function:

◆ NiSDK2JointName()

std::string NiSDK2JointName ( int joint,
NiSDK_Lib lib )

Definition at line 188 of file NiJointsTool.cpp.

189{
190 std::string str = "";
191
192 if (lib==NiSDK_OpenNI2) {
193 int n = _OpenNI22JointNameNum[j];
194 if (n>=0) str = _NiJointName[n];
195 }
196 else if (lib==NiSDK_OpenNI) {
197 int n = _OpenNI2JointNameNum[j];
198 if (n>=0) str = _NiJointName[n];
199 }
200 else if (lib==NiSDK_Kinect) {
201 int n = _Kinect2JointNameNum[j];
202 if (n>=0) str = _NiJointName[n];
203 }
204 else if (lib==NiSDK_None) {
205 //str = _NiJointName[_Ni2JointNameNum[j]];
206 str = _NiJointName[j];
207 }
208
209 return str;
210}
static int _OpenNI22JointNameNum[]
static int _OpenNI2JointNameNum[]
static int _Kinect2JointNameNum[]

References _Kinect2JointNameNum, _NiJointName, _OpenNI22JointNameNum, _OpenNI2JointNameNum, NiSDK_Kinect, NiSDK_None, NiSDK_OpenNI, and NiSDK_OpenNI2.

◆ NiSDKMirrorJointNum()

int NiSDKMirrorJointNum ( int joint,
NiSDK_Lib lib )

Definition at line 261 of file NiJointsTool.cpp.

262{
263 int ret = -1;
264 if (j<0) return ret;
265
266 if (lib==NiSDK_OpenNI2) {
267 ret = _OpenNI2MirrorJointNum[j];
268 }
269 else if (lib==NiSDK_OpenNI) {
270 ret = _OpenNIMirrorJointNum[j];
271 }
272 else if (lib==NiSDK_Kinect) {
273 ret = _KinectMirrorJointNum[j];
274 }
275 else if (lib==NiSDK_None) {
276 ret = _NiMirrorJointNum[j];
277 }
278
279 return ret;
280}
static int _NiMirrorJointNum[]
static int _KinectMirrorJointNum[]
static int _OpenNIMirrorJointNum[]
static int _OpenNI2MirrorJointNum[]

References _KinectMirrorJointNum, _NiMirrorJointNum, _OpenNI2MirrorJointNum, _OpenNIMirrorJointNum, NiSDK_Kinect, NiSDK_None, NiSDK_OpenNI, and NiSDK_OpenNI2.

Referenced by CNiJTextTool::setJntAngl(), CNiJTextTool::setPosVect(), and CNiJTextTool::setRotQuat().

Here is the caller graph for this function:

◆ NiSetJointEuler()

void NiSetJointEuler ( int joint,
Vector< double > * vect,
Quaternion< double > * quat )

Definition at line 1016 of file NiJointsTool.cpp.

1017{
1018 Quaternion<double> qut[2], rot[2];
1019 Vector<double> eul[2];
1020
1021 if (joint==NI_L_ANKLE || joint==NI_R_ANKLE) {
1022 eul[0].set(vect[0].x, vect[0].z, vect[0].y);
1023 eul[1].set(vect[1].x, vect[1].z, vect[1].y);
1024 qut[0].setExtEulerXZY(eul[0]);
1025 qut[1].setExtEulerXZY(eul[1]);
1026 }
1027 else if (joint==NI_L_COLLAR || joint==NI_R_COLLAR) {
1028 eul[0].set(vect[0].y, vect[0].x, vect[0].z);
1029 eul[1].set(vect[1].y, vect[1].x, vect[1].z);
1030 qut[0].setExtEulerYXZ(eul[0]);
1031 qut[1].setExtEulerYXZ(eul[1]);
1032 }
1033 else if (joint==NI_L_SHLDR || joint==NI_R_SHLDR) {
1034 eul[0].set(vect[0].y, vect[0].z, vect[0].x);
1035 eul[1].set(vect[1].y, vect[1].z, vect[1].x);
1036 qut[0].setExtEulerYZX(eul[0]);
1037 qut[1].setExtEulerYZX(eul[1]);
1038 }
1039 else if (joint==NI_L_ELBOW || joint==NI_R_ELBOW) {
1040 eul[0].set(vect[0].y, vect[0].x, vect[0].z);
1041 eul[1].set(vect[1].y, vect[1].x, vect[1].z);
1042 qut[0].setExtEulerYXZ(eul[0]);
1043 qut[1].setExtEulerYXZ(eul[1]);
1044 }
1045 else if (joint==NI_L_WRIST || joint==NI_R_WRIST) {
1046 eul[0].set(vect[0].y, vect[0].z, vect[0].x);
1047 eul[1].set(vect[1].y, vect[1].z, vect[1].x);
1048 qut[0].setExtEulerYZX(eul[0]);
1049 qut[1].setExtEulerYZX(eul[1]);
1050 }
1051 else {
1052 eul[0].set(vect[0].z, vect[0].x, vect[0].y);
1053 eul[1].set(vect[1].z, vect[1].x, vect[1].y);
1054 qut[0].setExtEulerZXY(eul[0]);
1055 qut[1].setExtEulerZXY(eul[1]);
1056 }
1057
1058 //
1059 rot[0] = qut[0]*~(*quat);
1060 rot[1] = qut[1]*~(*quat);
1061 //
1062 if (rot[0].getAngle()<=rot[1].getAngle()) { // 回転角の小さい方を選択
1063 *quat = qut[0];
1064 }
1065 else {
1066 *quat = qut[1];
1067 }
1068
1069 return;
1070}

References NI_L_ANKLE, NI_L_COLLAR, NI_L_ELBOW, NI_L_SHLDR, NI_L_WRIST, NI_R_ANKLE, NI_R_COLLAR, NI_R_ELBOW, NI_R_SHLDR, and NI_R_WRIST.

Referenced by NiCorrectJointEuler().

Here is the caller graph for this function:

◆ NiSetKinectJointNums()

void NiSetKinectJointNums ( void )

Definition at line 575 of file NiJointsTool.cpp.

576{
577 NI_SDK_PELVIS = 0; // NUI_SKELETON_POSITION_HIP_CENTER
578 NI_SDK_TORSO = 1; // SPINE は書き換えて使用
579 NI_SDK_NECK = 2; // NUI_SKELETON_POSITION_SHOULDER_CENTER
580 NI_SDK_HEAD = 3; // NUI_SKELETON_POSITION_HEAD
581
582 NI_SDK_L_EYE = -1;
583 NI_SDK_R_EYE = -1;
584 NI_SDK_L_BUST = -1;
585 NI_SDK_R_BUST = -1;
586
587 NI_SDK_L_SHLDR = 4; // NUI_SKELETON_POSITION_SHOULDER_LEFT
588 NI_SDK_L_ELBOW = 5; // NUI_SKELETON_POSITION_ELBOW_LEFT
589 NI_SDK_L_WRIST = 6; // NUI_SKELETON_POSITION_WRIST_LEFT
590 NI_SDK_L_HAND = 7; // NUI_SKELETON_POSITION_HAND_LEFT
591 NI_SDK_L_FNGRTIP = -1;
592
593 NI_SDK_R_SHLDR = 8; // NUI_SKELETON_POSITION_SHOULDER_RIGHT
594 NI_SDK_R_ELBOW = 9; // NUI_SKELETON_POSITION_ELBOW_RIGHT
595 NI_SDK_R_WRIST = 10; // NUI_SKELETON_POSITION_WRIST_RIGHT
596 NI_SDK_R_HAND = 11; // NUI_SKELETON_POSITION_HAND_RIGHT
597 NI_SDK_R_FNGRTIP = -1;
598
599 NI_SDK_L_HIP = 12; // NUI_SKELETON_POSITION_HIP_LEFT
600 NI_SDK_L_KNEE = 13; // NUI_SKELETON_POSITION_KNEE_LEFT
601 NI_SDK_L_ANKLE = 14; // NUI_SKELETON_POSITION_ANKLE_LEFT
602 NI_SDK_L_FOOT = 15; // NUI_SKELETON_POSITION_FOOT_LEFT
603
604 NI_SDK_R_HIP = 16; // NUI_SKELETON_POSITION_HIP_RIGHT
605 NI_SDK_R_KNEE = 17; // NUI_SKELETON_POSITION_KNEE_RIGHT
606 NI_SDK_R_ANKLE = 18; // NUI_SKELETON_POSITION_ANKLE_RIGHT
607 NI_SDK_R_FOOT = 19; // NUI_SKELETON_POSITION_FOOT_RIGHT
608
609 NI_SDK_L_FINGER = -1;
610 NI_SDK_R_FINGER = -1;
611 NI_SDK_FACE = -1;
612 NI_SDK_AVATAR = -1;
613
614 return;
615}
int NI_SDK_R_KNEE
int NI_SDK_R_HAND
int NI_SDK_L_WRIST
int NI_SDK_L_HAND
int NI_SDK_L_HIP
int NI_SDK_R_HIP
int NI_SDK_R_SHLDR
int NI_SDK_R_EYE
int NI_SDK_L_SHLDR
int NI_SDK_R_ANKLE
int NI_SDK_HEAD
int NI_SDK_L_FNGRTIP
int NI_SDK_R_FINGER
int NI_SDK_PELVIS
int NI_SDK_NECK
int NI_SDK_R_ELBOW
int NI_SDK_FACE
int NI_SDK_L_FOOT
int NI_SDK_L_EYE
int NI_SDK_L_KNEE
int NI_SDK_AVATAR
int NI_SDK_R_FNGRTIP
int NI_SDK_L_ANKLE
int NI_SDK_R_FOOT
int NI_SDK_TORSO
int NI_SDK_R_BUST
int NI_SDK_L_FINGER
int NI_SDK_L_ELBOW
int NI_SDK_R_WRIST
int NI_SDK_L_BUST

References NI_SDK_AVATAR, NI_SDK_FACE, NI_SDK_HEAD, NI_SDK_L_ANKLE, NI_SDK_L_BUST, NI_SDK_L_ELBOW, NI_SDK_L_EYE, NI_SDK_L_FINGER, NI_SDK_L_FNGRTIP, NI_SDK_L_FOOT, NI_SDK_L_HAND, NI_SDK_L_HIP, NI_SDK_L_KNEE, NI_SDK_L_SHLDR, NI_SDK_L_WRIST, NI_SDK_NECK, NI_SDK_PELVIS, NI_SDK_R_ANKLE, NI_SDK_R_BUST, NI_SDK_R_ELBOW, NI_SDK_R_EYE, NI_SDK_R_FINGER, NI_SDK_R_FNGRTIP, NI_SDK_R_FOOT, NI_SDK_R_HAND, NI_SDK_R_HIP, NI_SDK_R_KNEE, NI_SDK_R_SHLDR, NI_SDK_R_WRIST, and NI_SDK_TORSO.

◆ NiSetOpenNI2JointNums()

void NiSetOpenNI2JointNums ( void )

Definition at line 530 of file NiJointsTool.cpp.

531{
532 NI_SDK_PELVIS = 0; //
533 NI_SDK_TORSO = 9; // NITE_JOINT_TORSO + 1
534 NI_SDK_NECK = 2; // NITE_JOINT_NECK + 1
535 NI_SDK_HEAD = 1; // NITE_JOINT_HEAD + 1
536
537 NI_SDK_L_EYE = -1;
538 NI_SDK_R_EYE = -1;
539 NI_SDK_L_BUST = -1;
540 NI_SDK_R_BUST = -1;
541
542 NI_SDK_L_SHLDR = 4; // NITE_JOINT_RIGHT_SHOULDER + 1
543 NI_SDK_L_ELBOW = 6; // NITE_JOINT_RIGHT_ELBOW + 1
544 NI_SDK_L_WRIST = 8; // NITE_JOINT_RIGHT_HAND + 1
545 NI_SDK_L_HAND = -1;
546 NI_SDK_L_FNGRTIP = -1;
547
548 NI_SDK_R_SHLDR = 3; // NITE_JOINT_LEFT_SHOULDER + 1
549 NI_SDK_R_ELBOW = 5; // NITE_JOINT_LEFT_ELBOW + 1
550 NI_SDK_R_WRIST = 7; // NITE_JOINT_LEFT_HAND + 1
551 NI_SDK_R_HAND = -1;
552 NI_SDK_R_FNGRTIP = -1;
553
554 NI_SDK_L_HIP = 11; // NITE_JOINT_RIGHT_HIP + 1
555 NI_SDK_L_KNEE = 13; // NITE_JOINT_RIGHT_KNEE + 1
556 NI_SDK_L_ANKLE = 15; // NITE_JOINT_RIGHT_FOOT + 1
557 NI_SDK_L_FOOT = -1;
558
559 NI_SDK_R_HIP = 10; // NITE_JOINT_LEFT_HIP + 1
560 NI_SDK_R_KNEE = 12; // NITE_JOINT_LEFT_KNEE + 1
561 NI_SDK_R_ANKLE = 14; // NITE_JOINT_LEFT_FOOT + 1
562 NI_SDK_R_FOOT = -1;
563
564 NI_SDK_L_FINGER = -1;
565 NI_SDK_R_FINGER = -1;
566 NI_SDK_FACE = -1;
567 NI_SDK_AVATAR = -1;
568
569 return;
570}

References NI_SDK_AVATAR, NI_SDK_FACE, NI_SDK_HEAD, NI_SDK_L_ANKLE, NI_SDK_L_BUST, NI_SDK_L_ELBOW, NI_SDK_L_EYE, NI_SDK_L_FINGER, NI_SDK_L_FNGRTIP, NI_SDK_L_FOOT, NI_SDK_L_HAND, NI_SDK_L_HIP, NI_SDK_L_KNEE, NI_SDK_L_SHLDR, NI_SDK_L_WRIST, NI_SDK_NECK, NI_SDK_PELVIS, NI_SDK_R_ANKLE, NI_SDK_R_BUST, NI_SDK_R_ELBOW, NI_SDK_R_EYE, NI_SDK_R_FINGER, NI_SDK_R_FNGRTIP, NI_SDK_R_FOOT, NI_SDK_R_HAND, NI_SDK_R_HIP, NI_SDK_R_KNEE, NI_SDK_R_SHLDR, NI_SDK_R_WRIST, and NI_SDK_TORSO.

◆ NiSetOpenNIJointNums()

void NiSetOpenNIJointNums ( void )

Definition at line 485 of file NiJointsTool.cpp.

486{
487 NI_SDK_PELVIS = 0; //
488 NI_SDK_TORSO = 3; // XN_SKEL_TORSO
489 NI_SDK_NECK = 2; // XN_SKEL_NECK
490 NI_SDK_HEAD = 1; // XN_SKEL_HEAD
491
492 NI_SDK_L_EYE = -1;
493 NI_SDK_R_EYE = -1;
494 NI_SDK_L_BUST = -1;
495 NI_SDK_R_BUST = -1;
496
497 NI_SDK_L_SHLDR = 12; // XN_SKEL_RIGHT_SHOULDER
498 NI_SDK_L_ELBOW = 13; // XN_SKEL_RIGHT_ELBOW
499 NI_SDK_L_WRIST = 15; // XN_SKEL_RIGHT_HAND
500 NI_SDK_L_HAND = -1;
501 NI_SDK_L_FNGRTIP = -1;
502
503 NI_SDK_R_SHLDR = 6; // XN_SKEL_LEFT_SHOULDER
504 NI_SDK_R_ELBOW = 7; // XN_SKEL_LEFT_ELBOW
505 NI_SDK_R_WRIST = 9; // XN_SKEL_LEFT_HAND
506 NI_SDK_R_HAND = -1;
507 NI_SDK_R_FNGRTIP = -1;
508
509 NI_SDK_L_HIP = 21; // XN_SKEL_RIGHT_HIP
510 NI_SDK_L_KNEE = 22; // XN_SKEL_RIGHT_KNEE
511 NI_SDK_L_ANKLE = 24; // XN_SKEL_RIGHT_FOOT
512 NI_SDK_L_FOOT = -1;
513
514 NI_SDK_R_HIP = 17; // XN_SKEL_LEFT_HIP
515 NI_SDK_R_KNEE = 18; // XN_SKEL_LEFT_KNEE
516 NI_SDK_R_ANKLE = 20; // XN_SKEL_LEFT_FOOT
517 NI_SDK_R_FOOT = -1;
518
519 NI_SDK_L_FINGER = -1;
520 NI_SDK_R_FINGER = -1;
521 NI_SDK_FACE = -1;
522 NI_SDK_AVATAR = -1;
523
524 return;
525}

References NI_SDK_AVATAR, NI_SDK_FACE, NI_SDK_HEAD, NI_SDK_L_ANKLE, NI_SDK_L_BUST, NI_SDK_L_ELBOW, NI_SDK_L_EYE, NI_SDK_L_FINGER, NI_SDK_L_FNGRTIP, NI_SDK_L_FOOT, NI_SDK_L_HAND, NI_SDK_L_HIP, NI_SDK_L_KNEE, NI_SDK_L_SHLDR, NI_SDK_L_WRIST, NI_SDK_NECK, NI_SDK_PELVIS, NI_SDK_R_ANKLE, NI_SDK_R_BUST, NI_SDK_R_ELBOW, NI_SDK_R_EYE, NI_SDK_R_FINGER, NI_SDK_R_FNGRTIP, NI_SDK_R_FOOT, NI_SDK_R_HAND, NI_SDK_R_HIP, NI_SDK_R_KNEE, NI_SDK_R_SHLDR, NI_SDK_R_WRIST, and NI_SDK_TORSO.

◆ NiSetUserColor()

void NiSetUserColor ( int label,
uByte * ptr,
BOOL use_image = TRUE )

Definition at line 13 of file NiToolWin.cpp.

14{
15 if (label==1) {
16 if (!use_image) ptr[0] = ptr[1] = 0;
17 ptr[2] = NI_DETECT_COLOR_BRIGHT; // R
18 }
19 else if (label==2) {
20 if (!use_image) ptr[0] = ptr[2] = 0;
21 ptr[1] = NI_DETECT_COLOR_BRIGHT; // G
22 }
23 else if (label==3) {
24 if (!use_image) ptr[1] = ptr[2] = 0;
25 ptr[0] = NI_DETECT_COLOR_BRIGHT; // B
26 }
27 else if (label==4) {
28 if (!use_image) ptr[2] = 0;
29 ptr[0] = ptr[1] = NI_DETECT_COLOR_BRIGHT; // B, G
30 }
31 else if (label==5) {
32 if (!use_image) ptr[1] = 0;
33 ptr[0] = ptr[2] = NI_DETECT_COLOR_BRIGHT; // B, R
34 }
35 else {
36 if (!use_image) ptr[0] = 0;
37 ptr[1] = ptr[2] = NI_DETECT_COLOR_BRIGHT; // G, R
38 }
39
40 return;
41}

References NI_DETECT_COLOR_BRIGHT.

◆ numbering_name_t()

CString numbering_name_t ( LPCTSTR fmt,
int n )

Definition at line 403 of file WinTools.cpp.

404{
405 TCHAR fname[LNAME];
406
407 sntprintf(fname, LNAME-1, fmt, n);
408 CString ret = fname;
409 return ret;
410}

Referenced by CDxMGRView::MakeSetTitle(), and CRwGRDoc::ReadDataFile().

Here is the caller graph for this function:

◆ open_shm_debuger()

void open_shm_debuger ( void )

Definition at line 106 of file WinSMTool.cpp.

107{
108 jbxwl::_Debug_SHM = new CWinSharedMem("jbxwl_SHM_DEBUGGER");
109}

References _Debug_SHM.

◆ read_index_tList_file_t()

tList * read_index_tList_file_t ( LPCTSTR fn,
char cc )

Definition at line 387 of file WinTools.cpp.

388{
389 char* pathstr = NULL;
390 if (fn!=_T("")) pathstr = ts2mbs(fn);
391
392 tList* lt = read_index_tList_file(pathstr, cc);
393 freeNull(pathstr);
394
395 return lt;
396}

References ts2mbs().

Here is the call graph for this function:

◆ RebootProgram()

void RebootProgram ( void )

Definition at line 69 of file MFCTool.cpp.

70{
71 TCHAR path[LDATA];
72 GetModuleFileName(NULL, (LPTSTR)path, (DWORD)LDATA);
73
74 CString arg;
75 arg.Format(_T("/waitpid %u"), GetCurrentProcessId());
76 ShellExecute(NULL, NULL, (LPCTSTR)path, (LPCTSTR)arg, NULL, SW_SHOWNORMAL);
77
78 SendWinMessage(WM_CLOSE);
79}
void SendWinMessage(UINT mesg, WPARAM wparam=NULL, LPARAM lparam=NULL)
Definition WinTools.cpp:561

References SendWinMessage().

Here is the call graph for this function:

◆ releaseNull()

template<class T >
void releaseNull ( T *& ptr)
inline

Definition at line 220 of file WinTools.h.

221{
222 if (!jbxl::isNull(ptr)) {
223 ptr->Release();
224 ptr = NULL;
225 }
226}

Referenced by CWinAudioTool::free().

Here is the caller graph for this function:

◆ ResetDx9Device()

HRESULT ResetDx9Device ( LPDIRECT3DDEVICE9 lpD3DDevice,
D3DPRESENT_PARAMETERS * pd3dParam,
CDxBaseView * pviw = NULL )

HRESULT ResetDx9Device(LPDIRECT3DDEVICE9, D3DPRESENT_PARAMETERS*, CDxBaseView* pviw=NULL);

機能:  DirectX9のデバイスをリセットする.

引数: lpD3DDevice     リセットするDirectX9デバイス 
         d3dParam       デバイスリセットのためのパラメータ.作成時に使用したものを指定する.
         pviw           このデバイスを持っている CDxBaseViewクラスを指定する.省略可能(NULL)  

戻値:  リセットの HRESULT

説明:  D3DPOOL_DEFAULT管理のリソースなどは,デバイスのリセットを行う前にそれを開放し,
        リセット後に再び獲得しなければならない.pviwに CDxBaseViewクラスのポインタを設定
        した場合,解放関数として pviw->ClearObject() が呼び出され,再獲得関数として 
        pviw->InitObject()が呼び出される.この2つの関数は,CDxBaseViewクラスの継承クラス
        の中でオーバーライドされなければならない.pviw に NULLを指定した場合は,リソース
        の開放・再獲得は行われない.

        CDxBaseView* を引数に持つので,Dx9.cpp へは入れられない.

機能: DirectX9のデバイスをリセットする.

引数: lpD3DDevice リセットするDirectX9デバイス d3dParam デバイスリセットのためのパラメータ.作成時に使用したものを指定する. pviw このデバイスを持っている CDxBaseViewクラスを指定する.省略可能(NULL)

戻値: リセットの HRESULT

説明: D3DPOOL_DEFAULT管理のリソースなどは,デバイスのリセットを行う前にそれを開放し, リセット後に再び獲得しなければならない.pviwに CDxBaseViewクラスのポインタを設定 した場合,解放関数として pviw->ClearObject() が呼び出され,再獲得関数として pviw->InitObject()が呼び出される.この2つの関数は,CDxBaseViewクラスの継承クラス の中でオーバーライドされなければならない.pviw に NULLを指定した場合は,リソース の開放・再獲得は行われない.

CDxBaseView* を引数に持つので,Dx9.cpp へは入れられない.

Definition at line 347 of file DxBaseClass.cpp.

348{
349 HRESULT hr = lpD3DDevice->TestCooperativeLevel();
350 if (hr==D3D_OK) return hr;
351
352 do {
353 Sleep(100);
354 hr = lpD3DDevice->TestCooperativeLevel();
355 } while (hr==D3DERR_DEVICELOST); // デバイスがリセットできるようになるまで待つ.
356
357 if (hr==D3DERR_DEVICENOTRESET) { // リセット可能
358 if (pviw!=NULL) pviw->ClearObject();
359
360 hr = lpD3DDevice->Reset(pd3dParam);
361 if (hr==D3D_OK) { // リセット成功
362 DEBUG_INFO("jbxwl::ResetDx9Device(): Reseted Dx9 Device.\n");
363 if (pviw!=NULL) pviw->InitObject();
364 }
365 else {
366 DEBUG_ERROR("jbxwl::ResetDx9Device(): Failed to Reset.\n");
367 }
368 }
369 return hr;
370}
virtual void ClearObject(void)
virtual void InitObject(void)

References CDxBaseView::ClearObject(), and CDxBaseView::InitObject().

Referenced by CDx2DView::ExecRender(), CDxSRenderView::ExecRender(), CDxVScrollView::ExecRender(), CDxDirectView::ExecRender(), and CDxMGRView::ExecRender().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ SaveToClipboard()

void SaveToClipboard ( void * ptr,
size_t len )

Definition at line 595 of file WinTools.cpp.

596{
597 if (ptr == NULL) return;
598
599 HGLOBAL hMem = ::GlobalAlloc(GHND, len);
600 char* pszptr = (char*)::GlobalLock(hMem);
601
602 memcpy(pszptr, ptr, len);
603 //lstrcpy(pszptr, data);
604
605 ::GlobalUnlock(hMem);
606
607 if (!OpenClipboard(NULL)) {
608 ::GlobalFree(hMem);
609 return;
610 }
611 if (!EmptyClipboard()) {
612 ::GlobalFree(hMem);
613 return;
614 }
615 if (SetClipboardData(CF_TEXT, hMem) == NULL) {
616 ::GlobalFree(hMem);
617 }
618 CloseClipboard();
619
620 return;
621}

Referenced by SaveToClipboard_byStr().

Here is the caller graph for this function:

◆ SaveToClipboard_byStr()

void SaveToClipboard_byStr ( CString data)

Definition at line 587 of file WinTools.cpp.

588{
589 if (data.IsEmpty()) return;
590
591 SaveToClipboard(CStringA(data).GetBuffer(), CStringA(data).GetLength());
592}
void SaveToClipboard(void *ptr, size_t len)
Definition WinTools.cpp:595

References SaveToClipboard().

Here is the call graph for this function:

◆ SendKeyAction()

void SendKeyAction ( WORD key,
SENDKEY_Action action )

Definition at line 628 of file WinTools.cpp.

629{
630 INPUT input;
631
632 input.type = INPUT_KEYBOARD;
633 input.ki.wVk = key;
634 input.ki.wScan = MapVirtualKeyW(key, 0);
635 input.ki.dwFlags = KEYEVENTF_EXTENDEDKEY;
636
637 if (action==SENDKEY_TapAction || action==SENDKEY_DownAction) {
638 SendInput(1, &input, sizeof(INPUT));
639 }
640 if (action==SENDKEY_TapAction || action==SENDKEY_UpAction) {
641 input.ki.dwFlags |= KEYEVENTF_KEYUP;
642 SendInput(1, &input, sizeof(INPUT));
643 }
644}

References SENDKEY_DownAction, SENDKEY_TapAction, and SENDKEY_UpAction.

Referenced by SendKeyActionTap(), SendKeyActionTap(), and SendKeyActionTap().

Here is the caller graph for this function:

◆ SendKeyActionTap() [1/3]

void SendKeyActionTap ( WORD key)
inline

Definition at line 144 of file WinTools.h.

144{ SendKeyAction(key, SENDKEY_TapAction);}
void SendKeyAction(WORD key, SENDKEY_Action action)
Definition WinTools.cpp:628

References SENDKEY_TapAction, and SendKeyAction().

Referenced by DoSystemKeyAction(), SendKeyActionTapAlt(), SendKeyActionTapCtrl(), and SendKeyActionTapShift().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ SendKeyActionTap() [2/3]

void SendKeyActionTap ( WORD key1,
WORD key2 )

Definition at line 648 of file WinTools.cpp.

References SENDKEY_DownAction, SENDKEY_TapAction, SENDKEY_UpAction, and SendKeyAction().

Here is the call graph for this function:

◆ SendKeyActionTap() [3/3]

void SendKeyActionTap ( WORD key1,
WORD key2,
WORD key3 )

Definition at line 657 of file WinTools.cpp.

References SENDKEY_DownAction, SENDKEY_TapAction, SENDKEY_UpAction, and SendKeyAction().

Here is the call graph for this function:

◆ SendKeyActionTapAlt()

void SendKeyActionTapAlt ( WORD key)
inline

Definition at line 149 of file WinTools.h.

149{ SendKeyActionTap(VK_LMENU, key);}

References SendKeyActionTap().

Referenced by DoSystemKeyAction().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ SendKeyActionTapCtrl()

void SendKeyActionTapCtrl ( WORD key)
inline

Definition at line 151 of file WinTools.h.

151{ SendKeyActionTap(VK_LCONTROL, key);}

References SendKeyActionTap().

Referenced by DoSystemKeyAction().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ SendKeyActionTapShift()

void SendKeyActionTapShift ( WORD key)
inline

Definition at line 150 of file WinTools.h.

150{ SendKeyActionTap(VK_LSHIFT, key);}

References SendKeyActionTap().

Here is the call graph for this function:

◆ SendWinMessage()

void SendWinMessage ( UINT mesg,
WPARAM wparam = NULL,
LPARAM lparam = NULL )

Definition at line 561 of file WinTools.cpp.

562{
563 CWinApp* app = AfxGetApp();
564 if (app!=NULL) {
565 CWnd* wnd = app->m_pMainWnd;
566 if (wnd!=NULL) wnd->SendMessage(mesg, wparam, lparam);
567 }
568}

Referenced by RebootProgram().

Here is the caller graph for this function:

◆ setBVHJointName()

tList * setBVHJointName ( void )
See also
llfloatermodelpreview.cpp

Definition at line 11 of file NiBVHName.cpp.

12{
13 tList* lt = add_bvh_name(NULL, -1, "BVH Name List");
14 tList* pp = lt;
15
16 // NI: PELVIS, WAIST, TORSO, ....., R_TOE see NiJointsTool.cpp
17 for (int j=0; j<NI_NORML_JOINT_NUM; j++) {
18 pp = add_bvh_name(pp, j, (char*)NiJointName(j).c_str());
19 }
20
21 // SL/OS
22 pp = add_bvh_name(pp, NI_PELVIS, "mPelvis");
23 pp = add_bvh_name(pp, NI_TORSO, "mTorso");
24 pp = add_bvh_name(pp, NI_CHEST, "mChest");
25 pp = add_bvh_name(pp, NI_NECK, "mNeck");
26 pp = add_bvh_name(pp, NI_HEAD, "mHead");
27 pp = add_bvh_name(pp, NI_SKULL, "mSkull");
28 pp = add_bvh_name(pp, NI_L_EYE, "mEyeLeft");
29 pp = add_bvh_name(pp, NI_R_EYE, "mEyeRight");
30 pp = add_bvh_name(pp, NI_L_COLLAR, "mCollarLeft");
31 pp = add_bvh_name(pp, NI_L_SHLDR, "mShoulderLeft");
32 pp = add_bvh_name(pp, NI_L_ELBOW, "mElbowLeft");
33 pp = add_bvh_name(pp, NI_L_WRIST, "mWristLeft");
34 pp = add_bvh_name(pp, NI_R_COLLAR, "mCollarRight");
35 pp = add_bvh_name(pp, NI_R_SHLDR, "mShoulderRight");
36 pp = add_bvh_name(pp, NI_R_ELBOW, "mElbowRight");
37 pp = add_bvh_name(pp, NI_R_WRIST, "mWristRight");
38 pp = add_bvh_name(pp, NI_L_HIP, "mHipLeft");
39 pp = add_bvh_name(pp, NI_L_KNEE, "mKneeLeft");
40 pp = add_bvh_name(pp, NI_L_ANKLE, "mAnkleLeft");
41 pp = add_bvh_name(pp, NI_L_FOOT, "mFootLeft");
42 pp = add_bvh_name(pp, NI_L_TOE, "mToeLeft");
43 pp = add_bvh_name(pp, NI_R_HIP, "mHipRight");
44 pp = add_bvh_name(pp, NI_R_KNEE, "mKneeRight");
45 pp = add_bvh_name(pp, NI_R_ANKLE, "mAnkleRight");
46 pp = add_bvh_name(pp, NI_R_FOOT, "mFootRight");
47 pp = add_bvh_name(pp, NI_R_TOE, "mToeRight");
48
49 //
50 pp = add_bvh_name(pp, NI_PELVIS, "avatar_mPelvis");
51 pp = add_bvh_name(pp, NI_TORSO, "avatar_mTorso");
52 pp = add_bvh_name(pp, NI_CHEST, "avatar_mChest");
53 pp = add_bvh_name(pp, NI_NECK, "avatar_mNeck");
54 pp = add_bvh_name(pp, NI_HEAD, "avatar_mHead");
55 pp = add_bvh_name(pp, NI_SKULL, "avatar_mSkull");
56 pp = add_bvh_name(pp, NI_L_EYE, "avatar_mEyeLeft");
57 pp = add_bvh_name(pp, NI_R_EYE, "avatar_mEyeRight");
58 pp = add_bvh_name(pp, NI_L_COLLAR, "avatar_mCollarLeft");
59 pp = add_bvh_name(pp, NI_L_SHLDR, "avatar_mShoulderLeft");
60 pp = add_bvh_name(pp, NI_L_ELBOW, "avatar_mElbowLeft");
61 pp = add_bvh_name(pp, NI_L_WRIST, "avatar_mWristLeft");
62 pp = add_bvh_name(pp, NI_R_COLLAR, "avatar_mCollarRight");
63 pp = add_bvh_name(pp, NI_R_SHLDR, "avatar_mShoulderRight");
64 pp = add_bvh_name(pp, NI_R_ELBOW, "avatar_mElbowRight");
65 pp = add_bvh_name(pp, NI_R_WRIST, "avatar_mWristRight");
66 pp = add_bvh_name(pp, NI_L_HIP, "avatar_mHipLeft");
67 pp = add_bvh_name(pp, NI_L_KNEE, "avatar_mKneeLeft");
68 pp = add_bvh_name(pp, NI_L_ANKLE, "avatar_mAnkleLeft");
69 pp = add_bvh_name(pp, NI_L_FOOT, "avatar_mFootLeft");
70 pp = add_bvh_name(pp, NI_L_TOE, "avatar_mToeLeft");
71 pp = add_bvh_name(pp, NI_R_HIP, "avatar_mHipRight");
72 pp = add_bvh_name(pp, NI_R_KNEE, "avatar_mKneeRight");
73 pp = add_bvh_name(pp, NI_R_ANKLE, "avatar_mAnkleRight");
74 pp = add_bvh_name(pp, NI_R_FOOT, "avatar_mFootRight");
75 pp = add_bvh_name(pp, NI_R_TOE, "avatar_mToeRight");
76
77 // QAv
78 pp = add_bvh_name(pp, NI_PELVIS, "hip");
79 pp = add_bvh_name(pp, NI_TORSO, "abdomen");
80 pp = add_bvh_name(pp, NI_CHEST, "chest");
81 pp = add_bvh_name(pp, NI_NECK, "neck");
82 pp = add_bvh_name(pp, NI_HEAD, "head");
83 pp = add_bvh_name(pp, NI_L_COLLAR, "lCollar");
84 pp = add_bvh_name(pp, NI_L_SHLDR, "lShldr");
85 pp = add_bvh_name(pp, NI_L_ELBOW, "lForeArm");
86 pp = add_bvh_name(pp, NI_L_WRIST, "lHand");
87 pp = add_bvh_name(pp, NI_R_COLLAR, "rCollar");
88 pp = add_bvh_name(pp, NI_R_SHLDR, "rShldr");
89 pp = add_bvh_name(pp, NI_R_ELBOW, "rForeArm");
90 pp = add_bvh_name(pp, NI_R_WRIST, "rHand");
91 pp = add_bvh_name(pp, NI_L_HIP, "lThigh");
92 pp = add_bvh_name(pp, NI_L_KNEE, "lShin");
93 pp = add_bvh_name(pp, NI_L_FOOT, "lFoot");
94 pp = add_bvh_name(pp, NI_R_HIP, "rThigh");
95 pp = add_bvh_name(pp, NI_R_KNEE, "rShin");
96 pp = add_bvh_name(pp, NI_R_FOOT, "rFoot");
97
98 return lt;
99}
#define NI_PELVIS
#define NI_R_EYE
#define NI_R_TOE
#define NI_L_TOE
#define NI_SKULL
#define NI_L_EYE

References add_bvh_name, NI_CHEST, NI_HEAD, NI_L_ANKLE, NI_L_COLLAR, NI_L_ELBOW, NI_L_EYE, NI_L_FOOT, NI_L_HIP, NI_L_KNEE, NI_L_SHLDR, NI_L_TOE, NI_L_WRIST, NI_NECK, NI_NORML_JOINT_NUM, NI_PELVIS, NI_R_ANKLE, NI_R_COLLAR, NI_R_ELBOW, NI_R_EYE, NI_R_FOOT, NI_R_HIP, NI_R_KNEE, NI_R_SHLDR, NI_R_TOE, NI_R_WRIST, NI_SKULL, NI_TORSO, and NiJointName().

Referenced by CNiBVHTool::init(), and CNiFileTool::writeBVHFile().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ SetExLink()

bool SetExLink ( CExDocument * pdoc,
CExFrame * pfrm,
CExView * pviw,
CAppCallBack * papp )

bool jbxwl::SetExLink(CExDocument* pdoc, CExFrame* pfrm, CExView* pviw, CAppCallBack* papp)

各オブジェクト間の関連付けを行う.

Definition at line 18 of file ExClass.cpp.

19{
20 if (pdoc==NULL) return false;
21 if (pfrm==NULL) return false;
22 if (pviw==NULL) return false;
23
24 pdoc->pView = pfrm->pView = pviw;
25 pdoc->pFrame = pviw->pFrame = pfrm;
26 pviw->pDoc = pfrm->pDoc = pdoc;
27 pviw->pApp = pfrm->pApp = pdoc->pApp = papp;
28 return true;
29}
CExFrame * pFrame
Definition ExDocument.h:56
CAppCallBack * pApp
Definition ExDocument.h:57
CAppCallBack * pApp
Definition ExFrame.h:43
CExFrame * pFrame
Definition ExView.h:77
CAppCallBack * pApp
Definition ExView.h:78
CExDocument * pDoc
Definition ExView.h:76

References CExDocument::pApp, CExFrame::pApp, CExView::pApp, CExFrame::pDoc, CExView::pDoc, CExDocument::pFrame, CExView::pFrame, CExDocument::pView, and CExFrame::pView.

Referenced by CreateDocFrmView().

Here is the caller graph for this function:

◆ setResourceLocale()

void setResourceLocale ( void )

Definition at line 429 of file WinTools.cpp.

430{
431 CString locale = LoadString_byID(IDS_STR_LOCALE);
432 _tsetlocale(LC_ALL, (LPCTSTR)locale);
433 return;
434}

References IDS_STR_LOCALE, and LoadString_byID().

Here is the call graph for this function:

◆ setSystemLocale()

void setSystemLocale ( LPCTSTR locale = _T(""))

Definition at line 437 of file WinTools.cpp.

438{
439 _tsetlocale(LC_ALL, locale);
440 return;
441}

◆ sjis_to_utf8()

Buffer sjis_to_utf8 ( void * ptr,
size_t len )

Definition at line 227 of file WinTools.cpp.

228{
229 // sjis -> unicode
230 int len_unic = MultiByteToWideChar(CP_THREAD_ACP, 0, (LPCCH)ptr, (int)len, NULL, 0);
231 wchar_t* buf_unic = new wchar_t[len_unic];
232 MultiByteToWideChar(CP_THREAD_ACP, 0, (LPCCH)ptr, (int)len + 1, buf_unic, len_unic);
233
234 // unicode -> utf-8
235 int len_utf8 = WideCharToMultiByte(CP_UTF8, 0, buf_unic, -1, NULL, 0, NULL, NULL);
236 Buffer buf_utf8 = make_Buffer(len_utf8);
237 WideCharToMultiByte(CP_UTF8, 0, buf_unic, len_unic, (LPSTR)buf_utf8.buf, len_utf8, NULL, NULL);
238
239 delete buf_unic;
240
241 buf_utf8.vldsz = len_utf8;
242 return buf_utf8;
243}

Referenced by sjis_to_utf8_byStr().

Here is the caller graph for this function:

◆ sjis_to_utf8_byStr()

Buffer sjis_to_utf8_byStr ( CString str)

Definition at line 216 of file WinTools.cpp.

217{
218 Buffer buf = init_Buffer();
219 if (str.IsEmpty()) return buf;
220
221 buf = sjis_to_utf8(CStringA(str).GetBuffer(), CStringA(str).GetLength());
222
223 return buf;
224}
Buffer sjis_to_utf8(void *ptr, size_t len)
Definition WinTools.cpp:227

References sjis_to_utf8().

Here is the call graph for this function:

◆ String2Buffer()

Buffer String2Buffer ( CString str)

Definition at line 24 of file WinTools.cpp.

25{
26 Buffer buf = make_Buffer(CStringA(str).GetLength());
27
28 copy_b2Buffer(CStringA(str).GetBuffer(), &buf, CStringA(str).GetLength());
29 return buf;
30}

◆ tc2Buffer()

Buffer tc2Buffer ( TCHAR * tchar,
int size = -1 )

Definition at line 34 of file WinTools.cpp.

35{
36 if (size<0) size = LDATA;
37 Buffer buf = make_Buffer(size);
38
39#ifdef _UNICODE
40 //setlocale(LC_ALL, ".UTF8");
41
42 size_t len;
43 int err = wcstombs_s(&len, (char*)buf.buf, buf.bufsz, tchar, _TRUNCATE);
44
45 if (err!=0) clear_Buffer(&buf);
46 else buf.vldsz = (int)Min(len-1, strlen((char*)buf.buf));
47 buf.state = err;
48#else
49 copy_s2Buffer(tchar, &buf);
50#endif
51
52 return buf;
53}

◆ ts2Buffer()

Buffer ts2Buffer ( LPCTSTR str,
int size = -1 )

Definition at line 56 of file WinTools.cpp.

57{
58 if (size<0) size = (int)tcslen(str);
59
60#ifdef _UNICODE
61 //setlocale(LC_ALL, ".UTF8");
62
63 Buffer buf = make_Buffer((size+1)*4);
64 size_t len;
65
66 int err = wcstombs_s(&len, (char*)buf.buf, buf.bufsz, str, _TRUNCATE);
67 if (err!=0) clear_Buffer(&buf);
68 else buf.vldsz = (int)Min(len-1, strlen((char*)buf.buf));
69 buf.state = err;
70#else
71 Buffer buf = make_Buffer(size);
72 copy_b2Buffer((char*)str, &buf, size);
73#endif
74
75 return buf;
76}

Referenced by get_dir_files_t(), and ts2mbs().

Here is the caller graph for this function:

◆ ts2mbs()

◆ utf8_to_sjis()

Buffer utf8_to_sjis ( void * ptr,
size_t len )

Definition at line 196 of file WinTools.cpp.

197{
198 // utf-8 -> unicode
199 int len_unic = MultiByteToWideChar(CP_UTF8, 0, (LPCCH)ptr, (int)len, NULL, 0);
200 wchar_t* buf_unic = new wchar_t[len_unic];
201 MultiByteToWideChar(CP_UTF8, 0, (LPCCH)ptr, (int)len + 1, buf_unic, len_unic);
202
203 // unicode -> sjis
204 int len_sjis = WideCharToMultiByte(CP_THREAD_ACP, 0, buf_unic, -1, NULL, 0, NULL, NULL);
205 Buffer buf_sjis = make_Buffer(len_sjis);
206 WideCharToMultiByte(CP_THREAD_ACP, 0, buf_unic, len_unic, (LPSTR)buf_sjis.buf, len_sjis, NULL, NULL);
207
208 delete buf_unic;
209
210 buf_sjis.vldsz = len_sjis;
211 return buf_sjis;
212}

Referenced by utf8_to_sjis_byStr().

Here is the caller graph for this function:

◆ utf8_to_sjis_byStr()

Buffer utf8_to_sjis_byStr ( CString str)

Definition at line 185 of file WinTools.cpp.

186{
187 Buffer buf = init_Buffer();
188 if (str.IsEmpty()) return buf;
189
190 buf = utf8_to_sjis(CStringA(str).GetBuffer(), CStringA(str).GetLength());
191
192 return buf;
193}
Buffer utf8_to_sjis(void *ptr, size_t len)
Definition WinTools.cpp:196

References utf8_to_sjis().

Here is the call graph for this function:

◆ VMD2NiJointNum()

int VMD2NiJointNum ( int joint)

VMDのジョイント番号から,共通ジョイントの番号を得る

Definition at line 142 of file NiVMDTool.cpp.

143{
144 if (joint<0 || joint>=VMD_JOINT_NUM) return -1;
145
146 return _VMD2NiJointNum[joint];
147}
static int _VMD2NiJointNum[]
#define VMD_JOINT_NUM
Definition NiVMDTool.h:11

References _VMD2NiJointNum, and VMD_JOINT_NUM.

Referenced by CNiVMDTool::getFramesData().

Here is the caller graph for this function:

◆ VMDJointName()

std::string VMDJointName ( int n)

std::string jbxwl::VMDJointName(int n)

VMDのジョイント番号から,MMDのジョイント名を得る

Definition at line 46 of file NiVMDTool.cpp.

47{
48 std::string str = "";
49
50 if (n>=0 && n<VMD_JOINT_NUM) {
51 str = _VMDJointName[n];
52 }
53
54 return str;
55}
static std::string _VMDJointName[]
Definition NiVMDTool.cpp:9

References _VMDJointName, and VMD_JOINT_NUM.

◆ VMDJointNum()

int VMDJointNum ( char * name)

int jbxwl::VMDJointNum(char* name)

MMDのジョイント名から,VMDのジョイント番号を得る

Definition at line 64 of file NiVMDTool.cpp.

65{
66 for (int i=0; i<VMD_JOINT_NUM; i++) {
67 if (!strcmp(name, _VMDJointName[i].c_str()) || !strcmp(name, _VMDJointName_eng[i].c_str())) {
68 return i;
69 }
70 }
71 return -1;
72}
static std::string _VMDJointName_eng[]
Definition NiVMDTool.cpp:26

References _VMDJointName, _VMDJointName_eng, and VMD_JOINT_NUM.

Referenced by CNiVMDTool::convert2FrameData().

Here is the caller graph for this function:

◆ WaitPidTerm()

BOOL WaitPidTerm ( int tm)

Definition at line 83 of file MFCTool.cpp.

84{
85 DWORD pid = 0;
86
87 for (int i=1; i<__argc; i++) {
88 if (!tcscmp(__targv[i], _T("/waitpid"))) {
89 if (i+1<__argc) {
90 pid = ttoi(__targv[i+1]);
91 break;
92 }
93 }
94 }
95 if (pid==0) return TRUE;
96
97 HANDLE hdl = OpenProcess(SYNCHRONIZE, FALSE, pid);
98 if (hdl!=NULL) {
99 if (WaitForSingleObject(hdl, tm*1000)==WAIT_TIMEOUT) return FALSE;
100 }
101
102 return TRUE;
103}

◆ WinSystem()

void WinSystem ( char * command,
DWORD flag,
BOOL wait )

Definition at line 818 of file WinTools.cpp.

819{
820 STARTUPINFOA sinfo;
821 PROCESS_INFORMATION pinfo;
822
823 memset(&sinfo, 0, sizeof(STARTUPINFO));
824 sinfo.cb = sizeof(STARTUPINFO);
825 //sinfo.wShowWindow = SW_HIDE;
826
827 CreateProcessA(NULL, (LPSTR)command, NULL, NULL, FALSE, flag, NULL, NULL, (LPSTARTUPINFOA)&sinfo, &pinfo);
828
829 CloseHandle(pinfo.hThread);
830 if (wait) WaitForSingleObject(pinfo.hProcess, INFINITE);
831 CloseHandle(pinfo.hProcess);
832
833 return;
834}

◆ writeGraphicFileWithCounter()

int writeGraphicFileWithCounter ( LPCTSTR fname,
MSGraph< sWord > vp,
int kind,
BOOL mlt = FALSE,
int fn = 0,
int tn = 0 )

Definition at line 131 of file MFCio.cpp.

132{
133 // グローバルカウンタの生成
134 CProgressBarDLG* counter = NULL;
135 if (vp.zs>=10) {
136 counter = new CProgressBarDLG(IDD_PROGBAR, NULL, TRUE); // ディスパッチャー有効
137 if (counter!=NULL) {
138 SetGlobalCounter(counter);
139 CString mesg;
140 mesg.LoadString(IDS_STR_WRTNG_FILE);
141 //
142 char* mbstr = ts2mbs(mesg);
143 counter->Start(0, mbstr);
144 ::free(mbstr);
145 }
146 }
147
148 //
149 char* mbstr = ts2mbs(fname);
150 int ret = writeGraphicFile(mbstr, vp, frmt, mlt, fn, tn, true);
151 ::free(mbstr);
152
153 // グローバルカウンタの削除
154 if (counter!=NULL) {
155 counter->Stop();
156 ClearGlobalCounter();
157 delete counter;
158 }
159
160 return ret;
161}

References IDD_PROGBAR, IDS_STR_WRTNG_FILE, CProgressBarDLG::Start(), CProgressBarDLG::Stop(), and ts2mbs().

Here is the call graph for this function:

Variable Documentation

◆ _Debug_SHM

CWinSharedMem * _Debug_SHM = NULL
extern

Definition at line 103 of file WinSMTool.cpp.

Referenced by close_shm_debuger(), and open_shm_debuger().

◆ Dx9DividePrimitiveMode

BOOL Dx9DividePrimitiveMode = TRUE
extern

Definition at line 20 of file Dx9.cpp.

Referenced by Dx9DrawPrimitive().

◆ Dx9ReverseZMode

BOOL Dx9ReverseZMode = FALSE
extern

Definition at line 21 of file Dx9.cpp.

Referenced by CDxSRenderView::OnInitialUpdate().

◆ GpD3D

LPDIRECT3D9 GpD3D = NULL
extern

Definition at line 13 of file Dx9.cpp.

Referenced by Dx9CreateInterface(), Dx9ReleaseInterface(), and CDxBaseView::InitDevice().

◆ GpDInput

LPDIRECTINPUT8 GpDInput = NULL
extern

Definition at line 14 of file Dx9.cpp.

Referenced by Dx9CreateInterface(), and Dx9ReleaseInterface().

◆ GpDKeyBoard

LPDIRECTINPUTDEVICE8 GpDKeyBoard = NULL
extern

Definition at line 17 of file Dx9.cpp.

Referenced by Dx9CreateInterface(), Dx9ReleaseInterface(), and CDxBaseView::InitDevice().

◆ GpDMouse

LPDIRECTINPUTDEVICE8 GpDMouse = NULL
extern

Definition at line 16 of file Dx9.cpp.

Referenced by Dx9CreateInterface(), Dx9ReleaseInterface(), and CDxBaseView::InitDevice().

◆ SetHeaderDLG

CSetHeaderDLG SetHeaderDLG
extern

Definition at line 18 of file ReadFilesDLG.cpp.

Referenced by CReadFilesDLG::OnSetHead(), and CRwGRDoc::ReadDataFile().

◆ TimerID

UINT TimerID = 1
extern

Definition at line 19 of file ExView.cpp.

Referenced by CExView::TimerStart().

◆ WinAudioToolBitsPerSample

const WORD WinAudioToolBitsPerSample = 16
static

Definition at line 33 of file WinAudioTool.h.

Referenced by CWinAudioTool::getAudioFormat().

◆ WinAudioToolChannels

const WORD WinAudioToolChannels = 1
static

Definition at line 31 of file WinAudioTool.h.

Referenced by CWinAudioTool::getAudioFormat().

◆ WinAudioToolFormat

const WORD WinAudioToolFormat = WAVE_FORMAT_PCM
static

Definition at line 30 of file WinAudioTool.h.

Referenced by CWinAudioTool::getAudioFormat().

◆ WinAudioToolSamplesPerSec

const DWORD WinAudioToolSamplesPerSec = 16000
static

Definition at line 32 of file WinAudioTool.h.

Referenced by CWinAudioTool::getAudioFormat().