Added a TODO why our bitmap code is currently pretty inefficient.
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@15390 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
9584d7e45e
commit
ec17c60f5a
@ -2244,16 +2244,11 @@ BBitmap::InitObject(BRect bounds, color_space colorSpace, uint32 flags,
|
|||||||
link.Attach<int32>(bytesPerRow);
|
link.Attach<int32>(bytesPerRow);
|
||||||
link.Attach<int32>(screenID.id);
|
link.Attach<int32>(screenID.id);
|
||||||
|
|
||||||
// Reply Code: SERVER_TRUE
|
|
||||||
// Reply Data:
|
// Reply Data:
|
||||||
// 1) int32 server token
|
// 1) int32 server token
|
||||||
// 2) area_id id of the area in which the bitmap data resides
|
// 2) area_id id of the area in which the bitmap data resides
|
||||||
// 3) int32 area pointer offset used to calculate fBasePtr
|
// 3) int32 area pointer offset used to calculate fBasePtr
|
||||||
|
|
||||||
// alternatively, if something went wrong
|
|
||||||
// Reply Code: SERVER_FALSE
|
|
||||||
// Reply Data:
|
|
||||||
// None
|
|
||||||
error = B_ERROR;
|
error = B_ERROR;
|
||||||
if (link.FlushWithReply(error) == B_OK && error == B_OK) {
|
if (link.FlushWithReply(error) == B_OK && error == B_OK) {
|
||||||
// server side success
|
// server side success
|
||||||
@ -2266,6 +2261,8 @@ BBitmap::InitObject(BRect bounds, color_space colorSpace, uint32 flags,
|
|||||||
link.Read<int32>(&areaOffset);
|
link.Read<int32>(&areaOffset);
|
||||||
|
|
||||||
// Get the area in which the data resides
|
// Get the area in which the data resides
|
||||||
|
// TODO: the actual cloning doesn't have to happen before someone calls Bits()
|
||||||
|
// that would make bitmap creation a lot cheaper and faster...
|
||||||
fArea = clone_area("shared bitmap area",
|
fArea = clone_area("shared bitmap area",
|
||||||
(void**)&fBasePtr,
|
(void**)&fBasePtr,
|
||||||
B_ANY_ADDRESS,
|
B_ANY_ADDRESS,
|
||||||
@ -2274,7 +2271,7 @@ BBitmap::InitObject(BRect bounds, color_space colorSpace, uint32 flags,
|
|||||||
if (fArea >= B_OK) {
|
if (fArea >= B_OK) {
|
||||||
// Jump to the location in the area
|
// Jump to the location in the area
|
||||||
fBasePtr = (int8*)fBasePtr + areaOffset;
|
fBasePtr = (int8*)fBasePtr + areaOffset;
|
||||||
|
|
||||||
fSize = size;
|
fSize = size;
|
||||||
fColorSpace = colorSpace;
|
fColorSpace = colorSpace;
|
||||||
fBounds = bounds;
|
fBounds = bounds;
|
||||||
|
Loading…
Reference in New Issue
Block a user