Microsoft PowerPoint - animation

Size: px
Start display at page:

Download "Microsoft PowerPoint - animation"

Transcription

1 다이렉트 X 9.0 SDK 에서 제공하는 Skinned Animation 1

2 애니메이션 3 차원그래픽에서애니메이션이란메시나텍스처등의오브젝트를 3 차원공간에서움직이게하는것을통칭하는말이다. 일반적으로많이사용하는애니메이션기법 1. 버텍스애니메이션 (vertex animation) 2. 계층형애니메이션 (hierarchical animation) 3. 뼈대애니메이션 (bone based animation, skeletal animation) 4. 스키닝 (skinning) 5. 역운동학 (inverse kinematics) 키프레임애니메이션전체애니메이션중에서중요한몇개의프레임에애니메이션키값을등록하고, 나머지값들을자동생성하는애니메이션방식을말한다. 여기서의프레임이란애니메이션에서출력될장면한장한장을가리킨다고생각하면된다. 2

3 키프레임애니메이션 y 좌표 (-10,0,0) 좌표 (10,0,0) x z 1번재키프레임 보간생성된프레임 2번째키프레임 (Interpolated Frame) 1 번프레임 2 번프레임 3 번프레임 4 번프레임 5 번프레임 6 번프레임 좌표 (-10,0,0) 좌표 (-6,0,0) 좌표 (-2,0,0) 좌표 (2,0,0) 좌표 (6,0,0) 좌표 (10,0,0) 3

4 계층구조구현방법 계층구조는간단하게생각하면부모자식관계를구현하는것이다. 부모자식관계를 3D로구현한다는것은결국 3D적인표현수단을사용한다는것이고, 우리가알고있는 3D적인표현수단은행렬이있다. 정점의변환 V = V M world local transform TM = M transform 일때, Vworld = Vlocal TM 정점이계층구조일때, V world = Vlocal TM child TM parent 부모에해당하는행렬이여러개라면해당하는개수만큼곱해주면된다. 만약부모에해당하는행렬이 n개라면다음과같이처리한다. V = V TM TM TM L TM world local child parent ( n) parent ( n 1) parent (1) 4

5 계층구조의구현예 인간형태로모델링된메시 인간모델의트리구조 5

6 계층구조의실제구현 자식메시 구성요소 행렬명 기본변환 TM child 부모메시 Z 축회전부모행렬 R child M parent 부모최종행렬 M = R TM parent parent parent 구성요소 행렬명 기본변환 Y 축회전 TM parent R parent 자식최종행렬 M child = R = R child child TM TM child child M parent ( R TM ) parent parent 6

7 스키닝 과거의게임들은여러개의분할메시로되어있을경우메시와메시의연결부위가자연스럽게붙지않는관절끊김현상이있었다. 이러한관절끊김을막기위해서메시를단일한하나의메시로만들어버린것이그이후의방식이다. 그러나이방식은관절의끊김은막을수있었으나, 관절이자연스럽게이어지도록만들수는없었다. 그래서나온방법이가중치 (weight) 를사용한기법이다. 7

8 스키닝 애니메이션결과값비교 가중치없음 v = v M A 분할메시 A의 TM= B의 TM = M B 의가중치 = 의가중치 = M A M B M A W A W B 단일메시 & 가중치없음 A v B v 단일메시 & 가중치사용 가중치사용 v = v M W + v M W A A B B v 8

9 예제 소프트웨어스키닝 NonIndexed 스키닝 Indexed 스키닝적용 NoneIndexed 스키닝을가지고클래스를설계구현한예제분석 9

10 CPROD3DANIMESH 이라는클래스 : 만들어진스킨드메시를가지고애니메이션을제어하는클래스 CAllocateHierarchy 클래스 : 실제적으로애니메이션을셋팅하는클래스 10

11 CAllocateHierarchy 클래스는 CPROD3DANIMESH 클래스가생성될때한번, 소멸될때한번생성되어서본을셋팅하고메시컨테이너를셋팅하고소멸시키는역할을함 DXSDK 9.0 개발문서 원래 CAllocateHierarchy 는 ID3DXAllocateHierarchy 으로이미제공됨 CAllocateHierarchy 는 ID3DXAllocateHierarchy 을상속받아서새로만든자식클래스 원래 D3DXLoadMeshHierarchyFromX() 함수를호출할때인자로넘겨주는인터페이스임 11

12 D3DXLoadMeshHierarchyFromX - 상속받아서새로만들어서쓰는이유 D3DXLoadMeshHierarchyFromX loads the animation data and frame hierarchy from an.x file. It scans the.x file and builds a frame hierarchy and animation controller according to the ID3DXAllocateHierarchy-derived object passed to it through palloc. Loading the data requires several steps as follows: Derive ID3DXAllocateHierarchy, implementing each method. This controls how frames and meshes are allocated and freed. Derive ID3DXLoadUserData, implementing each method. If your.x file has no embedded user-defined data, or if you do not need it, you can skip this part. Create an object of your ID3DXAllocateHierarchy class, and optionally of your LoadUserData class. You do not need to call any methods of these objects yourself. Call D3DXLoadMeshHierarchyFromX, passing in your ID3DXAllocateHierarchy object and your ID3DXLoadUserData object (or NULL) to create the frame hierarchy and animation controller. All the animation sets and frames are automatically registered to the animation controller. 12

13 D3DXLoadMeshHierarchyFromX 원래상속받아서쓰는인터페이스임 즉, 원형만만들어놓은추상클래스임 프로그래머가상속받아서이용 스키닝방법이나기타모든것에자유를주면서, 일정한형식을갖추도록한것임 그목적은 ID3DXAnimationController 라는인터페이스와데이터가묶이도록하기위해서임 즉, CAllocateHierarchy 클래스를제대로만들면애니메이션을다구현했다는것을의미 *.X 파일을읽어오는 D3DXLoadMeshHierarchyFromX() 가이클래스로만든객체의포인터를받아서실제로프레임정보와메시컨테이너를만들때 CAllocateHierarchy 에있는함수를사용하기때문에사용 지울때도 CAllocateHierarchy 에있는 DestroyFrame() 함수와 DestroyMeshContainer() 함수를사용함 13

14 AllocateName() class CAllocateHierarchy: public ID3DXAllocateHierarchy // // Name: AllocateName() - Global // Desc: Allocates memory for a string to hold the name of a frame or mesh // HRESULT AllocateName( LPCTSTR Name, LPTSTR *pnewname ) UINT cblength; if (Name!= NULL) cblength = lstrlen(name) + 1; *pnewname = new TCHAR[cbLength]; if (*pnewname == NULL) return E_OUTOFMEMORY; memcpy(*pnewname, Name, cblength*sizeof(tchar)); else *pnewname = NULL; return S_OK; 뼈 ( 프레임 ) 에이름을넣어주는함수임 3DsMax 같은데서디자인할때뼈에이름을심어주는데, 그이름을인자로받아와서새로들어간본구조체안의이름에동적메모리를할당해서이름을넣어주는역할 14

15 CAllocateHierarchy // // Name: class CAllocateHierarchy // Desc: Custom version of ID3DXAllocateHierarchy with custom methods to create // frames and meshcontainers. // class CAllocateHierarchy: public ID3DXAllocateHierarchy public: STDMETHOD(CreateFrame)(THIS_ LPCTSTR Name, LPD3DXFRAME *ppnewframe); STDMETHOD(CreateMeshContainer)(THIS_ LPCTSTR Name, LPD3DXMESHDATA pmeshdata, LPD3DXMATERIAL pmaterials, LPD3DXEFFECTINSTANCE peffectinstances, DWORD NumMaterials, DWORD *padjacency, LPD3DXSKININFO pskininfo, LPD3DXMESHCONTAINER *ppnewmeshcontainer); STDMETHOD(DestroyFrame)(THIS_ LPD3DXFRAME pframetofree); STDMETHOD(DestroyMeshContainer)(THIS_ LPD3DXMESHCONTAINER pmeshcontainerbase); CAllocateHierarchy( CPROD3DANIMESH* m_papp) :m_pobject(pobject) public: CPROD3DANIMESH* m_papp; ; public: CPROD3DANIMESH* m_papp; 이클래스가생성될때애니메이션객체의포인터를넘겨줘서... 그포인터를사용해서애니메이션클래스에접근을함 15

16 // // Name: CAllocateHierarchy::CreateFrame() // Desc: making new frame by got name and pointing new frame pointer // HRESULT CAllocateHierarchy::CreateFrame( LPCTSTR Name, LPD3DXFRAME *ppnewframe ) HRESULT hr = S_OK; D3DXFRAME_DERIVED *pframe; *ppnewframe = NULL; pframe = new D3DXFRAME_DERIVED; if( pframe == NULL ) hr = E_OUTOFMEMORY; delete pframe; return hr; hr = AllocateName( Name, &pframe->name ); // 위에나왔던 AllocateName() 전역함수. if( FAILED(hr) ) delete pframe; return hr; // Initialize other data member of the frame D3DXMatrixIdentity( &pframe->combinedtransformationmatrix ); D3DXMatrixIdentity( &pframe->transformationmatrix ); pframe->pmeshcontainer = NULL; pframe->pframefirstchild = NULL; pframe->pframesibling = NULL; *ppnewframe = pframe; pframe = NULL; return S_OK; 새로운프레임 - 뼈를만들어주는함수 : 인자로이름을받고, 프레임구조체형의더블포인터를받아서새로메모리를할당해서프레임을생성해주고포인터를연결해줌. 그프레임안에있는각종값들을초기화시킴. 프레임전체를트리구조로꾸미기위한준비작업 ( 뼈전체가트리구조 ) 16

17 CombinedTransformationMatrix // // Name: struct D3DXFRAME_DERIVED // Desc: Structure derived from D3DXFRAME so we can add some app-specific // info that will be stored with each frame // struct D3DXFRAME_DERIVED: public D3DXFRAME D3DXMATRIXA16 CombinedTransformationMatrix; ; CombinedTransformationMatrix : 누적된행렬정보 예 : 이프레임이손끝의프레임이라고한다면, 이행렬정보에는어깨의회전값, 팔의회전값, 손목의회전값이누적되어들어가게됨 ( 손끝의회전은손목을기준으로돌아가기때문 ) 17

18 D3DXFRAME 이구조체의부모클래스인 D3DXFRAME typedef struct _D3DXFRAME LPTSTR Name; // 프레임이름 D3DXMATRIX TransformationMatrix; // 변환행렬정보 LPD3DXMESHCONTAINER pmeshcontainer; // 메시컨테이너포인터 struct _D3DXFRAME *pframesibling; // 형제프레임의포인터 struct _D3DXFRAME *pframefirstchild; // 자식프레임의포인터 D3DXFRAME, *LPD3DXFRAME; 트리구조를위한형제, 자식의포인터와프레임이름과.. 자신의변환행렬정보.. 메시컨테이너의포인터가있음 LPD3DXMESHCONTAINER : 메시를담고있는컨테이너구조체 18

19 LPD3DXMESHCONTAINER LP : long pointer (4 바이트 ) LPD3DXMESHCONTAINER pmeshcontainer; // 메시컨테이너포인터라고선언되었듯이 D3DXMESHCONTAINER 구조체의포인터형임 19

