More stuff, should be almost feature complete (but bugged as hell, probably), I should start real testing tomorrow, hopefully
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@15350 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
9743fe8729
commit
9bd3f620bc
@ -7,7 +7,9 @@
|
||||
|
||||
#include <Debug.h>
|
||||
|
||||
const static int32 kMaxPoints = 1024;
|
||||
using namespace std;
|
||||
|
||||
const static int32 kMaxPoints = 512;
|
||||
const static int32 kMaxVerticalExtent = 0x10000000;
|
||||
const static int32 kMaxPositive = 0x7ffffffd;
|
||||
const static int32 kMaxNegative = 0x80000003;
|
||||
@ -309,6 +311,20 @@ ClipRegion::WriteToLink(BPrivate::ServerLink &link)
|
||||
#endif
|
||||
|
||||
// private methods
|
||||
static int
|
||||
leftComparator(const void *a, const void *b)
|
||||
{
|
||||
return ((clipping_rect *)(a))->left > ((clipping_rect *)(b))->left;
|
||||
}
|
||||
|
||||
|
||||
static int
|
||||
topComparator(const void *a, const void *b)
|
||||
{
|
||||
return ((clipping_rect *)(a))->top > ((clipping_rect *)(b))->top;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
ClipRegion::_IntersectWithComplex(const ClipRegion ®ion)
|
||||
{
|
||||
@ -323,7 +339,7 @@ ClipRegion::_IntersectWithComplex(const ClipRegion ®ion)
|
||||
}
|
||||
|
||||
if (dest.fCount > 1)
|
||||
dest._SortRects();
|
||||
qsort(dest.fData, sizeof(clipping_rect), dest.fCount, topComparator);
|
||||
|
||||
_Adopt(dest);
|
||||
}
|
||||
@ -386,6 +402,7 @@ ClipRegion::_IncludeNoIntersection(const ClipRegion ®ion)
|
||||
}
|
||||
|
||||
|
||||
|
||||
void
|
||||
ClipRegion::_IncludeComplex(const ClipRegion ®ion)
|
||||
{
|
||||
@ -407,8 +424,8 @@ ClipRegion::_IncludeComplex(const ClipRegion ®ion)
|
||||
+ region._ExtractStripRects(top, bottom, &rects[rectsCount], &b);
|
||||
|
||||
if (rectsCount > 0) {
|
||||
//if (rectsCount > 1)
|
||||
// SortTrans(lefts, rights, foundCount);
|
||||
if (rectsCount > 1)
|
||||
qsort(rects, sizeof(clipping_rect), rectsCount, leftComparator);
|
||||
dest._MergeAndInclude(rects, rectsCount);
|
||||
}
|
||||
}
|
||||
@ -422,39 +439,41 @@ ClipRegion::_IncludeComplex(const ClipRegion ®ion)
|
||||
void
|
||||
ClipRegion::_ExcludeComplex(const ClipRegion ®ion)
|
||||
{
|
||||
}
|
||||
/*
|
||||
int32 bottom = min_c(fBound.top, region.fBound.top) - 1;
|
||||
int32 a = 0, b = 0;
|
||||
ClipRegion dest;
|
||||
while (true) {
|
||||
int32 top = bottom + 1;
|
||||
bottom = region._FindSmallestBottom(_FindSmallestBottom(top, a), b);
|
||||
|
||||
if (bottom == kMaxVerticalExtent)
|
||||
break;
|
||||
|
||||
// Helper method to swap two rects
|
||||
static inline void
|
||||
SwapRects(clipping_rect &rect, clipping_rect &anotherRect)
|
||||
{
|
||||
clipping_rect tmpRect = rect;
|
||||
rect = anotherRect;
|
||||
anotherRect = tmpRect;
|
||||
}
|
||||
clipping_rect rectsA[kMaxPoints];
|
||||
rectsA[0].top = top;
|
||||
rectsA[0].bottom = bottom;
|
||||
|
||||
clipping_rect rectsB[kMaxPoints];
|
||||
rectsB[0].top = top;
|
||||
rectsB[0].bottom = bottom;
|
||||
|
||||
void
|
||||
ClipRegion::_SortRects()
|
||||
{
|
||||
bool again;
|
||||
int32 foundA = _ExtractStripRects(top, bottom, rectsA, &a);
|
||||
int32 foundB = region._ExtractStripRects(top, bottom, rectsB, &b);
|
||||
|
||||
if (fCount == 2) {
|
||||
if (fData[0].top > fData[1].top)
|
||||
SwapRects(fData[0], fData[1]);
|
||||
if (foundA > 1)
|
||||
qsort(rectsA, sizeof(clipping_rect), foundA, leftComparator);
|
||||
|
||||
if (foundB > 1)
|
||||
qsort(rectsB, sizeof(clipping_rect), foundB, leftComparator);
|
||||
|
||||
// TODO: Do the actual exclusion
|
||||
|
||||
} else if (fCount > 2) {
|
||||
do {
|
||||
again = false;
|
||||
for (int32 c = 1; c < fCount; c++) {
|
||||
if (fData[c - 1].top > fData[c].top) {
|
||||
SwapRects(fData[c - 1], fData[c]);
|
||||
again = true;
|
||||
}
|
||||
}
|
||||
} while (again);
|
||||
}
|
||||
|
||||
dest._Coalesce();
|
||||
_Adopt(dest);
|
||||
*/
|
||||
}
|
||||
|
||||
|
||||
@ -562,6 +581,9 @@ ClipRegion::_ExtractStripRects(const int32 &top, const int32 &bottom, clipping_r
|
||||
break;
|
||||
}
|
||||
|
||||
if (*inOutIndex == -1)
|
||||
*inOutIndex = currentIndex;
|
||||
|
||||
return foundCount;
|
||||
}
|
||||
|
||||
|
@ -7,6 +7,7 @@ namespace BPrivate {
|
||||
class ServerLink;
|
||||
};
|
||||
|
||||
|
||||
class ClipRegion {
|
||||
public:
|
||||
ClipRegion();
|
||||
@ -68,7 +69,6 @@ private:
|
||||
void _IncludeComplex(const ClipRegion ®ion);
|
||||
void _ExcludeComplex(const ClipRegion ®ion);
|
||||
|
||||
void _SortRects();
|
||||
void _AddRect(const clipping_rect &rect);
|
||||
void _RecalculateBounds(const clipping_rect &newRect);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user