What can probably be done is, making InitFromFile call d3drm_create_image, checking if D3DRMIMAGE struct isn't set already, and LoadTexture will call InitFromFIle (on a fresh new object every time LoadTexture is called), whereas CreateTexture will merely HeapAlloc the object and assign the image supplied by the application.


On Sat, Mar 26, 2016 at 2:46 PM, Aaryaman Vasishta <jem456.vasishta@gmail.com> wrote:
For now I used CreateTexture (as the documentation suggested) another way is CreateTextureFromSurface, but that didn't work either (after passing it an off-screen plain surface).

I called IDirect3DRM3_CreateObject(d3drm3, &CLSID_CDirect3DRMTexture, NULL, &IID_IDirect3DRMTexture3, &texture3), which works, then calling InitFromFile on texture3 also returns successfully. It seems that if the image struct is not set within the object, only then InitFromFile works (as InitFromFile didn't work when called on a texture created from LoadTexture or CreateTexture, both of which initialize the image struct member).

On Sat, Mar 26, 2016 at 3:03 AM, Henri Verbeet <hverbeet@gmail.com> wrote:
On 25 March 2016 at 22:20, Aaryaman Vasishta <jem456.vasishta@gmail.com> wrote:
> I wrote a quick test, and it seems that InitFromFile always returns
> D3DRMERR_BADOBJECT, even after passing it an IDirect3DRMTexture created via
> CreateTexture.
How are you creating the texture? The interesting cases are probably
CoCreateInstance() and IDirect3DRM_CreateObject().