20 D3DXMESHCONTAINER Structure Encapsulates a mesh object in a transformation frame hierarchy. typedef struct _D3DXMESHCONTAINER LPTSTR Name; // 메시의이름 D3DXMESHDATA MeshData; // 메시데이터구조체 LPD3DXMATERIAL pmaterials; // 메시의메터리얼정보구조체의포인터 LPD3DXEFFECTINSTANCE peffects; // EffectInstance 구조체의포인터 DWORD NumMaterials; // 메터리얼갯수 DWORD *padjacency; // 인접정보를갖고있는 DWORD형의삼각형하 // 나당 3개의배열의포인터. LPD3DXSKININFO pskininfo; // 스킨정보를가지고있는 // ID3DXSKININFO 인터페이스의포인터 struct _D3DXMESHCONTAINER *pnextmeshcontainer; // 링크드리스트.. D3DXMESHCONTAINER, *LPD3DXMESHCONTAINER; 20

21 typedef struct D3DXMESHDATA D3DXMESHDATATYPE Type; // 메시의타입. union LPD3DXMESH pmesh; // 일반적인메시의포인터 LPD3DXMESH ppmesh; // 프로그레시브메시의포인터 LPD3DXPATCHMESH ppatchmesh; // 패치메시 (..?) 의포인터 D3DXMESHDATA, *LPD3DXMESHDATA; typedef enum D3DXMESHDATATYPE D3DXMESHTYPE_MESH = 0x001, D3DXMESHTYPE_PMESH = 0x002, D3DXMESHTYPE_PATCHMESH = 0x003, D3DXEDT_FORCE_DWORD = 0x7fffffff D3DXMESHDATATYPE; 21

22 D3DXMESHCONTAINER_DERIVED // // Name: struct D3DXMESHCONTAINER_DERIVED // Desc: Structure derived from D3DXMESHCONTAINER so we can add some app-specific // info that will be stored with each mesh // struct D3DXMESHCONTAINER_DERIVED: public D3DXMESHCONTAINER LPDIRECT3DTEXTURE9* pptextures; // array of textures, entries are NULL if no texture specified // SkinMesh info LPD3DXMESH porigmesh; // 원래메시의임시저장을위한.. LPD3DXATTRIBUTERANGE pattributetable; // 메시의속성테이블구조체. DWORD NumAttributeGroups; // 속성갯수. DWORD NumInfl; // 이디바이스가최대한블랜딩할수있는매트릭스갯수 LPD3DXBUFFER pbonecombinationbuf;// 본콤비네이션버퍼 D3DXMATRIX** ppbonematrixptrs; // 프레임에저장되어있는변환매트릭스들의배열의포인터. D3DXMATRIX* pboneoffsetmatrices;// 본의위치를담아둘매트릭스배열의포인터. DWORD NumPaletteEntries; // 행렬팔렛트엔트리.. NonIndexed에선사용되지않음. bool UseSoftwareVP; // 소프트웨어버텍스프로세싱사용? DWORD iattributesw; // used to denote the split between SW and HW if necessary for non-indexed skinning // 즉, Mixed 에서 SW와 HW 버텍스프로세싱을사용할때 // 나누기위한정보를저장하기위한변수. ; 스킨드애니메이션을위해서좀더필요한정보를저장하기위해서메시컨테이너를상속받아확장시킨구조체 속성 : 메시가나눠지는것 텍스쳐를기준으로나눠짐 : 매핑소스가 1개면메시가한덩어리 22 tiny.x는매핑소스가 1개이므로속성테이블의갯수도 1개

23 CreateMeshContainer HRESULT CAllocateHierarchy::CreateMeshContainer( LPCTSTR Name, LPD3DXMESHDATA pmeshdata, LPD3DXMATERIAL pmaterials, LPD3DXEFFECTINSTANCE peffectinstances, DWORD NumMaterials, DWORD *padjacency, LPD3DXSKININFO pskininfo, LPD3DXMESHCONTAINER *ppnewmeshcontainer ) 메시컨테이너를만들어주는함수 받는인자들은모두 D3DXMESHCONTAINER 구조체속에모두있는것들임 23

24 HRESULT hr; D3DXMESHCONTAINER_DERIVED *pmeshcontainer = NULL; // 임시로사용할메시컨테이너의포인터 UINT NumFaces; // 삼각형면의갯수 UINT imaterial; // 메터리얼갯수 UINT ibone, cbones; // 본의갯수, 본카운트임시변수 LPDIRECT3DDEVICE9 pd3ddevice = NULL; // 임시로받아둘디바이스의포인터 LPD3DXMESH pmesh = NULL; // 임시로사용할메시 24

25 *ppnewmeshcontainer = NULL; // this sample does not handle patch mesh, so fail when one is found if( pmeshdata->type!= D3DXMESHTYPE_MESH ) // 종료루틴 SAFE_RELEASE(pd3dDevice); // call Destroy function to properly clean up the memory allocated if (pmeshcontainer!= NULL) DestroyMeshContainer(pMeshContainer); return E_FAIL; 더블포인터형으로받은메시컨테이너의포인터를초기화시키는작업 메시타입이 D3DXMESHTYPE_MESH ( 일반적인메시 ) 가아니라면함수를끝내버리는일을함 25

26 // get the pmesh interface pointer out of the mesh data structure pmesh = pmeshdata->pmesh; // this sample does not FVF compatible meshes, so fail when one is found if( pmesh->getfvf() == 0 ) // 종료루틴생략 return E_FAIL; // allocate the overloaded structure to return as a D3DXMESHCONTAINER pmeshcontainer = new D3DXMESHCONTAINER_DERIVED; if( pmeshcontainer == NULL ) // 종료루틴생략 return E_OUTOFMEMORY; memset( pmeshcontainer, 0, sizeof(d3dxmeshcontainer_derived) ); // make sure and copy the name. All memory as input belongs to caller, interfaces can be addref'd though hr = AllocateName( Name, &pmeshcontainer->name ); if( FAILED(hr) ) // 종료루틴생략 return E_FAIL; 그리고나서, 임시로만들었던 pmesh 메시포인터에인자로넘어온메시데이터안에있는메시의포인터를그대로물려줌 FVF 가제대로있는지검사를하고메시컨테이너를하나동적으로생성 생성못하면그냥종료 만들어진구조체를초기화시킨후 AllocateName() 전역함수로생성된메시컨테이너안에인자로받았던이름을달아줌 26

27 pmesh->getdevice( &pd3ddevice ); NumFaces = pmesh->getnumfaces(); // if no normals are in the mesh, add them if(!(pmesh->getfvf() & D3DFVF_NORMAL) ) pmeshcontainer->meshdata.type = D3DXMESHTYPE_MESH; // clone the mesh to make room for the normals; hr = pmesh->clonemeshfvf( pmesh->getoptions(), pmesh->getfvf() D3DFVF_NORMAL, pd3ddevice, &pmeshcontainer->meshdata.pmesh ); if( FAILED(hr) ) // 종료루틴생략 return E_FAIL; else // get the new pmesh pointer back out of the mesh container use // NOTE: we do not release pmesh because we don't have a reference to it yet pmesh = pmeshcontainer->meshdata.pmesh; // now generate the normal for the pmesh D3DXComputeNormals( pmesh, NULL ); // if no normals, just add a reference to the mesh for mesh container pmeshcontainer->meshdata.pmesh = pmesh; pmeshcontainer->meshdata.type = D3DXMESHTYPE_MESH; // Increases the interface's reference count by 1. pmesh->addref(); // allocate memory to contain the meterial information. This sample uses // the D3D9 materials and texture names instead of the EffectInstance style materials pmeshcontainer->nummaterials = max( 1, NumMaterials ); pmeshcontainer->pmaterials = new D3DXMATERIAL[ pmeshcontainer->nummaterials ]; pmeshcontainer->pptextures = new LPDIRECT3DTEXTURE9[ pmeshcontainer->nummaterials ]; pmeshcontainer->padjacency = new DWORD[ NumFaces*3 ]; if( (pmeshcontainer->padjacency == NULL) (pmeshcontainer->pmaterials == NULL) ) // 종료루틴생략. return E_OUTOFMEMORY; pmesh로인터페이스에접근을해서디바이스를하나얻어옴 폴리곤수를따로저장 FVF를체크하는데, 만약에 NORMAL값이없는메시라면 CloneMeshFVF 함수를사용해서빛이들어간 FVF로설정된메시를새로복사해서만들어냄 새로생성되었던지금만들고있는메시컨테이너안의즉, pmeshcontainer->meshdata.pmesh 안에새로클론된메시를집어넣음 27

28 pmesh->addref() IUnknown 이라는클래스는 AddRef() QueryInterface() Release() 이세가지를멤버함수로가지고있음 따라서다이렉트 X 의모든인터페이스는저 3 가지함수를공통으로가지고있습니다. Release() 는자주쓰는것 Release() 와반대되는개념이 AddRef() 내부적으로레퍼런스카운트라고있는데 레퍼런스카운트가 0 이되어야만비로소진짜메모리에서릴리즈가됨 Release() 는레퍼런스카운트를하나줄여줌 28

29 // allocate memory to contain the meterial information. This sample uses // the D3D9 materials and texture names instead of the EffectInstance style materials pmeshcontainer->nummaterials = max( 1, NumMaterials ); pmeshcontainer->pmaterials = new D3DXMATERIAL[ pmeshcontainer->nummaterials ]; pmeshcontainer->pptextures = new LPDIRECT3DTEXTURE9[ pmeshcontainer->nummaterials ]; pmeshcontainer->padjacency = new DWORD[ NumFaces*3 ]; if( (pmeshcontainer->padjacency == NULL) (pmeshcontainer->pmaterials == NULL) ) // 종료루틴생략. return E_OUTOFMEMORY; memcpy( pmeshcontainer->padjacency, padjacency, sizeof(dword)*numfaces*3 ); memset( pmeshcontainer->pptextures, 0, sizeof(lpdirect3dtexture9)*pmeshcontainer->nummaterials ); // if materials provided, copy them if( NumMaterials > 0 ) memcpy( pmeshcontainer->pmaterials, pmaterials, sizeof(d3dxmaterial)*nummaterials ); for( imaterial = 0; imaterial < NumMaterials; imaterial++ ) // texture loading.. if( pmeshcontainer->pmaterials[ imaterial ].ptexturefilename!= NULL ) TCHAR strtexturepath[ MAX_PATH ] = ""; DXUtil_FindMediaFileCb( strtexturepath, sizeof(strtexturepath), pmeshcontainer->pmaterials[ imaterial ].ptexturefilename ); if( FAILED( D3DXCreateTextureFromFile( pd3ddevice, strtexturepath, &pmeshcontainer->pptextures[ imaterial ] ) ) ) pmeshcontainer->pptextures[ imaterial ] = NULL; // don't remember a pointer into the dynamic memory, just forget the name after loading pmeshcontainer->pmaterials[ imaterial ].ptexturefilename = NULL; else // if no materials provided, use a default one pmeshcontainer->pmaterials[ 0 ].ptexturefilename = NULL; memset( &pmeshcontainer->pmaterials[ 0 ].MatD3D, 0, sizeof(d3dmaterial9) ); pmeshcontainer->pmaterials[ 0 ].MatD3D.Diffuse.r = 0.5f; pmeshcontainer->pmaterials[ 0 ].MatD3D.Diffuse.g = 0.5f; pmeshcontainer->pmaterials[ 0 ].MatD3D.Diffuse.b = 0.5f; pmeshcontainer->pmaterials[ 0 ].MatD3D.Specular = pmeshcontainer->pmaterials[ 0 ].MatD3D.Diffuse; 메시컨테이너안에서메터리얼의갯수와텍스쳐, 기타메시에필요한정보들의공간만 new 로확보해놓음 adjacency 정보는인자로들어온값을그대로카피 텍스쳐포인터배열은 0으로초기화, 매터리얼갯수가 0이넘으면즉, 매터리얼이존재한다면인자로넘어온메터리얼구조체를또그대로카피 텍스쳐이름을체크해서텍스쳐를생성해주고이름이있던자리엔 NULL을넣어줌 만약매터리얼이없다면메터리얼에디폴트값들을넣어줌 29

