X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Ftexturecube.cpp;h=743eb986247eb95318c98490179b3fdb95683980;hb=d2efbd8a32efa2a3ee8542efc846277af19d63e0;hp=b071e8545df50ce665b1476b0683058a00af0590;hpb=e37851b98dde5082ee92570354746f2f92e21940;p=libs%2Fgl.git diff --git a/source/texturecube.cpp b/source/texturecube.cpp index b071e854..743eb986 100644 --- a/source/texturecube.cpp +++ b/source/texturecube.cpp @@ -23,6 +23,7 @@ Vector3 TextureCube::directions[6] = TextureCube::TextureCube(): Texture(GL_TEXTURE_CUBE_MAP), + ifmt(RGB), size(0), allocated(0) { @@ -46,8 +47,10 @@ void TextureCube::allocate(unsigned level) if(allocated&(1<>=1, ++level) ; allocated |= (1<(img.get_data()); + unsigned face_size = img.get_stride()*size; + for(unsigned i=0; i<6; ++i) + image(enumerate_faces(i), 0, fmt, UNSIGNED_BYTE, cdata+i*face_size); +} + unsigned TextureCube::get_level_size(unsigned level) { return size>>level; @@ -166,6 +192,11 @@ Vector3 TextureCube::get_texel_direction(TextureCubeFace face, unsigned u, unsig return fv+s*sv+t*tv; } +UInt64 TextureCube::get_data_size() const +{ + return id ? size*size*6*get_pixel_size(ifmt) : 0; +} + TextureCube::Loader::Loader(TextureCube &t): DataFile::DerivedObjectLoader(t)