OSDN Git Service

DTXMania089リリースに際してのtag付け。
[dtxmania/dtxmania.git] / 110401(DTXMania089) / SlimDXc_Jun2010(VC++2008) / source / directinput / PeriodicForce.cpp
1 /*\r
2 * Copyright (c) 2007-2010 SlimDX Group\r
3\r
4 * Permission is hereby granted, free of charge, to any person obtaining a copy\r
5 * of this software and associated documentation files (the "Software"), to deal\r
6 * in the Software without restriction, including without limitation the rights\r
7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r
8 * copies of the Software, and to permit persons to whom the Software is\r
9 * furnished to do so, subject to the following conditions:\r
10\r
11 * The above copyright notice and this permission notice shall be included in\r
12 * all copies or substantial portions of the Software.\r
13\r
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r
17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r
18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r
19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\r
20 * THE SOFTWARE.\r
21 */\r
22 #include "stdafx.h"\r
23 #include <dinput.h>\r
24 \r
25 #include "PeriodicForce.h"\r
26 \r
27 using namespace System;\r
28 \r
29 namespace SlimDX\r
30 {\r
31 namespace DirectInput\r
32 {\r
33         PeriodicForce::PeriodicForce()\r
34         {\r
35         }\r
36 \r
37         PeriodicForce^ PeriodicForce::FromData( void *data, int size )\r
38         {\r
39                 if( size != sizeof( DIPERIODIC ) )\r
40                         return nullptr;\r
41 \r
42                 PeriodicForce^ force = gcnew PeriodicForce();\r
43                 DIPERIODIC *ptr = reinterpret_cast<DIPERIODIC*>( data );\r
44                 \r
45                 force->Magnitude = ptr->dwMagnitude;\r
46                 force->Offset = ptr->lOffset;\r
47                 force->Phase = ptr->dwPhase;\r
48                 force->Period = ptr->dwPeriod;\r
49 \r
50                 return force;\r
51         }\r
52 \r
53         int PeriodicForce::Size::get()\r
54         {\r
55                 return sizeof( DIPERIODIC );\r
56         }\r
57 \r
58         void *PeriodicForce::ToUnmanaged()\r
59         {\r
60                 // Manual Allocation: released in Release function\r
61                 DIPERIODIC *result = new DIPERIODIC();\r
62 \r
63                 result->dwMagnitude = Magnitude;\r
64                 result->dwPeriod = Period;\r
65                 result->dwPhase = Phase;\r
66                 result->lOffset = Offset;\r
67 \r
68                 return result;\r
69         }\r
70 \r
71         void PeriodicForce::Release( void* data )\r
72         {\r
73                 delete data;\r
74         }\r
75 \r
76         ConstantForce^ PeriodicForce::AsConstantForce()\r
77         {\r
78                 return nullptr;\r
79         }\r
80 \r
81         CustomForce^ PeriodicForce::AsCustomForce()\r
82         {\r
83                 return nullptr;\r
84         }\r
85 \r
86         PeriodicForce^ PeriodicForce::AsPeriodicForce()\r
87         {\r
88                 return this;\r
89         }\r
90 \r
91         RampForce^ PeriodicForce::AsRampForce()\r
92         {\r
93                 return nullptr;\r
94         }\r
95 \r
96         ConditionSet^ PeriodicForce::AsConditionSet()\r
97         {\r
98                 return nullptr;\r
99         }\r
100 }\r
101 }