30 // 스킨정보가있을때실행 // if there is skinning information, save off the required data and then setup for HW skinning if( pskininfo!= NULL ) // first save off the skininfo and original mesh data pmeshcontainer->pskininfo = pskininfo; pskininfo->addref(); pmeshcontainer->porigmesh = pmesh; UINT temp = pmesh->addref(); // Will need an array of offset matrices to move vertices from the figure space to the bone's space cbones = pskininfo->getnumbones(); pmeshcontainer->pboneoffsetmatrices = new D3DXMATRIX[ cbones ]; if( pmeshcontainer->pboneoffsetmatrices == NULL ) // 종료루틴생략. return E_FAIL; // get each of the bone offset matrices so that we don't need to get them later for( ibone = 0; ibone < cbones; ++ibone ) pmeshcontainer->pboneoffsetmatrices[ ibone ] = *(pmeshcontainer->pskininfo- >GetBoneOffsetMatrix(iBone) ); // GenerateSkinniedMesh Will take general skinning information and transform it to a HW friendly version hr = m_papp->generateskinnedmesh( pmeshcontainer ); if( FAILED(hr) ) // 종료루틴생략. return E_FAIL; 스킨정보의포인터를복사해주면서또 AddRef() 로레퍼런스카운트를늘려줌 pmeshcontainer->pskininfo 를나중에따로릴리즈하기때문 메시컨테이너의오리지날메시에 pmesh 포인터를또복사해주면서레퍼런스카운트를늘려줌 pmeshcontainer->porigmesh 를따로릴리즈해주기때문 메시컨테이너안에본오프셋매트릭스 ( 프레임의원래위치 ) 를셋팅해주기위해서스킨정보인터페이스안에저장되어있는뼈의갯수를얻어옴 뼈의갯수만큼 for 문을돌면서뼈의번호에따라서메시컨테이너안에있는본오프셋매트릭스를저장 CPROD3DANIMESH* m_papp 포인터를이용해서 GenerateSkinnedMesh() 함수를호출 메시컨테이너안에있는메시데이터안의메시를스킨정보가들어간메시로바꿔주는일을함 30

31 *ppnewmeshcontainer = pmeshcontainer; pmeshcontainer = NULL; SAFE_RELEASE(pd3dDevice); // call Destroy function to properly clean up the memory allocated if (pmeshcontainer!= NULL) DestroyMeshContainer(pMeshContainer); return S_OK; 완성된메시컨테이너의포인터를인자로받은더블포인터를사용해연결시켜준다음에 pd3ddevice 를릴리즈 31

32 // // Name: CAllocateHierarchy::DestroyFrame() // Desc: Destroy Frame // HRESULT CAllocateHierarchy::DestroyFrame( LPD3DXFRAME pframetofree ) // first, delete string of name. it will be leak the memory, if you do not this work.. SAFE_DELETE_ARRAY( pframetofree->name ); SAFE_DELETE( pframetofree ); return S_OK; // // Name: CAllocateHierarchy::DestroyMeshContainer() // Desc: Destroy mesh container // HRESULT CAllocateHierarchy::DestroyMeshContainer( LPD3DXMESHCONTAINER pmeshcontainerbase ) UINT imaterial; D3DXMESHCONTAINER_DERIVED *pmeshcontainer = (D3DXMESHCONTAINER_DERIVED *)pmeshcontainerbase; SAFE_DELETE_ARRAY( pmeshcontainer->name ); SAFE_DELETE_ARRAY( pmeshcontainer->padjacency ); SAFE_DELETE_ARRAY( pmeshcontainer->pmaterials ); SAFE_DELETE_ARRAY( pmeshcontainer->pboneoffsetmatrices ); // release all the allocated textures if( pmeshcontainer->pptextures!= NULL ) for( imaterial = 0; imaterial < pmeshcontainer->nummaterials; ++imaterial ) SAFE_RELEASE( pmeshcontainer->pptextures[ imaterial ] ); SAFE_DELETE_ARRAY( pmeshcontainer->pptextures ); SAFE_DELETE_ARRAY( pmeshcontainer->ppbonematrixptrs ); SAFE_RELEASE( pmeshcontainer->pbonecombinationbuf ); SAFE_RELEASE( pmeshcontainer->meshdata.pmesh ); SAFE_RELEASE( pmeshcontainer->pskininfo ); SAFE_RELEASE( pmeshcontainer->porigmesh ); SAFE_DELETE( pmeshcontainer ); return S_OK; 32

33 HRESULT CPROD3DANIMESH::LoadSKNMesh(char * szfilename) HRESULT hr; CAllocateHierarchy Alloc(this); if(m_ppdevice == NULL) MessageBox(NULL, "NULL Device?", "ERROR", MB_OK); return FALSE; hr = D3DXLoadMeshHierarchyFromX(szFileName, D3DXMESH_MANAGED, m_ppdevice, &Alloc, NULL, &m_pframeroot, &m_panimcontroller); if(hr == D3DERR_INVALIDCALL) MessageBox(NULL, "The method call is invalid.", "ERROR", MB_OK); return FALSE; if(hr == E_OUTOFMEMORY) MessageBox(NULL, "not sufficient memory to complete the call.", "ERROR", MB_OK); return FALSE; hr = SetupBoneMatrixPointers(m_pFrameRoot); return TRUE; D3DXLoadMeshHierarchyFromX() 함수를호출 D3DXMESH_MANAGED 라는것은메시의버텍스버퍼와인덱스버퍼의메모리풀을 D3DPOOL_MANAGED 로사용 D3DPOOL_MANAGED 는데이타가시스템메모리와비디오카드메모리를왔다갔다하며알아서 D3D 가관리 D3DPOOL_DEFAULT 는오로지비디오카드메모리에만데이타가있겠다고하는것임 D3DPOOL_SYSTEMMEM 는오로지시스템메모리에만데이터를두겠다는것임 MANAGED 는디바이스를잃더라도알아서관리를해주기때문에편한반면, 시스템메모리와비디오메모리간에왔다갔다하기때문에약간의속도가저하 D3DPOOL_DEFAULT 는비디오메모리에만있어서속도는빠르지만디바이스를잃어버리면프로그래머가수동적으로데이터를 Restore 시켜줘야하는단점이있음 SetUpBoneMatrixPointers( m_pframeroot ); // 본매트릭스들을생성해서트리로꾸며진뼈에매트릭스들을달아주는일을함 33

34 GenerateSkinnedMesh() HRESULT hr = S_OK; // 스킨정보가없으면리턴 if( pmeshcontainer->pskininfo == NULL ) return hr; SAFE_RELEASE( pmeshcontainer->meshdata.pmesh ); SAFE_RELEASE( pmeshcontainer->pbonecombinationbuf ); hr = pmeshcontainer->pskininfo->converttoblendedmesh( pmeshcontainer->porigmesh, D3DXMESH_MANAGED D3DXMESHOPT_VERTEXCACHE, pmeshcontainer->padjacency, NULL, NULL, NULL, &pmeshcontainer->numinfl, &pmeshcontainer->numattributegroups, &pmeshcontainer->pbonecombinationbuf, &pmeshcontainer->meshdata.pmesh ); // 실패하면바로리턴. if( FAILED(hr) ) return hr; CAllocateMeshContainer::CreateMeshContainer() 함수안에서마지막에호출했던함수스킨정보가있는지검사. 없으면바로리턴메시컨테이너의메시데이터안에있는메시를릴리즈시키고, 본콤비네이션버퍼를없앰 ConvertToBlendMesh() 오리지날메시를받아서약간의옵션을정해준뒤메시컨테이너의여러정보들을채워줌메시도새로생성 : 원래메시가있던자리를밀어내고새로생성되니까.. 메모리누수가생기기전에미리릴리즈본콤비네이션 : 각각의 Attribute 에맞는 BoneID 를가지고있는것 ( 나중에그릴때사용 ) 34

35 // 디바이스캡에맞지않은본콤비네이션셋을찾는다. for( pmeshcontainer->iattributesw = 0; pmeshcontainer->iattributesw < pmeshcontainer->numattributegroups; ++pmeshcontainer->iattributesw ) DWORD cinfl = 0; for( DWORD iinfl = 0; iinfl < pmeshcontainer->numinfl; iinfl++ ) if( rgbonecombinations[ pmeshcontainer->iattributesw ].BoneId[ iinfl ]!= UINT_MAX ) ++cinfl; if( cinfl > m_d3dcaps.maxvertexblendmatrices ) break; 소프트웨어버텍스프로세싱을해줄갯수를정해주는것임 tiny.x 에서는 31개의본콤비네이션이있음 35

36 DrawMeshContainer() 함수 // first, check for skinning if( pmeshcontainer->pskininfo!= NULL ) AttribIdPrev = UNUSED32; pbonecomb = reinterpret_cast<lpd3dxbonecombination>(pmeshcontainer- >pbonecombinationbuf->getbufferpointer()); // Draw using default vertex processing of the device (typically HW) for( iattrib = 0; iattrib < pmeshcontainer->numattributegroups; ++iattrib ) NumBlend = 0; for( DWORD i = 0; i < pmeshcontainer->numinfl; ++i ) // 현재뼈에서블랜딩할매트릭스갯수를정확히지정해주는것 if( pbonecomb[ iattrib ].BoneId[ i ]!= UINT_MAX ) NumBlend = i; 36

37 // If necessary, draw parts that HW could not handle using SW if( pmeshcontainer->iattributesw < pmeshcontainer->numattributegroups ) AttribIdPrev = UNUSED32; m_pd3ddevice->setsoftwarevertexprocessing( TRUE ); for( iattrib = pmeshcontainer->iattributesw; iattrib < pmeshcontainer->numattributegroups; ++iattrib ) NumBlend = 0; for( DWORD i = 0; i < pmeshcontainer->numinfl; ++i ) if( pbonecomb[ iattrib ].BoneId[ i ]!= UINT_MAX ) NumBlend = i; if( m_d3dcaps.maxvertexblendmatrices < NumBlend+1 ) // first calculate the world matrices for the current set of blend weights and get the accurate // count of the number of blends for( DWORD i = 0; i < pmeshcontainer->numinfl; ++i ) if( imatrixindex!= UINT_MAX ) D3DXMatrixMultiply( &mattemp, &pmeshcontainer->pboneoffsetmatrices[ imatrixindex ], pmeshcontainer->ppbonematrixptrs[ imatrixindex ] ); m_pd3ddevice->settransform( D3DTS_WORLDMATRIX( i ), &mattemp ); m_pd3ddevice->setrenderstate( D3DRS_VERTEXBLEND, NumBlend ); // Lookup the material used this subset of faces if( (AttribIdPrev!= pbonecomb[ iattrib ].AttribId) (AttribIdPrev == UNUSED32) ) m_pd3ddevice->setmaterial( &pmeshcontainer- >pmaterials[ pbonecomb[ iattrib ].AttribId ].MatD3D ); m_pd3ddevice->settexture( 0, pmeshcontainer->pptextures[ pbonecomb[ iattrib ].AttribId ] ); AttribIdPrev = pbonecomb[ iattrib ].AttribId; // draw the subset now that the correct material and matrices are loaded pmeshcontainer->meshdata.pmesh->drawsubset( iattrib ); m_pd3ddevice->setsoftwarevertexprocessing( FALSE ); m_pd3ddevice->setrenderstate( D3DRS_VERTEXBLEND, 0 ); 37

