rsAdapter.h revision fb6b614bcea88a587a7ea4530be45ff0ffa0210e
1/*
2 * Copyright (C) 2009 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 *      http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef ANDROID_RS_ADAPTER_H
18#define ANDROID_RS_ADAPTER_H
19
20#include "rsAllocation.h"
21
22// ---------------------------------------------------------------------------
23namespace android {
24namespace renderscript {
25
26
27class Adapter1D : public ObjectBase
28{
29
30public:
31    // By policy this allocation will hold a pointer to the type
32    // but will not destroy it on destruction.
33    Adapter1D(Context *);
34    Adapter1D(Context *, Allocation *);
35    void reset();
36    void * getElement(uint32_t x);
37
38    void setAllocation(Allocation *a) {mAllocation.set(a);}
39
40    uint32_t getDimX() const {return mAllocation->getType()->getLODDimX(mLOD);}
41
42    const Type * getBaseType() const {return mAllocation->getType();}
43
44    inline void setY(uint32_t y) {mY = y;}
45    inline void setZ(uint32_t z) {mZ = z;}
46    inline void setLOD(uint32_t lod) {mLOD = lod;}
47    inline void setFace(uint32_t face) {mFace = face;}
48    //void setArray(uint32_t num, uint32_t value);
49
50    void subData(uint32_t xoff, uint32_t count, const void *data);
51    void data(const void *data);
52
53    virtual void serialize(OStream *stream) const;
54    virtual A3DClassID getClassId() const { return A3D_CLASS_ID_ADAPTER_1D; }
55    static Adapter1D *createFromStream(Context *rsc, IStream *stream);
56
57protected:
58    ObjectBaseRef<Allocation> mAllocation;
59    uint32_t mY;
60    uint32_t mZ;
61    uint32_t mLOD;
62    uint32_t mFace;
63};
64
65class Adapter2D : public ObjectBase
66{
67
68public:
69    // By policy this allocation will hold a pointer to the type
70    // but will not destroy it on destruction.
71    Adapter2D(Context *);
72    Adapter2D(Context *, Allocation *);
73    void reset();
74    void * getElement(uint32_t x, uint32_t y) const;
75
76    uint32_t getDimX() const {return mAllocation->getType()->getLODDimX(mLOD);}
77    uint32_t getDimY() const {return mAllocation->getType()->getLODDimY(mLOD);}
78    const Type * getBaseType() const {return mAllocation->getType();}
79
80    void setAllocation(Allocation *a) {mAllocation.set(a);}
81    inline void setZ(uint32_t z) {mZ = z;}
82    inline void setLOD(uint32_t lod) {mLOD = lod;}
83    inline void setFace(uint32_t face) {mFace = face;}
84    //void setArray(uint32_t num, uint32_t value);
85
86    void data(const void *data);
87    void subData(uint32_t xoff, uint32_t yoff, uint32_t w, uint32_t h, const void *data);
88
89    virtual void serialize(OStream *stream) const;
90    virtual A3DClassID getClassId() const { return A3D_CLASS_ID_ADAPTER_2D; }
91    static Adapter2D *createFromStream(Context *rsc, IStream *stream);
92
93protected:
94    ObjectBaseRef<Allocation> mAllocation;
95    uint32_t mZ;
96    uint32_t mLOD;
97    uint32_t mFace;
98};
99
100
101}
102}
103#endif
104
105