38 // // Name: DrawFrame() // Desc: Called to render a frame in the hierarchy // HRESULT DrawFrame(LPD3DXFRAME pframe) LPD3DXMESHCONTAINER pmeshcontainer; pmeshcontainer = pframe->pmeshcontainer; while( pmeshcontainer!= NULL ) DrawMeshContainer( pmeshcontainer, pframe ); pmeshcontainer = pmeshcontainer->pnextmeshcontainer; if( pframe->pframesibling!= NULL ) DrawFrame( pframe->pframesibling ); if( pframe->pframefirstchild!= NULL ) DrawFrame( pframe->pframefirstchild ); return S_OK; 현재있는메시컨테이너를모두그려준후에, 그밑에 if 문으로가서형제프레임이있는지검사만약존재한다면자기자신을또호출. 그런식으로계속깊게깊게들어가다보면결국자신과동등한트리깊이를가지고있는메시컨테이너들은다그리게됨 38

39 FrameMove - 애니메이션컨트롤러 : 시간을받아옴. 이시간은애니메이션되는정도를의미 39

40 // // Name: SetupBoneMatrixPointers() // Desc: Called to setup the pointers for a given bone to its transformation matrix // HRESULT CPROD3DANIMESH::SetupBoneMatrixPointersOnMesh(LPD3DXMESHCONTAINER pmeshcontainerbase) UINT ibone, cbones; D3DXFRAME_DERIVED *pframe; D3DXMESHCONTAINER_DERIVED *pmeshcontainer = (D3DXMESHCONTAINER_DERIVED*)pMeshContainerBase; // if there is skinned mesh, then setup the bone matrices if( pmeshcontainer->pskininfo!= NULL ) cbones = pmeshcontainer->pskininfo->getnumbones(); pmeshcontainer->ppbonematrixptrs = new D3DXMATRIX*[ cbones ]; if( pmeshcontainer->ppbonematrixptrs == NULL ) return E_OUTOFMEMORY; for( ibone = 0; ibone < cbones; ibone++ ) pframe = (D3DXFRAME_DERIVED*)D3DXFrameFind( m_pframeroot, pmeshcontainer- >pskininfo->getbonename(ibone) ); if( pframe == NULL ) return E_FAIL; pmeshcontainer->ppbonematrixptrs[ ibone ] = &pframe->combinedtransformationmatrix; return S_OK; 메시컨테이너에매트릭스를달아주는함수 DrawMeshContainer() 에서그려줄때 BoneID 로행렬을찾아줌 : 그배열을생성 스킨정보로전체뼈의갯수를얻어옴그개수대로매트릭스배열을동적메모리할당을해서만들어냄 40 뼈의갯수대로루프를돌며 D3DXFrameFind() 함수를사용하여뼈를이름으로찾아내고그프레임의최종변환행렬의포인터를배열에물려줌

41 // // Name: SetupBoneMatrixPointers() // Desc: Called to setup the pointers for a given bone to its transformation matrix // HRESULT CPROD3DANIMESH::SetupBoneMatrixPointers(LPD3DXFRAME pframe) HRESULT hr; if( pframe->pmeshcontainer!= NULL ) hr = SetUpBoneMatrixPointersOnMesh( pframe->pmeshcontainer ); if( FAILED(hr) ) return hr; if( pframe->pframesibling!= NULL ) hr = SetUpBoneMatrixPointers( pframe->pframesibling ); if( FAILED(hr) ) return hr; if( pframe->pframefirstchild!= NULL ) hr = SetUpBoneMatrixPointers( pframe->pframefirstchild ); if( FAILED(hr) ) return hr; 트리구조의뼈를돌면서메시컨테이너에최종변환매트릭스를할당하고물려줌 41

42 void CPROD3DANIMESH::UpdateFrameMatrices(LPD3DXFRAME pframebase, LPD3DXMATRIX pparentmatrix) D3DXFRAME_DERIVED *pframe = (D3DXFRAME_DERIVED*)pFrameBase; if( pparentmatrix!= NULL ) D3DXMatrixMultiply( &pframe->combinedtransformationmatrix, &pframe->transformationmatrix, pparentmatrix ); else pframe->combinedtransformationmatrix = pframe->transformationmatrix; if( pframe->pframesibling!= NULL ) UpdateFrameMatrices( pframe->pframesibling, pparentmatrix ); if( pframe->pframefirstchild!= NULL ) UpdateFrameMatrices( pframe->pframefirstchild, &pframe->combinedtransformationmatrix ); return S_OK; 사람모델인경우머리부터발끝까지순서대로순회를하며적절한애니메이션타임에따른매트릭스대로업데이트 42

Microsoft PowerPoint - Week04_DirectX9 프로그래밍의 기초2.pptx

Microsoft PowerPoint - Week04_DirectX9 프로그래밍의 기초2.pptx DirectX9 프로그래밍의기초 2 목 차 파일포맷 ID3DXBuffer 사용하기 경계볼륨 애니메이션및게임실습 2 3D Modeler 3DS Max LightWave 3D Maya 메쉬데이터 기하정보 재질 애니메이션 애니메이션및게임실습 3 .X DirectX 에서사용하는파일포맷 파일처리함수를 DirectX 가제공 파일종류 ASCII Binary Binary

More information

Microsoft PowerPoint - GameProgramming15-MeshII

Microsoft PowerPoint - GameProgramming15-MeshII Mesh Part II Mesh Part II ID3DXBuffer XFiles 데이터를 ID3DXMesh 객체로읽어들이는방법 프로그레시브메쉬 (Progressive mesh) 를이용하여얻을수있는이점에대한이해와메쉬인터페이스 ID3DXPMesh 이용방법 305890 2007년봄학기 5/9/2007 박경신 경계볼륨 (Bounding volume) 의정의와용도에대한학습과

More information

PowerPoint 프레젠테이션

PowerPoint 프레젠테이션 System Software Experiment 1 Lecture 5 - Array Spring 2019 Hwansoo Han (hhan@skku.edu) Advanced Research on Compilers and Systems, ARCS LAB Sungkyunkwan University http://arcs.skku.edu/ 1 배열 (Array) 동일한타입의데이터가여러개저장되어있는저장장소

More information

C# Programming Guide - Types

C# Programming Guide - Types C# Programming Guide - Types 최도경 lifeisforu@wemade.com 이문서는 MSDN 의 Types 를요약하고보충한것입니다. http://msdn.microsoft.com/enus/library/ms173104(v=vs.100).aspx Types, Variables, and Values C# 은 type 에민감한언어이다. 모든

More information

No Slide Title

No Slide Title Copyright, 2001 Multimedia Lab., CH 3. COM object (In-process server) Eun-sung Lee twoss@mmlab.net Multimedia Lab. Dept. of Electrical and Computer Eng. University of Seoul Seoul, Korea 0. Contents 1.

More information

<4D F736F F F696E74202D20C1A63034B0AD202D20C7C1B7B9C0D3B8AEBDBAB3CABFCD20B9ABB9F6C6DBC0D4B7C2>

<4D F736F F F696E74202D20C1A63034B0AD202D20C7C1B7B9C0D3B8AEBDBAB3CABFCD20B9ABB9F6C6DBC0D4B7C2> 게임엔진 제 4 강프레임리스너와 OIS 입력시스템 이대현교수 한국산업기술대학교게임공학과 학습내용 프레임리스너의개념 프레임리스너를이용한엔터티의이동 OIS 입력시스템을이용한키보드입력의처리 게임루프 Initialization Game Logic Drawing N Exit? Y Finish 실제게임루프 오우거엔진의메인렌더링루프 Root::startRendering()

More information

[ 마이크로프로세서 1] 2 주차 3 차시. 포인터와구조체 2 주차 3 차시포인터와구조체 학습목표 1. C 언어에서가장어려운포인터와구조체를설명할수있다. 2. Call By Value 와 Call By Reference 를구분할수있다. 학습내용 1 : 함수 (Functi

[ 마이크로프로세서 1] 2 주차 3 차시. 포인터와구조체 2 주차 3 차시포인터와구조체 학습목표 1. C 언어에서가장어려운포인터와구조체를설명할수있다. 2. Call By Value 와 Call By Reference 를구분할수있다. 학습내용 1 : 함수 (Functi 2 주차 3 차시포인터와구조체 학습목표 1. C 언어에서가장어려운포인터와구조체를설명할수있다. 2. Call By Value 와 Call By Reference 를구분할수있다. 학습내용 1 : 함수 (Function) 1. 함수의개념 입력에대해적절한출력을발생시켜주는것 내가 ( 프로그래머 ) 작성한명령문을연산, 처리, 실행해주는부분 ( 모듈 ) 자체적으로실행되지않으며,

More information

API 매뉴얼

API 매뉴얼 PCI-DIO12 API Programming (Rev 1.0) Windows, Windows2000, Windows NT and Windows XP are trademarks of Microsoft. We acknowledge that the trademarks or service names of all other organizations mentioned

More information

chap 5: Trees

chap 5: Trees 5. Threaded Binary Tree 기본개념 n 개의노드를갖는이진트리에는 2n 개의링크가존재 2n 개의링크중에 n + 1 개의링크값은 null Null 링크를다른노드에대한포인터로대체 Threads Thread 의이용 ptr left_child = NULL 일경우, ptr left_child 를 ptr 의 inorder predecessor 를가리키도록변경

More information

12 강. 문자출력 Direct3D 에서는문자를출력하기위해서 LPD3DXFONT 객체를사용한다 LPD3DXFONT 객체생성과초기화 LPD3DXFONT 객체를생성하고초기화하는함수로 D3DXCreateFont() 가있다. HRESULT D3DXCreateFont

12 강. 문자출력 Direct3D 에서는문자를출력하기위해서 LPD3DXFONT 객체를사용한다 LPD3DXFONT 객체생성과초기화 LPD3DXFONT 객체를생성하고초기화하는함수로 D3DXCreateFont() 가있다. HRESULT D3DXCreateFont 12 강. 문자출력 Direct3D 에서는문자를출력하기위해서 LPD3DXFONT 객체를사용한다. 12.1 LPD3DXFONT 객체생성과초기화 LPD3DXFONT 객체를생성하고초기화하는함수로 D3DXCreateFont() 가있다. HRESULT D3DXCreateFont( in LPDIRECT3DDEVICE9 pdevice, in INT Height, in UINT

More information

JAVA PROGRAMMING 실습 08.다형성

JAVA PROGRAMMING 실습 08.다형성 2015 학년도 2 학기 1. 추상메소드 선언은되어있으나코드구현되어있지않은메소드 abstract 키워드사용 메소드타입, 이름, 매개변수리스트만선언 public abstract String getname(); public abstract void setname(string s); 2. 추상클래스 abstract 키워드로선언한클래스 종류 추상메소드를포함하는클래스

More information

adfasdfasfdasfasfadf

adfasdfasfdasfasfadf C 4.5 Source code Pt.3 ISL / 강한솔 2019-04-10 Index Tree structure Build.h Tree.h St-thresh.h 2 Tree structure *Concpets : Node, Branch, Leaf, Subtree, Attribute, Attribute Value, Class Play, Don't Play.

More information

유니티 변수-함수.key

유니티 변수-함수.key C# 1 or 16 (Binary or Hex) 1:1 C# C# (Java, Python, Go ) (0101010 ). (Variable) : (Value) (Variable) : (Value) ( ) (Variable) : (Value) ( ) ; (Variable) : (Value) ( ) ; = ; (Variable) : (Value) (Variable)

More information

<322EBCF8C8AF28BFACBDC0B9AEC1A6292E687770>

<322EBCF8C8AF28BFACBDC0B9AEC1A6292E687770> 연습문제해답 5 4 3 2 1 0 함수의반환값 =15 5 4 3 2 1 0 함수의반환값 =95 10 7 4 1-2 함수의반환값 =3 1 2 3 4 5 연습문제해답 1. C 언어에서의배열에대하여다음중맞는것은? (1) 3차원이상의배열은불가능하다. (2) 배열의이름은포인터와같은역할을한다. (3) 배열의인덱스는 1에서부터시작한다. (4) 선언한다음, 실행도중에배열의크기를변경하는것이가능하다.

More information

슬라이드 1

슬라이드 1 -Part3- 제 4 장동적메모리할당과가변인 자 학습목차 4.1 동적메모리할당 4.1 동적메모리할당 4.1 동적메모리할당 배울내용 1 프로세스의메모리공간 2 동적메모리할당의필요성 4.1 동적메모리할당 (1/6) 프로세스의메모리구조 코드영역 : 프로그램실행코드, 함수들이저장되는영역 스택영역 : 매개변수, 지역변수, 중괄호 ( 블록 ) 내부에정의된변수들이저장되는영역

More information

Microsoft Word - FunctionCall

Microsoft Word - FunctionCall Function all Mechanism /* Simple Program */ #define get_int() IN KEYOARD #define put_int(val) LD A val \ OUT MONITOR int add_two(int a, int b) { int tmp; tmp = a+b; return tmp; } local auto variable stack

More information

Microsoft PowerPoint - ch09 - 연결형리스트, Stack, Queue와 응용 pm0100

Microsoft PowerPoint - ch09 - 연결형리스트, Stack, Queue와 응용 pm0100 2015-1 프로그래밍언어 9. 연결형리스트, Stack, Queue 2015 년 5 월 4 일 교수김영탁 영남대학교공과대학정보통신공학과 (Tel : +82-53-810-2497; Fax : +82-53-810-4742 http://antl.yu.ac.kr/; E-mail : ytkim@yu.ac.kr) 연결리스트 (Linked List) 연결리스트연산 Stack

More information

A Hierarchical Approach to Interactive Motion Editing for Human-like Figures

A Hierarchical Approach to Interactive Motion Editing for Human-like Figures 단일연결리스트 (Singly Linked List) 신찬수 연결리스트 (linked list)? tail 서울부산수원용인 null item next 구조체복습 struct name_card { char name[20]; int date; } struct name_card a; // 구조체변수 a 선언 a.name 또는 a.date // 구조체 a의멤버접근 struct

More information

설계란 무엇인가?

설계란 무엇인가? 금오공과대학교 C++ 프로그래밍 jhhwang@kumoh.ac.kr 컴퓨터공학과 황준하 9 강. 클래스의활용목차 멤버함수의외부정의 this 포인터 friend 선언 static 멤버 임시객체 1 /17 9 강. 클래스의활용멤버함수의외부정의 멤버함수정의구현방법 내부정의 : 클래스선언내에함수정의구현 외부정의 클래스선언 : 함수프로토타입 멤버함수정의 : 클래스선언외부에구현

More information

예제 2) Test.java class A intvar= 10; void method() class B extends A intvar= 20; 1"); void method() 2"); void method1() public class Test 3"); args) A

예제 2) Test.java class A intvar= 10; void method() class B extends A intvar= 20; 1); void method() 2); void method1() public class Test 3); args) A 제 10 장상속 예제 1) ConstructorTest.java class Parent public Parent() super - default"); public Parent(int i) this("hello"); super(int) constructor" + i); public Parent(char c) this(); super(char) constructor

More information

Microsoft PowerPoint - chap10-함수의활용.pptx

Microsoft PowerPoint - chap10-함수의활용.pptx #include int main(void) { int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; } 1 학습목표 중 값에 의한 전달 방법과

More information

A Dynamic Grid Services Deployment Mechanism for On-Demand Resource Provisioning

A Dynamic Grid Services Deployment Mechanism for On-Demand Resource Provisioning C Programming Practice (II) Contents 배열 문자와문자열 구조체 포인터와메모리관리 구조체 2/17 배열 (Array) (1/2) 배열 동일한자료형을가지고있으며같은이름으로참조되는변수들의집합 배열의크기는반드시상수이어야한다. type var_name[size]; 예 ) int myarray[5] 배열의원소는원소의번호를 0 부터시작하는색인을사용

More information

11장 포인터

11장 포인터 Dynamic Memory and Linked List 1 동적할당메모리의개념 프로그램이메모리를할당받는방법 정적 (static) 동적 (dynamic) 정적메모리할당 프로그램이시작되기전에미리정해진크기의메모리를할당받는것 메모리의크기는프로그램이시작하기전에결정 int i, j; int buffer[80]; char name[] = data structure"; 처음에결정된크기보다더큰입력이들어온다면처리하지못함

More information

Microsoft PowerPoint - ch07 - 포인터 pm0415

Microsoft PowerPoint - ch07 - 포인터 pm0415 2015-1 프로그래밍언어 7. 포인터 (Pointer), 동적메모리할당 2015 년 4 월 4 일 교수김영탁 영남대학교공과대학정보통신공학과 (Tel : +82-53-810-2497; Fax : +82-53-810-4742 http://antl.yu.ac.kr/; E-mail : ytkim@yu.ac.kr) Outline 포인터 (pointer) 란? 간접참조연산자

More information

쉽게 풀어쓴 C 프로그래밍

쉽게 풀어쓴 C 프로그래밍 제 5 장생성자와접근제어 1. 객체지향기법을이해한다. 2. 클래스를작성할수있다. 3. 클래스에서객체를생성할수있다. 4. 생성자를이용하여객체를초기화할수 있다. 5. 접근자와설정자를사용할수있다. 이번장에서만들어볼프로그램 생성자 생성자 (constructor) 는초기화를담당하는함수 생성자가필요한이유 #include using namespace

More information

Chap 6: Graphs

Chap 6: Graphs 그래프표현법 인접행렬 (Adjacency Matrix) 인접리스트 (Adjacency List) 인접다중리스트 (Adjacency Multilist) 6 장. 그래프 (Page ) 인접행렬 (Adjacency Matrix) n 개의 vertex 를갖는그래프 G 의인접행렬의구성 A[n][n] (u, v) E(G) 이면, A[u][v] = Otherwise, A[u][v]

More information

쉽게 풀어쓴 C 프로그래밍

쉽게 풀어쓴 C 프로그래밍 제 11 장상속 1. 상속의개념을이해한다. 2. 상속을이용하여자식클래스를작성할수있다. 3. 상속과접근지정자와의관계를이해한다. 4. 상속시생성자와소멸자가호출되는순서를이해한다. 이번장에서만들어볼프로그램 class Circle { int x, y; int radius;... class Rect { int x, y; int width, height;... 중복 상속의개요

More information

Page 2 of 6 Here are the rules for conjugating Whether (or not) and If when using a Descriptive Verb. The only difference here from Action Verbs is wh

Page 2 of 6 Here are the rules for conjugating Whether (or not) and If when using a Descriptive Verb. The only difference here from Action Verbs is wh Page 1 of 6 Learn Korean Ep. 13: Whether (or not) and If Let s go over how to say Whether and If. An example in English would be I don t know whether he ll be there, or I don t know if he ll be there.

More information

UI TASK & KEY EVENT

UI TASK & KEY EVENT 2007. 2. 5 PLATFORM TEAM 정용학 차례 CONTAINER & WIDGET SPECIAL WIDGET 질의응답및토의 2 Container LCD에보여지는화면한개 1개이상의 Widget을가짐 3 Container 초기화과정 ui_init UMP_F_CONTAINERMGR_Initialize UMP_H_CONTAINERMGR_Initialize

More information

Spring Boot/JDBC JdbcTemplate/CRUD 예제

Spring Boot/JDBC JdbcTemplate/CRUD 예제 Spring Boot/JDBC JdbcTemplate/CRUD 예제 오라클자바커뮤니티 (ojc.asia, ojcedu.com) Spring Boot, Gradle 과오픈소스인 MariaDB 를이용해서 EMP 테이블을만들고 JdbcTemplate, SimpleJdbcTemplate 을이용하여 CRUD 기능을구현해보자. 마리아 DB 설치는다음 URL 에서확인하자.

More information

11장 포인터

11장 포인터 누구나즐기는 C 언어콘서트 제 9 장포인터 이번장에서학습할내용 포인터이란? 변수의주소 포인터의선언 간접참조연산자 포인터연산 포인터와배열 포인터와함수 이번장에서는포인터의기초적인지식을학습한다. 포인터란? 포인터 (pointer): 주소를가지고있는변수 메모리의구조 변수는메모리에저장된다. 메모리는바이트단위로액세스된다. 첫번째바이트의주소는 0, 두번째바이트는 1, 변수와메모리

More information

Microsoft PowerPoint - lecture2.ppt

Microsoft PowerPoint - lecture2.ppt Overview s & osg::referenced Class & osg::ref_ptr Template Class 개요 OSG OSG::Referenced Class OSG::ref_ptr Template Class 2008년여름박경신 2 스마트포인터 () 는 C++ class 이다. syntax 와 semantics 상일반포인터와같다. memory

More information

이번장에서학습할내용 동적메모리란? malloc() 와 calloc() 연결리스트 파일을이용하면보다많은데이터를유용하고지속적으로사용및관리할수있습니다. 2

이번장에서학습할내용 동적메모리란? malloc() 와 calloc() 연결리스트 파일을이용하면보다많은데이터를유용하고지속적으로사용및관리할수있습니다. 2 제 17 장동적메모리와연결리스트 유준범 (JUNBEOM YOO) Ver. 2.0 jbyoo@konkuk.ac.kr http://dslab.konkuk.ac.kr 본강의자료는생능출판사의 PPT 강의자료 를기반으로제작되었습니다. 이번장에서학습할내용 동적메모리란? malloc() 와 calloc() 연결리스트 파일을이용하면보다많은데이터를유용하고지속적으로사용및관리할수있습니다.

More information

Microsoft PowerPoint - java1-lab5-ImageProcessorTestOOP.pptx

Microsoft PowerPoint - java1-lab5-ImageProcessorTestOOP.pptx 2018 학년도 1 학기 JAVA 프로그래밍 II 514760-1 2018 년봄학기 5/10/2018 박경신 Lab#1 (ImageTest) Lab#1 은영상파일 (Image) 을읽어서정보를출력 Java Tutorials Lesson: Working with Images https://docs.oracle.com/javase/tutorial/2d/images/index.html

More information

Microsoft PowerPoint - CSharp-10-예외처리

Microsoft PowerPoint - CSharp-10-예외처리 10 장. 예외처리 예외처리개념 예외처리구문 사용자정의예외클래스와예외전파 순천향대학교컴퓨터학부이상정 1 예외처리개념 순천향대학교컴퓨터학부이상정 2 예외처리 오류 컴파일타임오류 (Compile-Time Error) 구문오류이기때문에컴파일러의구문오류메시지에의해쉽게교정 런타임오류 (Run-Time Error) 디버깅의절차를거치지않으면잡기어려운심각한오류 시스템에심각한문제를줄수도있다.

More information

PowerPoint 프레젠테이션

PowerPoint 프레젠테이션 @ Lesson 2... ( ). ( ). @ vs. logic data method variable behavior attribute method field Flow (Type), ( ) member @ () : C program Method A ( ) Method B ( ) Method C () program : Java, C++, C# data @ Program

More information

Lab 3. 실습문제 (Single linked list)_해답.hwp

Lab 3. 실습문제 (Single linked list)_해답.hwp Lab 3. Singly-linked list 의구현 실험실습일시 : 2009. 3. 30. 담당교수 : 정진우 담당조교 : 곽문상 보고서제출기한 : 2009. 4. 5. 학과 : 학번 : 성명 : 실습과제목적 : 이론시간에배운 Singly-linked list를실제로구현할수있다. 실습과제내용 : 주어진소스를이용해 Singly-linked list의각함수를구현한다.

More information

쉽게 풀어쓴 C 프로그래밍

쉽게 풀어쓴 C 프로그래밍 제 3 장함수와문자열 1. 함수의기본적인개념을이해한다. 2. 인수와매개변수의개념을이해한다. 3. 함수의인수전달방법 2가지를이해한다 4. 중복함수를이해한다. 5. 디폴트매개변수를이해한다. 6. 문자열의구성을이해한다. 7. string 클래스의사용법을익힌다. 이번장에서만들어볼프로그램 함수란? 함수선언 함수호출 예제 #include using

More information

Microsoft PowerPoint - Week03_DirectX9 프로그래밍의 기초.pptx

Microsoft PowerPoint - Week03_DirectX9 프로그래밍의 기초.pptx DirectX9 프로그래밍의기초 목 차 DirectX9 프로그래밍의기초 DirectX 그래픽의역사 HAL 과 COM 에대한개요 DirectX9 에서의그리기 Win32API 프로그래밍의개요 Direct3D 초기화 정점 / 인덱스버퍼를이용한그리기 D3DX 기하물체 메쉬의이용 애니메이션및게임실습 2 DirectX 그래픽의역사 DirectX 2.0 1995. DirectX

More information

Microsoft PowerPoint - chap11-포인터의활용.pptx

Microsoft PowerPoint - chap11-포인터의활용.pptx #include int main(void) int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; 1 학습목표 포인터를 사용하는 다양한 방법에

More information

제8장 자바 GUI 프로그래밍 II

제8장 자바 GUI 프로그래밍 II 제8장 MVC Model 8.1 MVC 모델 (1/7) MVC (Model, View, Controller) 모델 스윙은 MVC 모델에기초를두고있다. MVC란 Xerox의연구소에서 Smalltalk 언어를바탕으로사용자인터페이스를개발하기위한방법 MVC는 3개의구성요소로구성 Model : 응용프로그램의자료를표현하기위한모델 View : 자료를시각적으로 (GUI 방식으로

More information

Analytics > Log & Crash Search > Unity ios SDK [Deprecated] Log & Crash Unity ios SDK. TOAST SDK. Log & Crash Unity SDK Log & Crash Search. Log & Cras

Analytics > Log & Crash Search > Unity ios SDK [Deprecated] Log & Crash Unity ios SDK. TOAST SDK. Log & Crash Unity SDK Log & Crash Search. Log & Cras Analytics > Log & Crash Search > Unity ios SDK [Deprecated] Log & Crash Unity ios SDK. TOAST SDK. Log & Crash Unity SDK Log & Crash Search. Log & Crash Unity SDK... Log & Crash Search. - Unity3D v4.0 ios

More information

Lab 4. 실습문제 (Circular singly linked list)_해답.hwp

Lab 4. 실습문제 (Circular singly linked list)_해답.hwp Lab 4. Circular singly-linked list 의구현 실험실습일시 : 2009. 4. 6. 담당교수 : 정진우 담당조교 : 곽문상 보고서제출기한 : 2009. 4. 12. 학과 : 학번 : 성명 : 실습과제목적 : 이론시간에배운 Circular Singly-linked list를실제로구현할수있다. 실습과제내용 : 주어진소스를이용해 Circular

More information

슬라이드 제목 없음

슬라이드 제목 없음 2006-09-27 경북대학교컴퓨터공학과 1 제 5 장서브넷팅과슈퍼넷팅 서브넷팅 (subnetting) 슈퍼넷팅 (Supernetting) 2006-09-27 경북대학교컴퓨터공학과 2 서브넷팅과슈퍼넷팅 서브넷팅 (subnetting) 하나의네트워크를여러개의서브넷 (subnet) 으로분할 슈퍼넷팅 (supernetting) 여러개의서브넷주소를결합 The idea

More information

API 매뉴얼

API 매뉴얼 PCI-TC03 API Programming (Rev 1.0) Windows, Windows2000, Windows NT, Windows XP and Windows 7 are trademarks of Microsoft. We acknowledge that the trademarks or service names of all other organizations

More information

PowerPoint Presentation

PowerPoint Presentation 객체지향프로그래밍 클래스, 객체, 메소드 ( 실습 ) 손시운 ssw5176@kangwon.ac.kr 예제 1. 필드만있는클래스 텔레비젼 2 예제 1. 필드만있는클래스 3 예제 2. 여러개의객체생성하기 4 5 예제 3. 메소드가추가된클래스 public class Television { int channel; // 채널번호 int volume; // 볼륨 boolean

More information

q 이장에서다룰내용 1 객체지향프로그래밍의이해 2 객체지향언어 : 자바 2

q 이장에서다룰내용 1 객체지향프로그래밍의이해 2 객체지향언어 : 자바 2 객체지향프로그래밍 IT CookBook, 자바로배우는쉬운자료구조 q 이장에서다룰내용 1 객체지향프로그래밍의이해 2 객체지향언어 : 자바 2 q 객체지향프로그래밍의이해 v 프로그래밍기법의발달 A 군의사업발전 1 단계 구조적프로그래밍방식 3 q 객체지향프로그래밍의이해 A 군의사업발전 2 단계 객체지향프로그래밍방식 4 q 객체지향프로그래밍의이해 v 객체란무엇인가

More information

K7VT2_QIG_v3

K7VT2_QIG_v3 1......... 2 3..\ 4 5 [R] : Enter Raid setup utility 6 Press[A]keytocreateRAID RAID Type: JBOD RAID 0 RAID 1: 2 7 " RAID 0 Auto Create Manual Create: 2 RAID 0 Block Size: 16K 32K

More information

PowerPoint Presentation

PowerPoint Presentation Class - Property Jo, Heeseung 목차 section 1 클래스의일반구조 section 2 클래스선언 section 3 객체의생성 section 4 멤버변수 4-1 객체변수 4-2 클래스변수 4-3 종단 (final) 변수 4-4 멤버변수접근방법 section 5 멤버변수접근한정자 5-1 public 5-2 private 5-3 한정자없음

More information

data

data 3D Game Programming 11 - ASE Animation afewhee@gmail.com 0. 목차 ASE 구조 Geometry Parsing Geometry Texture Parsing Material Texture Rigid Body Animation Scene Animation X-File Animation 1. ASE 구조 ASE Parsing

More information

K&R2 Reference Manual 번역본

K&R2 Reference Manual 번역본 typewriter structunion struct union if-else if if else if if else if if if if else else ; auto register static extern typedef void char short int long float double signed unsigned const volatile { } struct

More information

KNK_C_05_Pointers_Arrays_structures_summary_v02

KNK_C_05_Pointers_Arrays_structures_summary_v02 Pointers and Arrays Structures adopted from KNK C Programming : A Modern Approach 요약 2 Pointers and Arrays 3 배열의주소 #include int main(){ int c[] = {1, 2, 3, 4}; printf("c\t%p\n", c); printf("&c\t%p\n",

More information

4 5 4. Hi-MO 애프터케어 시스템 편 5. 오비맥주 카스 카스 후레쉬 테이블 맥주는 천연식품이다 편 처음 스타일 그대로, 부탁 케어~ Hi-MO 애프터케어 시스템 지속적인 모발 관리로 끝까지 스타일이 유지되도록 독보적이다! 근데 그거 아세요? 맥주도 인공첨가물이

4 5 4. Hi-MO 애프터케어 시스템 편 5. 오비맥주 카스 카스 후레쉬 테이블 맥주는 천연식품이다 편 처음 스타일 그대로, 부탁 케어~ Hi-MO 애프터케어 시스템 지속적인 모발 관리로 끝까지 스타일이 유지되도록 독보적이다! 근데 그거 아세요? 맥주도 인공첨가물이 1 2 On-air 3 1. 이베이코리아 G마켓 용평리조트 슈퍼브랜드딜 편 2. 아모레퍼시픽 헤라 루즈 홀릭 리퀴드 편 인쇄 광고 올해도 겨울이 왔어요. 당신에게 꼭 해주고 싶은 말이 있어요. G마켓에선 용평리조트 스페셜 패키지가 2만 6900원! 역시 G마켓이죠? G마켓과 함께하는 용평리조트 스페셜 패키지. G마켓의 슈퍼브랜드딜은 계속된다. 모바일 쇼핑 히어로

More information

Something that can be seen, touched or otherwise sensed

Something that can be seen, touched or otherwise sensed Something that can be seen, touched or otherwise sensed Things about an object Weight Height Material Things an object does Pen writes Book stores words Water have Fresh water Rivers Oceans have

More information

Microsoft PowerPoint - chap06-2pointer.ppt

Microsoft PowerPoint - chap06-2pointer.ppt 2010-1 학기프로그래밍입문 (1) chapter 06-2 참고자료 포인터 박종혁 Tel: 970-6702 Email: jhpark1@snut.ac.kr 한빛미디어 출처 : 뇌를자극하는 C프로그래밍, 한빛미디어 -1- 포인터의정의와사용 변수를선언하는것은메모리에기억공간을할당하는것이며할당된이후에는변수명으로그기억공간을사용한다. 할당된기억공간을사용하는방법에는변수명외에메모리의실제주소값을사용하는것이다.

More information

슬라이드 1

슬라이드 1 정적메모리할당 (Static memory allocation) 일반적으로프로그램의실행에필요한메모리 ( 변수, 배열, 객체등 ) 는컴파일과정에서결정되고, 실행파일이메모리에로드될때할당되며, 종료후에반환됨 동적메모리할당 (Dynamic memory allocation) 프로그램의실행중에필요한메모리를할당받아사용하고, 사용이끝나면반환함 - 메모리를프로그램이직접관리해야함

More information

슬라이드 1

슬라이드 1 한국산업기술대학교 제 4 강프레임리스너 (Frame Listener) 이대현교수 학습안내 학습목표 프레임리스너를이용하여게임루프를구현하는방법을이해한다. 오우거엔짂의키입력처리방식을이해한다. 학습내용 프레임리스너의개념프레임리스너를이용한게임캐릭터의이동캐릭터의이동속도조절 OIS 입력시스템을이용한키보드입력의처리 기본게임루프 Initialization Game Logic

More information

Chapter 4. LISTS

Chapter 4. LISTS C 언어에서리스트구현 리스트의생성 struct node { int data; struct node *link; ; struct node *ptr = NULL; ptr = (struct node *) malloc(sizeof(struct node)); Self-referential structure NULL: defined in stdio.h(k&r C) or

More information

<4D F736F F F696E74202D B3E22032C7D0B1E220C0A9B5B5BFECB0D4C0D3C7C1B7CEB1D7B7A1B9D620C1A638B0AD202D20C7C1B7B9C0D320BCD3B5B5C0C720C1B6C0FD>

<4D F736F F F696E74202D B3E22032C7D0B1E220C0A9B5B5BFECB0D4C0D3C7C1B7CEB1D7B7A1B9D620C1A638B0AD202D20C7C1B7B9C0D320BCD3B5B5C0C720C1B6C0FD> 2006 년 2 학기윈도우게임프로그래밍 제 8 강프레임속도의조절 이대현 한국산업기술대학교 오늘의학습내용 프레임속도의조절 30fps 맞추기 스프라이트프레임속도의조절 프레임속도 (Frame Rate) 프레임속도란? 얼마나빨리프레임 ( 일반적으로하나의완성된화면 ) 을만들어낼수있는지를나타내는척도 일반적으로초당프레임출력횟수를많이사용한다. FPS(Frame Per Sec)

More information

2 min 응용 말하기 01 I set my alarm for 7. 02 It goes off. 03 It doesn t go off. 04 I sleep in. 05 I make my bed. 06 I brush my teeth. 07 I take a shower.

2 min 응용 말하기 01 I set my alarm for 7. 02 It goes off. 03 It doesn t go off. 04 I sleep in. 05 I make my bed. 06 I brush my teeth. 07 I take a shower. 스피킹 매트릭스 특별 체험판 정답 및 스크립트 30초 영어 말하기 INPUT DAY 01 p.10~12 3 min 집중 훈련 01 I * wake up * at 7. 02 I * eat * an apple. 03 I * go * to school. 04 I * put on * my shoes. 05 I * wash * my hands. 06 I * leave

More information

Microsoft PowerPoint 세션.ppt

Microsoft PowerPoint 세션.ppt 웹프로그래밍 () 2006 년봄학기 문양세강원대학교컴퓨터과학과 세션변수 (Session Variable) (1/2) 쇼핑몰장바구니 장바구니에서는사용자가페이지를이동하더라도장바구니의구매물품리스트의내용을유지하고있어야함 PHP 에서사용하는일반적인변수는스크립트의수행이끝나면모두없어지기때문에페이지이동시변수의값을유지할수없음 이러한문제점을해결하기위해서 PHP 에서는세션 (session)

More information

Chapter #01 Subject

Chapter #01  Subject Device Driver March 24, 2004 Kim, ki-hyeon 목차 1. 인터럽트처리복습 1. 인터럽트복습 입력검출방법 인터럽트방식, 폴링 (polling) 방식 인터럽트서비스등록함수 ( 커널에등록 ) int request_irq(unsigned int irq, void(*handler)(int,void*,struct pt_regs*), unsigned

More information

gnu-lee-oop-kor-lec06-3-chap7

gnu-lee-oop-kor-lec06-3-chap7 어서와 Java 는처음이지! 제 7 장상속 Super 키워드 상속과생성자 상속과다형성 서브클래스의객체가생성될때, 서브클래스의생성자만호출될까? 아니면수퍼클래스의생성자도호출되는가? class Base{ public Base(String msg) { System.out.println("Base() 생성자 "); ; class Derived extends Base

More information

Microsoft PowerPoint - C++ 5 .pptx

Microsoft PowerPoint - C++ 5 .pptx C++ 언어프로그래밍 한밭대학교전자. 제어공학과이승호교수 연산자중복 (operator overloading) 이란? 2 1. 연산자중복이란? 1) 기존에미리정의되어있는연산자 (+, -, /, * 등 ) 들을프로그래머의의도에맞도록새롭게정의하여사용할수있도록지원하는기능 2) 연산자를특정한기능을수행하도록재정의하여사용하면여러가지이점을가질수있음 3) 하나의기능이프로그래머의의도에따라바뀌어동작하는다형성

More information

JVM 메모리구조

JVM 메모리구조 조명이정도면괜찮조! 주제 JVM 메모리구조 설미라자료조사, 자료작성, PPT 작성, 보고서작성. 발표. 조장. 최지성자료조사, 자료작성, PPT 작성, 보고서작성. 발표. 조원 이용열자료조사, 자료작성, PPT 작성, 보고서작성. 이윤경 자료조사, 자료작성, PPT작성, 보고서작성. 이수은 자료조사, 자료작성, PPT작성, 보고서작성. 발표일 2013. 05.

More information

슬라이드 1

슬라이드 1 2007 년 2 학기윈도우게임프로그래밍 제 7 강프레임속도의조절 이대현 핚국산업기술대학교 학습내용 프레임속도의조절 30fps 맞추기 스프라이트프레임속도의조절 프레임속도 (Frame Rate) 프레임속도란? 얼마나빨리프레임 ( 일반적으로하나의완성된화면 ) 을만들어낼수있는지를나타내는척도 일반적으로초당프레임출력횟수를많이사용핚다. FPS(Frame Per Sec)

More information

(Microsoft PowerPoint - 07\300\345.ppt [\310\243\310\257 \270\360\265\345])

(Microsoft PowerPoint - 07\300\345.ppt [\310\243\310\257 \270\360\265\345]) 클래스의응용 클래스를자유자재로사용하자. 이장에서다룰내용 1 객체의치환 2 함수와클래스의상관관계 01_ 객체의치환 객체도변수와마찬가지로치환이가능하다. 기본예제 [7-1] 객체도일반변수와마찬가지로대입이가능하다. 기본예제 [7-2] 객체의치환시에는조심해야할점이있다. 복사생성자의필요성에대하여알아보자. [ 기본예제 7-1] 클래스의치환 01 #include

More information

JUNIT 실습및발표

JUNIT 실습및발표 JUNIT 실습및발표 JUNIT 접속 www.junit.org DownLoad JUnit JavaDoc API Document 를참조 JUNIT 4.8.1 다운로드 설치파일 (jar 파일 ) 을다운로드 CLASSPATH 를설정 환경변수에서설정 실행할클래스에서 import JUnit 설치하기 테스트실행주석 @Test Test 를실행할 method 앞에붙임 expected

More information

PowerPoint 프레젠테이션

PowerPoint 프레젠테이션 인터페이스 배효철 th1g@nate.com 1 목차 인터페이스의역할 인터페이스선언 인터페이스구현 인터페이스사용 타입변환과다형성 인터페이스상속 디폴트메소드와인터페이스확장 2 인터페이스의역할 인터페이스란? 개발코드와객체가서로통신하는접점 개발코드는인터페이스의메소드만알고있으면 OK 인터페이스의역할 개발코드가객체에종속되지않게 -> 객체교체할수있도록하는역할 개발코드변경없이리턴값또는실행내용이다양해질수있음

More information

Microsoft PowerPoint - GameProgramming23-PixelShader.ppt

Microsoft PowerPoint - GameProgramming23-PixelShader.ppt 픽셀셰이더 HLSL Pixel Shader 305890 2009년봄학기 6/10/2009 박경신 각픽셀의래스터라이즈과정을위해그래픽카드의 GPU 에서실행되는프로그램 Direct3D 는소프트웨어적으로픽셀셰이더기능을에뮬레이트하지않음 픽셀과텍스처좌표에대한직접적인접근, 처리 멀티텍스처링, 픽셀당조명, 필드깊이, 구름시뮬레이션, 불시뮬레이션, 복잡한그림자테크닉 GPU

More information

1. auto_ptr 다음프로그램의문제점은무엇인가? void func(void) int *p = new int; cout << " 양수입력 : "; cin >> *p; if (*p <= 0) cout << " 양수를입력해야합니다 " << endl; return; 동적할

1. auto_ptr 다음프로그램의문제점은무엇인가? void func(void) int *p = new int; cout <<  양수입력 : ; cin >> *p; if (*p <= 0) cout <<  양수를입력해야합니다  << endl; return; 동적할 15 장기타주제들 auto_ptr 변환함수 cast 연산자에의한명시적형변환실행시간타입정보알아내기 (RTTI) C++ 프로그래밍입문 1. auto_ptr 다음프로그램의문제점은무엇인가? void func(void) int *p = new int; cout > *p; if (*p

More information

어댑터뷰

어댑터뷰 04 커스텀어댑터뷰 (Custom Adapter View) 커스텀어댑터뷰 (Custom Adapter View) 커스텀어댑터뷰 (Custom Adatper View) 란? u 어댑터뷰의항목하나는단순한문자열이나이미지뿐만아니라, 임의의뷰가될수 있음 이미지뷰 u 커스텀어댑터뷰설정절차 1 2 항목을위한 XML 레이아웃정의 어댑터정의 3 어댑터를생성하고어댑터뷰객체에연결

More information

Page 2 of 5 아니다 means to not be, and is therefore the opposite of 이다. While English simply turns words like to be or to exist negative by adding not,

Page 2 of 5 아니다 means to not be, and is therefore the opposite of 이다. While English simply turns words like to be or to exist negative by adding not, Page 1 of 5 Learn Korean Ep. 4: To be and To exist Of course to be and to exist are different verbs, but they re often confused by beginning students when learning Korean. In English we sometimes use the

More information

- 목차 - - ios 개발환경및유의사항. - 플랫폼 ios Project. - Native Controller와플랫폼화면연동. - 플랫폼 Web(js)-Native 간데이터공유. - 플랫폼확장 WN Interface 함수개발. - Network Manager clas

- 목차 - - ios 개발환경및유의사항. - 플랫폼 ios Project. - Native Controller와플랫폼화면연동. - 플랫폼 Web(js)-Native 간데이터공유. - 플랫폼확장 WN Interface 함수개발. - Network Manager clas 플랫폼사용을위한 ios Native Guide - 목차 - - ios 개발환경및유의사항. - 플랫폼 ios Project. - Native Controller와플랫폼화면연동. - 플랫폼 Web(js)-Native 간데이터공유. - 플랫폼확장 WN Interface 함수개발. - Network Manager class 개발. - Native Controller에서

More information

JAVA 프로그래밍실습 실습 1) 실습목표 - 메소드개념이해하기 - 매개변수이해하기 - 새메소드만들기 - Math 클래스의기존메소드이용하기 ( ) 문제 - 직사각형모양의땅이있다. 이땅의둘레, 면적과대각

JAVA 프로그래밍실습 실습 1) 실습목표 - 메소드개념이해하기 - 매개변수이해하기 - 새메소드만들기 - Math 클래스의기존메소드이용하기 (   ) 문제 - 직사각형모양의땅이있다. 이땅의둘레, 면적과대각 JAVA 프로그래밍실습 실습 1) 실습목표 - 메소드개념이해하기 - 매개변수이해하기 - 새메소드만들기 - Math 클래스의기존메소드이용하기 ( http://java.sun.com/javase/6/docs/api ) 문제 - 직사각형모양의땅이있다. 이땅의둘레, 면적과대각선의길이를계산하는메소드들을작성하라. 직사각형의가로와세로의길이는주어진다. 대각선의길이는 Math클래스의적절한메소드를이용하여구하라.

More information

휠세미나3 ver0.4

휠세미나3 ver0.4 andromeda@sparcs:/$ ls -al dev/sda* brw-rw---- 1 root disk 8, 0 2014-06-09 18:43 dev/sda brw-rw---- 1 root disk 8, 1 2014-06-09 18:43 dev/sda1 brw-rw---- 1 root disk 8, 2 2014-06-09 18:43 dev/sda2 andromeda@sparcs:/$

More information

PowerPoint 프레젠테이션

PowerPoint 프레젠테이션 Lab 4 ADT Design 클래스로정의됨. 모든객체들은힙영역에할당됨. 캡슐화 (Encapsulation) : Data representation + Operation 정보은닉 (Information Hiding) : Opertion부분은가려져있고, 사용자가 operation으로만사용가능해야함. 클래스정의의형태 public class Person { private

More information

Chapter 4. LISTS

Chapter 4. LISTS 연결리스트의응용 류관희 충북대학교 1 체인연산 체인을역순으로만드는 (inverting) 연산 3 개의포인터를적절히이용하여제자리 (in place) 에서문제를해결 typedef struct listnode *listpointer; typedef struct listnode { char data; listpointer link; ; 2 체인연산 체인을역순으로만드는

More information

Microsoft PowerPoint - a10.ppt [호환 모드]

Microsoft PowerPoint - a10.ppt [호환 모드] Structure Chapter 10: Structures t and Macros Structure 관련된변수들의그룹으로이루어진자료구조 template, pattern field structure를구성하는변수 (cf) C언어의 struct 프로그램의 structure 접근 entire structure 또는 individual fields Structure는

More information

<32B1B3BDC32E687770>

<32B1B3BDC32E687770> 008년도 상반기 제회 한 국 어 능 력 시 험 The th Test of Proficiency in Korean 일반 한국어(S-TOPIK 중급(Intermediate A 교시 이해 ( 듣기, 읽기 수험번호(Registration No. 이 름 (Name 한국어(Korean 영 어(English 유 의 사 항 Information. 시험 시작 지시가 있을

More information

Microsoft PowerPoint - 07-Data Manipulation.pptx

Microsoft PowerPoint - 07-Data Manipulation.pptx Digital 3D Anthropometry 7. Data Analysis Sungmin Kim SEOUL NATIONAL UNIVERSITY Body 기본정보표시 Introduction 스케일조절하기 단면형상추출 단면정보관리 3D 단면형상표시 2 기본정보표시및스케일조절 UI 및핸들러구성 void fastcall TMainForm::BeginNewProject1Click(TObject

More information

예제 1.1 ( 관계연산자 ) >> A=1:9, B=9-A A = B = >> tf = A>4 % 4 보다큰 A 의원소들을찾을경우 tf = >> tf = (A==B) % A

예제 1.1 ( 관계연산자 ) >> A=1:9, B=9-A A = B = >> tf = A>4 % 4 보다큰 A 의원소들을찾을경우 tf = >> tf = (A==B) % A 예제 1.1 ( 관계연산자 ) >> A=1:9, B=9-A A = 1 2 3 4 5 6 7 8 9 B = 8 7 6 5 4 3 2 1 0 >> tf = A>4 % 4 보다큰 A 의원소들을찾을경우 tf = 0 0 0 0 1 1 1 1 1 >> tf = (A==B) % A 의원소와 B 의원소가똑같은경우를찾을때 tf = 0 0 0 0 0 0 0 0 0 >> tf

More information

Microsoft Word - ASG AT90CAN128 모듈.doc

Microsoft Word - ASG AT90CAN128 모듈.doc ASG AT90128 Project 3 rd Team Author Cho Chang yeon Date 2006-07-31 Contents 1 Introduction... 3 2 Schematic Revision... 4 3 Library... 5 3.1 1: 1 Communication... 5 iprinceps - 2-2006/07/31

More information

<B1E2C8B9BEC828BFCFBCBAC1F7C0FC29322E687770>

<B1E2C8B9BEC828BFCFBCBAC1F7C0FC29322E687770> 맛있는 한국으로의 초대 - 중화권 음식에서 한국 음식의 관광 상품화 모색하기 - 소속학교 : 한국외국어대학교 지도교수 : 오승렬 교수님 ( 중국어과) 팀 이 름 : 飮 食 男 女 ( 음식남녀) 팀 원 : 이승덕 ( 중국어과 4) 정진우 ( 중국어과 4) 조정훈 ( 중국어과 4) 이민정 ( 중국어과 3) 탐방목적 1. 한국 음식이 가지고 있는 장점과 경제적 가치에도

More information

슬라이드 1

슬라이드 1 Pairwise Tool & Pairwise Test NuSRS 200511305 김성규 200511306 김성훈 200614164 김효석 200611124 유성배 200518036 곡진화 2 PICT Pairwise Tool - PICT Microsoft 의 Command-line 기반의 Free Software www.pairwise.org 에서다운로드후설치

More information

구조체정의 자료형 (data types) 기본자료형 (primitive data types) : char, int, float 등과같이 C 언어에서제공하는자료형. 사용자정의자료형 (user-defined data types) : 다양한자료형을묶어서목적에따라새로운자료형을

구조체정의 자료형 (data types) 기본자료형 (primitive data types) : char, int, float 등과같이 C 언어에서제공하는자료형. 사용자정의자료형 (user-defined data types) : 다양한자료형을묶어서목적에따라새로운자료형을 (structures) 구조체정의 구조체선언및초기화 구조체배열 구조체포인터 구조체배열과포인터 구조체와함수 중첩된구조체 구조체동적할당 공용체 (union) 1 구조체정의 자료형 (data types) 기본자료형 (primitive data types) : char, int, float 등과같이 C 언어에서제공하는자료형. 사용자정의자료형 (user-defined

More information

C++ Programming

C++ Programming C++ Programming 클래스와데이터추상화 Seo, Doo-okok clickseo@gmail.com http://www.clickseo.com 목 차 객체지향프로그래밍 클래스와객체 2 객체지향프로그래밍 객체지향언어 (Object-Oriented Language) 프로그램을명령어의목록으로보는시각에서벗어나여러개의 독립된단위, 즉 객체 (Object) 들의모임으로파악

More information

강의10

강의10 Computer Programming gdb and awk 12 th Lecture 김현철컴퓨터공학부서울대학교 순서 C Compiler and Linker 보충 Static vs Shared Libraries ( 계속 ) gdb awk Q&A Shared vs Static Libraries ( 계속 ) Advantage of Using Libraries Reduced

More information

Microsoft PowerPoint - chap02-C프로그램시작하기.pptx

Microsoft PowerPoint - chap02-C프로그램시작하기.pptx #include int main(void) { int num; printf( Please enter an integer "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; } 1 학습목표 을 작성하면서 C 프로그램의

More information

03_queue

03_queue Queue Data Structures and Algorithms 목차 큐의이해와 ADT 정의 큐의배열기반구현 큐의연결리스트기반구현 큐의활용 덱 (Deque) 의이해와구현 Data Structures and Algorithms 2 큐의이해와 ADT 정의 Data Structures and Algorithms 3 큐 (Stack) 의이해와 ADT 정의 큐는 LIFO(Last-in,

More information

Microsoft PowerPoint - 3ÀÏ°_º¯¼ö¿Í »ó¼ö.ppt

Microsoft PowerPoint - 3ÀÏ°_º¯¼ö¿Í »ó¼ö.ppt 변수와상수 1 변수란무엇인가? 변수 : 정보 (data) 를저장하는컴퓨터내의특정위치 ( 임시저장공간 ) 메모리, register 메모리주소 101 번지 102 번지 변수의크기에따라 주로 byte 단위 메모리 2 기본적인변수형및변수의크기 변수의크기 해당컴퓨터에서는항상일정 컴퓨터마다다를수있음 short

More information

학습목차 2.1 다차원배열이란 차원배열의주소와값의참조

학습목차 2.1 다차원배열이란 차원배열의주소와값의참조 - Part2- 제 2 장다차원배열이란무엇인가 학습목차 2.1 다차원배열이란 2. 2 2 차원배열의주소와값의참조 2.1 다차원배열이란 2.1 다차원배열이란 (1/14) 다차원배열 : 2 차원이상의배열을의미 1 차원배열과다차원배열의비교 1 차원배열 int array [12] 행 2 차원배열 int array [4][3] 행 열 3 차원배열 int array [2][2][3]

More information

thesis

thesis ( Design and Implementation of a Generalized Management Information Repository Service for Network and System Management ) ssp@nile nile.postech.ac..ac.kr DPE Lab. 1997 12 16 GMIRS GMIRS GMIRS prototype

More information

DocsPin_Korean.pages

DocsPin_Korean.pages Unity Localize Script Service, Page 1 Unity Localize Script Service Introduction Application Game. Unity. Google Drive Unity.. Application Game. -? ( ) -? -?.. 준비사항 Google Drive. Google Drive.,.. - Google

More information

<443A5C4C C4B48555C B3E25C32C7D0B1E25CBCB3B0E8C7C1B7CEC1A7C6AE425CBED0C3E0C7C1B7CEB1D7B7A55C D616E2E637070>

<443A5C4C C4B48555C B3E25C32C7D0B1E25CBCB3B0E8C7C1B7CEC1A7C6AE425CBED0C3E0C7C1B7CEB1D7B7A55C D616E2E637070> #include "stdafx.h" #include "Huffman.h" 1 /* 비트의부분을뽑아내는함수 */ unsigned HF::bits(unsigned x, int k, int j) return (x >> k) & ~(~0

More information

Microsoft PowerPoint - 2강

Microsoft PowerPoint - 2강 컴퓨터과학과 김희천교수 학습개요 Java 언어문법의기본사항, 자료형, 변수와상수선언및사용법, 각종연산자사용법, if/switch 등과같은제어문사용법등에대해설명한다. 또한 C++ 언어와선언 / 사용방법이다른 Java의배열선언및사용법에대해서설명한다. Java 언어의효과적인활용을위해서는기본문법을이해하는것이중요하다. 객체지향의기본개념에대해알아보고 Java에서어떻게객체지향적요소를적용하고있는지살펴본다.

More information

슬라이드 1

슬라이드 1 CHAP 6: 큐 yicho@gachon.ac.kr 1 큐 (QUEUE) 큐 : 먼저들어온데이터가먼저나가는자료구조 선입선출 (FIFO: First-In First-Out) ( 예 ) 매표소의대기열 Ticket Box 전단 () 후단 () 2 큐 ADT 삽입과삭제는 FIFO 순서를따른다. 삽입은큐의후단에서, 삭제는전단에서이루어진다. 객체 : n 개의 element

More information

Slide 1

Slide 1 SeoulTech 2011-2 nd 프로그래밍입문 (2) Chapter 14. 상속 박종혁교수 (http://www.parkjonghyuk.net) Tel: 970-6702 Email: jhpark1@snut.ac.kr Learning Objectives 상속의기본 파생클래스와생성자 protected: 제한자 멤버함수의재정의 상속되지않는함수들 상속을이용한프로그래밍

More information

Microsoft PowerPoint - 26.pptx

Microsoft PowerPoint - 26.pptx 이산수학 () 관계와그특성 (Relations and Its Properties) 2011년봄학기 강원대학교컴퓨터과학전공문양세 Binary Relations ( 이진관계 ) Let A, B be any two sets. A binary relation R from A to B, written R:A B, is a subset of A B. (A 에서 B 로의이진관계

More information

Tcl의 문법

Tcl의 문법 월, 01/28/2008-20:50 admin 은 상당히 단순하고, 커맨드의 인자를 스페이스(공백)로 단락을 짓고 나열하는 정도입니다. command arg1 arg2 arg3... 한행에 여러개의 커맨드를 나열할때는, 세미콜론( ; )으로 구분을 짓습니다. command arg1 arg2 arg3... ; command arg1 arg2 arg3... 한행이

More information