Begin transfering implementations to the new API functions
git-svn-id: file:///srv/svn/repos/haiku/trunk/current@6836 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
52c2367204
commit
f0446088b3
@ -82,7 +82,7 @@ AccelerantDriver::~AccelerantDriver(void)
|
|||||||
*/
|
*/
|
||||||
bool AccelerantDriver::Initialize(void)
|
bool AccelerantDriver::Initialize(void)
|
||||||
{
|
{
|
||||||
/* int i;
|
int i;
|
||||||
char signature[1024];
|
char signature[1024];
|
||||||
char path[PATH_MAX];
|
char path[PATH_MAX];
|
||||||
struct stat accelerant_stat;
|
struct stat accelerant_stat;
|
||||||
@ -154,12 +154,7 @@ bool AccelerantDriver::Initialize(void)
|
|||||||
return false;
|
return false;
|
||||||
if ( GetDisplayMode(&mDisplayMode) != B_OK )
|
if ( GetDisplayMode(&mDisplayMode) != B_OK )
|
||||||
return false;
|
return false;
|
||||||
_SetDepth(GetDepthFromColorspace(mDisplayMode.space));
|
SetMode(mDisplayMode);
|
||||||
_SetWidth(mDisplayMode.virtual_width);
|
|
||||||
_SetHeight(mDisplayMode.virtual_height);
|
|
||||||
_SetMode(GetModeFromResolution(mDisplayMode.virtual_width,mDisplayMode.virtual_height,
|
|
||||||
GetDepthFromColorspace(mDisplayMode.space)));
|
|
||||||
|
|
||||||
memcpy(&R5DisplayMode,&mDisplayMode,sizeof(display_mode));
|
memcpy(&R5DisplayMode,&mDisplayMode,sizeof(display_mode));
|
||||||
#else
|
#else
|
||||||
SetMode(B_8_BIT_640x480);
|
SetMode(B_8_BIT_640x480);
|
||||||
@ -187,7 +182,6 @@ bool AccelerantDriver::Initialize(void)
|
|||||||
FillRect(BRect(0,0,1024,768),blue);
|
FillRect(BRect(0,0,1024,768),blue);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
*/
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -199,7 +193,6 @@ bool AccelerantDriver::Initialize(void)
|
|||||||
*/
|
*/
|
||||||
void AccelerantDriver::Shutdown(void)
|
void AccelerantDriver::Shutdown(void)
|
||||||
{
|
{
|
||||||
/*
|
|
||||||
#ifdef RUN_UNDER_R5
|
#ifdef RUN_UNDER_R5
|
||||||
set_display_mode SetDisplayMode = (set_display_mode)accelerant_hook(B_SET_DISPLAY_MODE, NULL);
|
set_display_mode SetDisplayMode = (set_display_mode)accelerant_hook(B_SET_DISPLAY_MODE, NULL);
|
||||||
if ( SetDisplayMode )
|
if ( SetDisplayMode )
|
||||||
@ -212,7 +205,6 @@ void AccelerantDriver::Shutdown(void)
|
|||||||
unload_add_on(accelerant_image);
|
unload_add_on(accelerant_image);
|
||||||
if (card_fd >= 0)
|
if (card_fd >= 0)
|
||||||
close(card_fd);
|
close(card_fd);
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -1522,3 +1514,140 @@ int AccelerantDriver::GetDepthFromColorspace(int space)
|
|||||||
}
|
}
|
||||||
return depth;
|
return depth;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AccelerantDriver::Blit(const BRect &src, const BRect &dest, const DrawData *d)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void AccelerantDriver::FillSolidRect(const BRect &rect, RGBColor &color)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void AccelerantDriver::FillPatternRect(const BRect &rect, const DrawData *d)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void AccelerantDriver::StrokeSolidLine(const BPoint &start, const BPoint &end, RGBColor &color)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void AccelerantDriver::StrokePatternLine(int32 x1, int32 y1, int32 x2, int32 y2, const DrawData *d)
|
||||||
|
{
|
||||||
|
int32 dx = x2 - x1;
|
||||||
|
int32 dy = y2 - y1;
|
||||||
|
int32 steps, k;
|
||||||
|
double xInc, yInc;
|
||||||
|
double x = x1;
|
||||||
|
double y = y1;
|
||||||
|
|
||||||
|
if ( abs(dx) > abs(dy) )
|
||||||
|
steps = abs(dx);
|
||||||
|
else
|
||||||
|
steps = abs(dy);
|
||||||
|
xInc = dx / (double) steps;
|
||||||
|
yInc = dy / (double) steps;
|
||||||
|
|
||||||
|
//(driver->*setPixel)(ROUND(x),ROUND(y));
|
||||||
|
for (k=0; k<steps; k++)
|
||||||
|
{
|
||||||
|
x += xInc;
|
||||||
|
y += yInc;
|
||||||
|
//(driver->*setPixel)(ROUND(x),ROUND(y));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void AccelerantDriver::StrokeSolidRect(const BRect &rect, RGBColor &color)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void AccelerantDriver::CopyBitmap(ServerBitmap *bitmap, const BRect &source, const BRect &dest, const DrawData *d)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void AccelerantDriver::CopyToBitmap(ServerBitmap *destbmp, const BRect &sourcerect)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
if(!destbmp)
|
||||||
|
{
|
||||||
|
printf("CopyToBitmap returned - not init or NULL bitmap\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(((uint32)destbmp->ColorSpace() & 0x000F) != (_displaymode.space & 0x000F))
|
||||||
|
{
|
||||||
|
printf("CopyToBitmap returned - unequal buffer pixel depth\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
BRect destrect(destbmp->Bounds()), source(sourcerect);
|
||||||
|
|
||||||
|
uint8 colorspace_size=destbmp->BitsPerPixel()/8;
|
||||||
|
|
||||||
|
// First, clip source rect to destination
|
||||||
|
if(source.Width() > destrect.Width())
|
||||||
|
source.right=source.left+destrect.Width();
|
||||||
|
|
||||||
|
if(source.Height() > destrect.Height())
|
||||||
|
source.bottom=source.top+destrect.Height();
|
||||||
|
|
||||||
|
|
||||||
|
// Second, check rectangle bounds against their own bitmaps
|
||||||
|
BRect work_rect(destbmp->Bounds());
|
||||||
|
|
||||||
|
if( !(work_rect.Contains(destrect)) )
|
||||||
|
{
|
||||||
|
// something in selection must be clipped
|
||||||
|
if(destrect.left < 0)
|
||||||
|
destrect.left = 0;
|
||||||
|
if(destrect.right > work_rect.right)
|
||||||
|
destrect.right = work_rect.right;
|
||||||
|
if(destrect.top < 0)
|
||||||
|
destrect.top = 0;
|
||||||
|
if(destrect.bottom > work_rect.bottom)
|
||||||
|
destrect.bottom = work_rect.bottom;
|
||||||
|
}
|
||||||
|
|
||||||
|
work_rect.Set(0,0,_displaymode.virtual_width-1,_displaymode.virtual_height-1);
|
||||||
|
|
||||||
|
if(!work_rect.Contains(sourcerect))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if( !(work_rect.Contains(source)) )
|
||||||
|
{
|
||||||
|
// something in selection must be clipped
|
||||||
|
if(source.left < 0)
|
||||||
|
source.left = 0;
|
||||||
|
if(source.right > work_rect.right)
|
||||||
|
source.right = work_rect.right;
|
||||||
|
if(source.top < 0)
|
||||||
|
source.top = 0;
|
||||||
|
if(source.bottom > work_rect.bottom)
|
||||||
|
source.bottom = work_rect.bottom;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set pointers to the actual data
|
||||||
|
uint8 *dest_bits = (uint8*) destbmp->Bits();
|
||||||
|
uint8 *src_bits = (uint8*) _target->Bits();
|
||||||
|
|
||||||
|
// Get row widths for offset looping
|
||||||
|
uint32 dest_width = uint32 (destbmp->BytesPerRow());
|
||||||
|
uint32 src_width = uint32 (_target->BytesPerRow());
|
||||||
|
|
||||||
|
// Offset bitmap pointers to proper spot in each bitmap
|
||||||
|
src_bits += uint32 ( (source.top * src_width) + (source.left * colorspace_size) );
|
||||||
|
dest_bits += uint32 ( (destrect.top * dest_width) + (destrect.left * colorspace_size) );
|
||||||
|
|
||||||
|
|
||||||
|
uint32 line_length = uint32 ((destrect.right - destrect.left+1)*colorspace_size);
|
||||||
|
uint32 lines = uint32 (source.bottom-source.top+1);
|
||||||
|
|
||||||
|
for (uint32 pos_y=0; pos_y<lines; pos_y++)
|
||||||
|
{
|
||||||
|
memcpy(dest_bits,src_bits,line_length);
|
||||||
|
|
||||||
|
// Increment offsets
|
||||||
|
src_bits += src_width;
|
||||||
|
dest_bits += dest_width;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
@ -84,6 +84,17 @@ protected:
|
|||||||
int GetHeightFromMode(int mode);
|
int GetHeightFromMode(int mode);
|
||||||
int GetDepthFromMode(int mode);
|
int GetDepthFromMode(int mode);
|
||||||
int GetDepthFromColorspace(int space);
|
int GetDepthFromColorspace(int space);
|
||||||
|
|
||||||
|
// Support functions for the rest of the driver
|
||||||
|
void Blit(const BRect &src, const BRect &dest, const DrawData *d);
|
||||||
|
void FillSolidRect(const BRect &rect, RGBColor &color);
|
||||||
|
void FillPatternRect(const BRect &rect, const DrawData *d);
|
||||||
|
void StrokeSolidLine(const BPoint &start, const BPoint &end, RGBColor &color);
|
||||||
|
void StrokePatternLine(int32 x1, int32 y1, int32 x2, int32 y2, const DrawData *d);
|
||||||
|
void StrokeSolidRect(const BRect &rect, RGBColor &color);
|
||||||
|
void CopyBitmap(ServerBitmap *bitmap, const BRect &source, const BRect &dest, const DrawData *d);
|
||||||
|
void CopyToBitmap(ServerBitmap *target, const BRect &source);
|
||||||
|
|
||||||
ServerCursor *cursor, *under_cursor;
|
ServerCursor *cursor, *under_cursor;
|
||||||
|
|
||||||
BRect cursorframe;
|
BRect cursorframe;
|
||||||
|
@ -762,7 +762,7 @@ void BitmapDriver::StrokeSolidLine(const BPoint &start, const BPoint &end, RGBCo
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void BitmapDriver::StrokePatternLine(const BPoint &start, const BPoint &end, const DrawData *d)
|
void BitmapDriver::StrokePatternLine(int32 x1, int32 y1, int32 x2, int32 y2, const DrawData *d)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -84,7 +84,7 @@ protected:
|
|||||||
virtual void FillSolidRect(const BRect &rect, RGBColor &color);
|
virtual void FillSolidRect(const BRect &rect, RGBColor &color);
|
||||||
virtual void FillPatternRect(const BRect &rect, const DrawData *d);
|
virtual void FillPatternRect(const BRect &rect, const DrawData *d);
|
||||||
virtual void StrokeSolidLine(const BPoint &start, const BPoint &end, RGBColor &color);
|
virtual void StrokeSolidLine(const BPoint &start, const BPoint &end, RGBColor &color);
|
||||||
virtual void StrokePatternLine(const BPoint &start, const BPoint &end, const DrawData *d);
|
virtual void StrokePatternLine(int32 x1, int32 y1, int32 x2, int32 y2, const DrawData *d);
|
||||||
virtual void StrokeSolidRect(const BRect &rect, RGBColor &color);
|
virtual void StrokeSolidRect(const BRect &rect, RGBColor &color);
|
||||||
virtual void CopyBitmap(ServerBitmap *bitmap, const BRect &source, const BRect &dest, const DrawData *d);
|
virtual void CopyBitmap(ServerBitmap *bitmap, const BRect &source, const BRect &dest, const DrawData *d);
|
||||||
virtual void CopyToBitmap(ServerBitmap *target, const BRect &source);
|
virtual void CopyToBitmap(ServerBitmap *target, const BRect &source);
|
||||||
|
@ -34,11 +34,9 @@
|
|||||||
#include "RectUtils.h"
|
#include "RectUtils.h"
|
||||||
#include "ServerCursor.h"
|
#include "ServerCursor.h"
|
||||||
|
|
||||||
// TODO: Major cleanup is left. Public functions should be repsonsible for locking.
|
// TODO: Remove remnants of old API. Inplement all functions. Bounds checking needs to be
|
||||||
// Clean the locking code from the protected functions. Remove bounds checking stuff
|
// handled by the public drawing functions.
|
||||||
// since clipper must handle all needed boundary checks (otherwise we could have windows
|
// Add clipping and make sure public functions have Lock & Unlock.
|
||||||
// bleeding into other windows).
|
|
||||||
// TODO: Add pixel, line, and rect functions for handling all of the options from LayerData
|
|
||||||
|
|
||||||
LineCalc::LineCalc()
|
LineCalc::LineCalc()
|
||||||
{
|
{
|
||||||
@ -849,20 +847,15 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &span, const DrawData *d)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Called for all BView::FillArc calls
|
\brief Called for all BView::FillArc calls
|
||||||
\param r Rectangle enclosing the entire arc
|
\param r Rectangle enclosing the entire arc
|
||||||
\param angle Starting angle for the arc in degrees
|
\param angle Starting angle for the arc in degrees
|
||||||
\param span Span of the arc in degrees. Ending angle = angle+span.
|
\param span Span of the arc in degrees. Ending angle = angle+span.
|
||||||
\param setLIne The horizontal line drawing function which handles needed things like pattern,
|
\param d Object holding the bazillion other options
|
||||||
color, and line thickness
|
|
||||||
*/
|
*/
|
||||||
void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &span,
|
|
||||||
DisplayDriver* driver, SetHorizontalLineFuncType setLine)
|
void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &span, const DrawData *d)
|
||||||
{
|
{
|
||||||
float xc = (r.left+r.right)/2;
|
float xc = (r.left+r.right)/2;
|
||||||
float yc = (r.top+r.bottom)/2;
|
float yc = (r.top+r.bottom)/2;
|
||||||
@ -883,12 +876,11 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
int startQuad, endQuad;
|
int startQuad, endQuad;
|
||||||
bool useQuad1, useQuad2, useQuad3, useQuad4;
|
bool useQuad1, useQuad2, useQuad3, useQuad4;
|
||||||
bool shortspan = false;
|
bool shortspan = false;
|
||||||
//BPoint center(xc,yc);
|
|
||||||
|
|
||||||
// Watch out for bozos giving us whacko spans
|
// Watch out for bozos giving us whacko spans
|
||||||
if ( (span >= 360) || (span <= -360) )
|
if ( (span >= 360) || (span <= -360) )
|
||||||
{
|
{
|
||||||
FillEllipse(r,driver,setLine);
|
FillEllipse(r,d);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -939,27 +931,13 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ( useQuad1 )
|
if ( useQuad1 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc-y),ROUND(xc+x),ROUND(yc-y),d);
|
||||||
if ( useQuad2 )
|
if ( useQuad2 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc-x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc-y),ROUND(xc-x),ROUND(yc-y),d);
|
||||||
if ( useQuad3 )
|
if ( useQuad3 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc-x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc),ROUND(yc+y),ROUND(xc-x),ROUND(yc+y),d);
|
||||||
if ( useQuad4 )
|
if ( useQuad4 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc),ROUND(yc+y),ROUND(xc+x),ROUND(yc+y),d);
|
||||||
/*
|
|
||||||
if ( (!shortspan && (((startQuad == 1) && (x <= startx)) || ((endQuad == 1) && (x >= endx)))) ||
|
|
||||||
(shortspan && (startQuad == 1) && (x <= startx) && (x >= endx)) )
|
|
||||||
StrokeLine(BPoint(xc+x,yc-y),center,d,pat);
|
|
||||||
if ( (!shortspan && (((startQuad == 2) && (x >= startx)) || ((endQuad == 2) && (x <= endx)))) ||
|
|
||||||
(shortspan && (startQuad == 2) && (x >= startx) && (x <= endx)) )
|
|
||||||
StrokeLine(BPoint(xc-x,yc-y),center,d,pat);
|
|
||||||
if ( (!shortspan && (((startQuad == 3) && (x <= startx)) || ((endQuad == 3) && (x >= endx)))) ||
|
|
||||||
(shortspan && (startQuad == 3) && (x <= startx) && (x >= endx)) )
|
|
||||||
StrokeLine(BPoint(xc-x,yc+y),center,d,pat);
|
|
||||||
if ( (!shortspan && (((startQuad == 4) && (x >= startx)) || ((endQuad == 4) && (x <= endx)))) ||
|
|
||||||
(shortspan && (startQuad == 4) && (x >= startx) && (x <= endx)) )
|
|
||||||
StrokeLine(BPoint(xc+x,yc+y),center,d,pat);
|
|
||||||
*/
|
|
||||||
|
|
||||||
p = ROUND (Ry2 - (Rx2 * ry) + (.25 * Rx2));
|
p = ROUND (Ry2 - (Rx2 * ry) + (.25 * Rx2));
|
||||||
while (px < py)
|
while (px < py)
|
||||||
@ -976,23 +954,23 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ( useQuad1 )
|
if ( useQuad1 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc-y),ROUND(xc+x),ROUND(yc-y),d);
|
||||||
if ( useQuad2 )
|
if ( useQuad2 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc-x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc-y),ROUND(xc-x),ROUND(yc-y),d);
|
||||||
if ( useQuad3 )
|
if ( useQuad3 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc-x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc),ROUND(yc+y),ROUND(xc-x),ROUND(yc+y),d);
|
||||||
if ( useQuad4 )
|
if ( useQuad4 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc),ROUND(yc+y),ROUND(xc+x),ROUND(yc+y),d);
|
||||||
if ( !shortspan )
|
if ( !shortspan )
|
||||||
{
|
{
|
||||||
if ( startQuad == 1 )
|
if ( startQuad == 1 )
|
||||||
{
|
{
|
||||||
if ( x <= startx )
|
if ( x <= startx )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc-y),ROUND(xc+x),ROUND(yc-y),d);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*startx/(double)starty);
|
xclip = ROUND(y*startx/(double)starty);
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+xclip),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc-y),ROUND(xc+xclip),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( startQuad == 2 )
|
else if ( startQuad == 2 )
|
||||||
@ -1000,17 +978,17 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
if ( x >= startx )
|
if ( x >= startx )
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*startx/(double)starty);
|
xclip = ROUND(y*startx/(double)starty);
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc-xclip),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc-y),ROUND(xc-xclip),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( startQuad == 3 )
|
else if ( startQuad == 3 )
|
||||||
{
|
{
|
||||||
if ( x <= startx )
|
if ( x <= startx )
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc+y),ROUND(xc),ROUND(yc+y),d);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*startx/(double)starty);
|
xclip = ROUND(y*startx/(double)starty);
|
||||||
(driver->*setLine)(ROUND(xc-xclip),ROUND(xc),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-xclip),ROUND(yc+y),ROUND(xc),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( startQuad == 4 )
|
else if ( startQuad == 4 )
|
||||||
@ -1018,7 +996,7 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
if ( x >= startx )
|
if ( x >= startx )
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*startx/(double)starty);
|
xclip = ROUND(y*startx/(double)starty);
|
||||||
(driver->*setLine)(ROUND(xc+xclip),ROUND(xc+x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc+xclip),ROUND(yc+y),ROUND(xc+x),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1027,17 +1005,17 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
if ( x >= endx )
|
if ( x >= endx )
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*endx/(double)endy);
|
xclip = ROUND(y*endx/(double)endy);
|
||||||
(driver->*setLine)(ROUND(xc+xclip),ROUND(xc+x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc+xclip),ROUND(yc-y),ROUND(xc+x),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( endQuad == 2 )
|
else if ( endQuad == 2 )
|
||||||
{
|
{
|
||||||
if ( x <= endx )
|
if ( x <= endx )
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc-y),ROUND(xc),ROUND(yc-y),d);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*endx/(double)endy);
|
xclip = ROUND(y*endx/(double)endy);
|
||||||
(driver->*setLine)(ROUND(xc-xclip),ROUND(xc),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-xclip),ROUND(yc-y),ROUND(xc),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( endQuad == 3 )
|
else if ( endQuad == 3 )
|
||||||
@ -1045,17 +1023,17 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
if ( x >= endx )
|
if ( x >= endx )
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*endx/(double)endy);
|
xclip = ROUND(y*endx/(double)endy);
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc-xclip),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc+y),ROUND(xc-xclip),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( endQuad == 4 )
|
else if ( endQuad == 4 )
|
||||||
{
|
{
|
||||||
if ( x <= endx )
|
if ( x <= endx )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc),ROUND(yc+y),ROUND(xc+x),ROUND(yc+y),d);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*endx/(double)endy);
|
xclip = ROUND(y*endx/(double)endy);
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+xclip),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc),ROUND(yc+y),ROUND(xc+xclip),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1066,30 +1044,30 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
if ( startQuad == 1 )
|
if ( startQuad == 1 )
|
||||||
{
|
{
|
||||||
if ( (x <= startx) && (x >= endx) )
|
if ( (x <= startx) && (x >= endx) )
|
||||||
(driver->*setLine)(ROUND(xc+endclip),ROUND(xc+x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc+endclip),ROUND(yc-y),ROUND(xc+x),ROUND(yc-y),d);
|
||||||
else
|
else
|
||||||
(driver->*setLine)(ROUND(xc+endclip),ROUND(xc+startclip),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc+endclip),ROUND(yc-y),ROUND(xc+startclip),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
else if ( startQuad == 2 )
|
else if ( startQuad == 2 )
|
||||||
{
|
{
|
||||||
if ( (x <= startx) && (x >= endx) )
|
if ( (x <= startx) && (x >= endx) )
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc-startclip),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc-y),ROUND(xc-startclip),ROUND(yc-y),d);
|
||||||
else
|
else
|
||||||
(driver->*setLine)(ROUND(xc-endclip),ROUND(xc-startclip),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-endclip),ROUND(yc-y),ROUND(xc-startclip),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
else if ( startQuad == 3 )
|
else if ( startQuad == 3 )
|
||||||
{
|
{
|
||||||
if ( (x <= startx) && (x >= endx) )
|
if ( (x <= startx) && (x >= endx) )
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc-endclip),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc+y),ROUND(xc-endclip),ROUND(yc+y),d);
|
||||||
else
|
else
|
||||||
(driver->*setLine)(ROUND(xc-startclip),ROUND(xc-endclip),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-startclip),ROUND(yc+y),ROUND(xc-endclip),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
else if ( startQuad == 4 )
|
else if ( startQuad == 4 )
|
||||||
{
|
{
|
||||||
if ( (x <= startx) && (x >= endx) )
|
if ( (x <= startx) && (x >= endx) )
|
||||||
(driver->*setLine)(ROUND(xc+startclip),ROUND(xc+x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc+startclip),ROUND(yc+y),ROUND(xc+x),ROUND(yc+y),d);
|
||||||
else
|
else
|
||||||
(driver->*setLine)(ROUND(xc+startclip),ROUND(xc+endclip),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc+startclip),ROUND(yc+y),ROUND(xc+endclip),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1109,23 +1087,23 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ( useQuad1 )
|
if ( useQuad1 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc-y),ROUND(xc+x),ROUND(yc-y),d);
|
||||||
if ( useQuad2 )
|
if ( useQuad2 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc-x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc-y),ROUND(xc-x),ROUND(yc-y),d);
|
||||||
if ( useQuad3 )
|
if ( useQuad3 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc-x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc),ROUND(yc+y),ROUND(xc-x),ROUND(yc+y),d);
|
||||||
if ( useQuad4 )
|
if ( useQuad4 )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc),ROUND(yc+y),ROUND(xc+x),ROUND(yc+y),d);
|
||||||
if ( !shortspan )
|
if ( !shortspan )
|
||||||
{
|
{
|
||||||
if ( startQuad == 1 )
|
if ( startQuad == 1 )
|
||||||
{
|
{
|
||||||
if ( x <= startx )
|
if ( x <= startx )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc-y),ROUND(xc+x),ROUND(yc-y),d);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*startx/(double)starty);
|
xclip = ROUND(y*startx/(double)starty);
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+xclip),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc-y),ROUND(xc+xclip),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( startQuad == 2 )
|
else if ( startQuad == 2 )
|
||||||
@ -1133,17 +1111,17 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
if ( x >= startx )
|
if ( x >= startx )
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*startx/(double)starty);
|
xclip = ROUND(y*startx/(double)starty);
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc-xclip),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc-y),ROUND(xc-xclip),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( startQuad == 3 )
|
else if ( startQuad == 3 )
|
||||||
{
|
{
|
||||||
if ( x <= startx )
|
if ( x <= startx )
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc+y),ROUND(xc),ROUND(yc+y),d);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*startx/(double)starty);
|
xclip = ROUND(y*startx/(double)starty);
|
||||||
(driver->*setLine)(ROUND(xc-xclip),ROUND(xc),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-xclip),ROUND(yc+y),ROUND(xc),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( startQuad == 4 )
|
else if ( startQuad == 4 )
|
||||||
@ -1151,7 +1129,7 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
if ( x >= startx )
|
if ( x >= startx )
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*startx/(double)starty);
|
xclip = ROUND(y*startx/(double)starty);
|
||||||
(driver->*setLine)(ROUND(xc+xclip),ROUND(xc+x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc+xclip),ROUND(yc+y),ROUND(xc+x),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1160,17 +1138,17 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
if ( x >= endx )
|
if ( x >= endx )
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*endx/(double)endy);
|
xclip = ROUND(y*endx/(double)endy);
|
||||||
(driver->*setLine)(ROUND(xc+xclip),ROUND(xc+x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc+xclip),ROUND(yc-y),ROUND(xc+x),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( endQuad == 2 )
|
else if ( endQuad == 2 )
|
||||||
{
|
{
|
||||||
if ( x <= endx )
|
if ( x <= endx )
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc-y),ROUND(xc),ROUND(yc-y),d);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*endx/(double)endy);
|
xclip = ROUND(y*endx/(double)endy);
|
||||||
(driver->*setLine)(ROUND(xc-xclip),ROUND(xc),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-xclip),ROUND(yc-y),ROUND(xc),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( endQuad == 3 )
|
else if ( endQuad == 3 )
|
||||||
@ -1178,17 +1156,17 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
if ( x >= endx )
|
if ( x >= endx )
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*endx/(double)endy);
|
xclip = ROUND(y*endx/(double)endy);
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc-xclip),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc+y),ROUND(xc-xclip),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( endQuad == 4 )
|
else if ( endQuad == 4 )
|
||||||
{
|
{
|
||||||
if ( x <= endx )
|
if ( x <= endx )
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc),ROUND(yc+y),ROUND(xc+x),ROUND(yc+y),d);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
xclip = ROUND(y*endx/(double)endy);
|
xclip = ROUND(y*endx/(double)endy);
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc+xclip),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc),ROUND(yc+y),ROUND(xc+xclip),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1199,34 +1177,35 @@ void DisplayDriver::FillArc(const BRect &r, const float &angle, const float &spa
|
|||||||
if ( startQuad == 1 )
|
if ( startQuad == 1 )
|
||||||
{
|
{
|
||||||
if ( (x <= startx) && (x >= endx) )
|
if ( (x <= startx) && (x >= endx) )
|
||||||
(driver->*setLine)(ROUND(xc+endclip),ROUND(xc+x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc+endclip),ROUND(yc-y),ROUND(xc+x),ROUND(yc-y),d);
|
||||||
else
|
else
|
||||||
(driver->*setLine)(ROUND(xc+endclip),ROUND(xc+startclip),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc+endclip),ROUND(yc-y),ROUND(xc+startclip),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
else if ( startQuad == 2 )
|
else if ( startQuad == 2 )
|
||||||
{
|
{
|
||||||
if ( (x <= startx) && (x >= endx) )
|
if ( (x <= startx) && (x >= endx) )
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc-startclip),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc-y),ROUND(xc-startclip),ROUND(yc-y),d);
|
||||||
else
|
else
|
||||||
(driver->*setLine)(ROUND(xc-endclip),ROUND(xc-startclip),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-endclip),ROUND(yc-y),ROUND(xc-startclip),ROUND(yc-y),d);
|
||||||
}
|
}
|
||||||
else if ( startQuad == 3 )
|
else if ( startQuad == 3 )
|
||||||
{
|
{
|
||||||
if ( (x <= startx) && (x >= endx) )
|
if ( (x <= startx) && (x >= endx) )
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc-endclip),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc+y),ROUND(xc-endclip),ROUND(yc+y),d);
|
||||||
else
|
else
|
||||||
(driver->*setLine)(ROUND(xc-startclip),ROUND(xc-endclip),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-startclip),ROUND(yc+y),ROUND(xc-endclip),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
else if ( startQuad == 4 )
|
else if ( startQuad == 4 )
|
||||||
{
|
{
|
||||||
if ( (x <= startx) && (x >= endx) )
|
if ( (x <= startx) && (x >= endx) )
|
||||||
(driver->*setLine)(ROUND(xc+startclip),ROUND(xc+x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc+startclip),ROUND(yc+y),ROUND(xc+x),ROUND(yc+y),d);
|
||||||
else
|
else
|
||||||
(driver->*setLine)(ROUND(xc+startclip),ROUND(xc+endclip),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc+startclip),ROUND(yc+y),ROUND(xc+endclip),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Unlock();
|
Unlock();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DisplayDriver::FillBezier(BPoint *pts, RGBColor &color)
|
void DisplayDriver::FillBezier(BPoint *pts, RGBColor &color)
|
||||||
@ -1321,16 +1300,13 @@ void DisplayDriver::FillEllipse(const BRect &r, RGBColor &color)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void DisplayDriver::FillEllipse(const BRect &r, const DrawData *d)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Called for all BView::FillEllipse calls
|
\brief Called for all BView::FillEllipse calls
|
||||||
\param r BRect enclosing the ellipse to be drawn.
|
\param r BRect enclosing the ellipse to be drawn.
|
||||||
\param setLine Horizontal line drawing routine which handles things like color and pattern.
|
\param d DrawData containing the endless options
|
||||||
*/
|
*/
|
||||||
void DisplayDriver::FillEllipse(const BRect &r, DisplayDriver* driver, SetHorizontalLineFuncType setLine)
|
|
||||||
|
void DisplayDriver::FillEllipse(const BRect &r, const DrawData *d)
|
||||||
{
|
{
|
||||||
float xc = (r.left+r.right)/2;
|
float xc = (r.left+r.right)/2;
|
||||||
float yc = (r.top+r.bottom)/2;
|
float yc = (r.top+r.bottom)/2;
|
||||||
@ -1348,10 +1324,8 @@ void DisplayDriver::FillEllipse(const BRect &r, DisplayDriver* driver, SetHorizo
|
|||||||
|
|
||||||
Lock();
|
Lock();
|
||||||
|
|
||||||
//SetPixel(ROUND(xc),ROUND(yc-y),pattern.GetColor(xc,yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc-y),ROUND(xc),ROUND(yc-y),d);
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc),ROUND(yc+y),ROUND(xc),ROUND(yc+y),d);
|
||||||
//SetPixel(ROUND(xc),ROUND(yc+y),pattern.GetColor(xc,yc+y));
|
|
||||||
(driver->*setLine)(ROUND(xc),ROUND(xc),ROUND(yc+y));
|
|
||||||
|
|
||||||
p = ROUND (Ry2 - (Rx2 * ry) + (.25 * Rx2));
|
p = ROUND (Ry2 - (Rx2 * ry) + (.25 * Rx2));
|
||||||
while (px < py)
|
while (px < py)
|
||||||
@ -1367,8 +1341,8 @@ void DisplayDriver::FillEllipse(const BRect &r, DisplayDriver* driver, SetHorizo
|
|||||||
p += Ry2 + px - py;
|
p += Ry2 + px - py;
|
||||||
}
|
}
|
||||||
|
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc+x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc-y),ROUND(xc+x),ROUND(yc-y),d);
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc+x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc+y),ROUND(xc+x),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
|
|
||||||
p = ROUND(Ry2*(x+.5)*(x+.5) + Rx2*(y-1)*(y-1) - Rx2*Ry2);
|
p = ROUND(Ry2*(x+.5)*(x+.5) + Rx2*(y-1)*(y-1) - Rx2*Ry2);
|
||||||
@ -1385,8 +1359,8 @@ void DisplayDriver::FillEllipse(const BRect &r, DisplayDriver* driver, SetHorizo
|
|||||||
p += Rx2 - py +px;
|
p += Rx2 - py +px;
|
||||||
}
|
}
|
||||||
|
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc+x),ROUND(yc-y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc-y),ROUND(xc+x),ROUND(yc-y),d);
|
||||||
(driver->*setLine)(ROUND(xc-x),ROUND(xc+x),ROUND(yc+y));
|
StrokePatternLine(ROUND(xc-x),ROUND(yc+y),ROUND(xc+x),ROUND(yc+y),d);
|
||||||
}
|
}
|
||||||
Unlock();
|
Unlock();
|
||||||
}
|
}
|
||||||
@ -1395,20 +1369,13 @@ void DisplayDriver::FillPolygon(BPoint *ptlist, int32 numpts, RGBColor &color)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void DisplayDriver::FillPolygon(BPoint *ptlist, int32 numpts, const DrawData *d)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Called for all BView::FillPolygon calls
|
\brief Called for all BView::FillPolygon calls
|
||||||
\param ptlist Array of BPoints defining the polygon.
|
\param ptlist Array of BPoints defining the polygon.
|
||||||
\param numpts Number of points in the BPoint array.
|
\param numpts Number of points in the BPoint array.
|
||||||
\param setLine Horizontal line drawing routine which handles things like color and pattern.
|
\param d The 50 bazillion drawing options (inluding clip region)
|
||||||
|
|
||||||
The points in the array are not guaranteed to be within the framebuffer's
|
|
||||||
coordinate range.
|
|
||||||
*/
|
*/
|
||||||
void DisplayDriver::FillPolygon(BPoint *ptlist, int32 numpts, DisplayDriver* driver, SetHorizontalLineFuncType setLine)
|
void DisplayDriver::FillPolygon(BPoint *ptlist, int32 numpts, const DrawData *d)
|
||||||
{
|
{
|
||||||
/* Here's the plan. Record all line segments in polygon. If a line segments crosses
|
/* Here's the plan. Record all line segments in polygon. If a line segments crosses
|
||||||
the y-value of a point not in the segment, split the segment into 2 segments.
|
the y-value of a point not in the segment, split the segment into 2 segments.
|
||||||
@ -1508,16 +1475,16 @@ void DisplayDriver::FillPolygon(BPoint *ptlist, int32 numpts, DisplayDriver* dri
|
|||||||
{
|
{
|
||||||
if ( (segmentArray[i].MinX() < _displaymode.virtual_width) &&
|
if ( (segmentArray[i].MinX() < _displaymode.virtual_width) &&
|
||||||
(segmentArray[i].MaxX() >= 0) )
|
(segmentArray[i].MaxX() >= 0) )
|
||||||
(driver->*setLine)(ROUND(segmentArray[i].MinX()),
|
StrokePatternLine(ROUND(segmentArray[i].MinX()), y,
|
||||||
ROUND(segmentArray[i].MaxX()), y);
|
ROUND(segmentArray[i].MaxX()), y, d);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if ( (segmentArray[i].GetX(y) < _displaymode.virtual_width) &&
|
if ( (segmentArray[i].GetX(y) < _displaymode.virtual_width) &&
|
||||||
(segmentArray[i+1].GetX(y) >= 0) )
|
(segmentArray[i+1].GetX(y) >= 0) )
|
||||||
(driver->*setLine)(ROUND(segmentArray[i].GetX(y)),
|
StrokePatternLine(ROUND(segmentArray[i].GetX(y)), y,
|
||||||
ROUND(segmentArray[i+1].GetX(y)), y);
|
ROUND(segmentArray[i+1].GetX(y)), y, d);
|
||||||
i+=2;
|
i+=2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1591,19 +1558,14 @@ void DisplayDriver::FillRoundRect(const BRect &r, const float &xrad, const float
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void DisplayDriver::FillRoundRect(const BRect &r, const float &xrad, const float &yrad, const DrawData *d)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Called for all BView::FillRoundRect calls
|
\brief Called for all BView::FillRoundRect calls
|
||||||
\param r The rectangle itself
|
\param r The rectangle itself
|
||||||
\param xrad X radius of the corner arcs
|
\param xrad X radius of the corner arcs
|
||||||
\param yrad Y radius of the corner arcs
|
\param yrad Y radius of the corner arcs
|
||||||
\param setRect Rectangle filling routine which handles things like color and pattern
|
\param d DrawData containing all other options
|
||||||
\param setLine Horizontal line drawing function which handles things like color and pattern
|
|
||||||
*/
|
*/
|
||||||
void DisplayDriver::FillRoundRect(const BRect &r, const float &xrad, const float &yrad, DisplayDriver* driver, SetRectangleFuncType setRect, SetHorizontalLineFuncType setLine)
|
void DisplayDriver::FillRoundRect(const BRect &r, const float &xrad, const float &yrad, const DrawData *d)
|
||||||
{
|
{
|
||||||
float arc_x;
|
float arc_x;
|
||||||
float yrad2 = yrad*yrad;
|
float yrad2 = yrad*yrad;
|
||||||
@ -1612,12 +1574,13 @@ void DisplayDriver::FillRoundRect(const BRect &r, const float &xrad, const float
|
|||||||
for (i=0; i<=(int)yrad; i++)
|
for (i=0; i<=(int)yrad; i++)
|
||||||
{
|
{
|
||||||
arc_x = xrad*sqrt(1-i*i/yrad2);
|
arc_x = xrad*sqrt(1-i*i/yrad2);
|
||||||
(driver->*setLine)(ROUND(r.left+xrad-arc_x), ROUND(r.right-xrad+arc_x),
|
StrokePatternLine(ROUND(r.left+xrad-arc_x), ROUND(r.top+yrad-i),
|
||||||
ROUND(r.top+yrad-i));
|
ROUND(r.right-xrad+arc_x), ROUND(r.top+yrad-i),d);
|
||||||
(driver->*setLine)(ROUND(r.left+xrad-arc_x), ROUND(r.right-xrad+arc_x),
|
StrokePatternLine(ROUND(r.left+xrad-arc_x), ROUND(r.bottom-yrad+i),
|
||||||
ROUND(r.bottom-yrad+i));
|
ROUND(r.right-xrad+arc_x), ROUND(r.bottom-yrad+i),d);
|
||||||
}
|
}
|
||||||
(driver->*setRect)((int)(r.left),(int)(r.top+yrad),(int)(r.right),(int)(r.bottom-yrad));
|
FillPatternRect(BRect(r.left,r.top+yrad,r.right,r.bottom-yrad),d);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//void DisplayDriver::FillShape(SShape *sh, const DrawData *d, const Pattern &pat)
|
//void DisplayDriver::FillShape(SShape *sh, const DrawData *d, const Pattern &pat)
|
||||||
@ -1628,16 +1591,12 @@ void DisplayDriver::FillTriangle(BPoint *pts, RGBColor &color)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void DisplayDriver::FillTriangle(BPoint *pts, const DrawData *d)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Called for all BView::FillTriangle calls
|
\brief Called for all BView::FillTriangle calls
|
||||||
\param pts Array of 3 BPoints. Always non-NULL.
|
\param pts Array of 3 BPoints. Always non-NULL.
|
||||||
\param setLine Horizontal line drawing routine which handles things like color and pattern.
|
\param setLine Horizontal line drawing routine which handles things like color and pattern.
|
||||||
*/
|
*/
|
||||||
void DisplayDriver::FillTriangle(BPoint *pts, DisplayDriver* driver, SetHorizontalLineFuncType setLine)
|
void DisplayDriver::FillTriangle(BPoint *pts, const DrawData *d)
|
||||||
{
|
{
|
||||||
if ( !pts )
|
if ( !pts )
|
||||||
return;
|
return;
|
||||||
@ -1686,7 +1645,7 @@ void DisplayDriver::FillTriangle(BPoint *pts, DisplayDriver* driver, SetHorizont
|
|||||||
end.y=first.y;
|
end.y=first.y;
|
||||||
start.x=MIN(first.x,MIN(second.x,third.x));
|
start.x=MIN(first.x,MIN(second.x,third.x));
|
||||||
end.x=MAX(first.x,MAX(second.x,third.x));
|
end.x=MAX(first.x,MAX(second.x,third.x));
|
||||||
(driver->*setLine)(ROUND(start.x), ROUND(end.x), ROUND(start.y));
|
StrokePatternLine(ROUND(start.x), ROUND(start.y), ROUND(end.x), ROUND(start.y), d);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1698,9 +1657,9 @@ void DisplayDriver::FillTriangle(BPoint *pts, DisplayDriver* driver, SetHorizont
|
|||||||
LineCalc lineA(first, third);
|
LineCalc lineA(first, third);
|
||||||
LineCalc lineB(second, third);
|
LineCalc lineB(second, third);
|
||||||
|
|
||||||
(driver->*setLine)(ROUND(first.x), ROUND(second.x), ROUND(first.y));
|
StrokePatternLine(ROUND(first.x), ROUND(first.y), ROUND(second.x), ROUND(first.y), d);
|
||||||
for(i=(int32)first.y+1; i<=third.y; i++)
|
for(i=(int32)first.y+1; i<=third.y; i++)
|
||||||
(driver->*setLine)(ROUND(lineA.GetX(i)), ROUND(lineB.GetX(i)), i);
|
StrokePatternLine(ROUND(lineA.GetX(i)), i, ROUND(lineB.GetX(i)), i, d);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1710,9 +1669,9 @@ void DisplayDriver::FillTriangle(BPoint *pts, DisplayDriver* driver, SetHorizont
|
|||||||
LineCalc lineA(first, second);
|
LineCalc lineA(first, second);
|
||||||
LineCalc lineB(first, third);
|
LineCalc lineB(first, third);
|
||||||
|
|
||||||
(driver->*setLine)(ROUND(second.x), ROUND(third.x), ROUND(second.y));
|
StrokePatternLine(ROUND(second.x), ROUND(second.y), ROUND(third.x), ROUND(second.y), d);
|
||||||
for(i=(int32)first.y; i<third.y; i++)
|
for(i=(int32)first.y; i<third.y; i++)
|
||||||
(driver->*setLine)(ROUND(lineA.GetX(i)), ROUND(lineB.GetX(i)), i);
|
StrokePatternLine(ROUND(lineA.GetX(i)), i, ROUND(lineB.GetX(i)), i, d);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1722,10 +1681,11 @@ void DisplayDriver::FillTriangle(BPoint *pts, DisplayDriver* driver, SetHorizont
|
|||||||
LineCalc lineC(second, third);
|
LineCalc lineC(second, third);
|
||||||
|
|
||||||
for(i=(int32)first.y; i<(int32)second.y; i++)
|
for(i=(int32)first.y; i<(int32)second.y; i++)
|
||||||
(driver->*setLine)(ROUND(lineA.GetX(i)), ROUND(lineB.GetX(i)), i);
|
StrokePatternLine(ROUND(lineA.GetX(i)), i, ROUND(lineB.GetX(i)), i, d);
|
||||||
|
|
||||||
for(i=(int32)second.y; i<=third.y; i++)
|
for(i=(int32)second.y; i<=third.y; i++)
|
||||||
(driver->*setLine)(ROUND(lineC.GetX(i)), ROUND(lineB.GetX(i)), i);
|
StrokePatternLine(ROUND(lineC.GetX(i)), i, ROUND(lineB.GetX(i)), i, d);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -2236,7 +2196,8 @@ void DisplayDriver::StrokeEllipse(const BRect &r, DisplayDriver* driver, SetPixe
|
|||||||
void DisplayDriver::StrokeLine(const BPoint &start, const BPoint &end, RGBColor &color)
|
void DisplayDriver::StrokeLine(const BPoint &start, const BPoint &end, RGBColor &color)
|
||||||
{
|
{
|
||||||
Lock();
|
Lock();
|
||||||
StrokeSolidLine(start,end,color);
|
//Not quite that simple bub
|
||||||
|
//StrokeSolidLine(start,end,color);
|
||||||
Unlock();
|
Unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2289,23 +2250,12 @@ void DisplayDriver::StrokePolygon(BPoint *ptlist, int32 numpts, RGBColor &color,
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
Lock();
|
Lock();
|
||||||
|
/*
|
||||||
for(int32 i=0; i<(numpts-1); i++)
|
for(int32 i=0; i<(numpts-1); i++)
|
||||||
StrokeSolidLine(ptlist[i],ptlist[i+1],color);
|
StrokeSolidLine(ptlist[i],ptlist[i+1],color);
|
||||||
if(is_closed)
|
if(is_closed)
|
||||||
StrokeSolidLine(ptlist[numpts-1],ptlist[0],color);
|
StrokeSolidLine(ptlist[numpts-1],ptlist[0],color);
|
||||||
Unlock();
|
*/
|
||||||
}
|
|
||||||
|
|
||||||
void DisplayDriver::StrokePolygon(BPoint *ptlist, int32 numpts, const DrawData *d, bool is_closed)
|
|
||||||
{
|
|
||||||
if(!ptlist)
|
|
||||||
return;
|
|
||||||
|
|
||||||
Lock();
|
|
||||||
for(int32 i=0; i<(numpts-1); i++)
|
|
||||||
StrokePatternLine(ptlist[i],ptlist[i+1],d);
|
|
||||||
if(is_closed)
|
|
||||||
StrokePatternLine(ptlist[numpts-1],ptlist[0],d);
|
|
||||||
Unlock();
|
Unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2313,14 +2263,19 @@ void DisplayDriver::StrokePolygon(BPoint *ptlist, int32 numpts, const DrawData *
|
|||||||
\brief Called for all BView::StrokePolygon calls
|
\brief Called for all BView::StrokePolygon calls
|
||||||
\param ptlist Array of BPoints defining the polygon.
|
\param ptlist Array of BPoints defining the polygon.
|
||||||
\param numpts Number of points in the BPoint array.
|
\param numpts Number of points in the BPoint array.
|
||||||
\param setPixel Pixel drawing function which handles things like size and pattern.
|
\param d DrawData containing all of the other options
|
||||||
*/
|
*/
|
||||||
void DisplayDriver::StrokePolygon(BPoint *ptlist, int32 numpts, DisplayDriver* driver, SetPixelFuncType setPixel, bool is_closed)
|
void DisplayDriver::StrokePolygon(BPoint *ptlist, int32 numpts, const DrawData *d, bool is_closed)
|
||||||
{
|
{
|
||||||
|
if(!ptlist)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Lock();
|
||||||
for(int32 i=0; i<(numpts-1); i++)
|
for(int32 i=0; i<(numpts-1); i++)
|
||||||
StrokeLine(ptlist[i],ptlist[i+1],driver,setPixel);
|
StrokeLine(ptlist[i],ptlist[i+1],d);
|
||||||
if(is_closed)
|
if(is_closed)
|
||||||
StrokeLine(ptlist[numpts-1],ptlist[0],driver,setPixel);
|
StrokeLine(ptlist[numpts-1],ptlist[0],d);
|
||||||
|
Unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -2339,21 +2294,13 @@ void DisplayDriver::StrokeRect(const BRect &r, RGBColor &color)
|
|||||||
void DisplayDriver::StrokeRect(const BRect &r, const DrawData *d)
|
void DisplayDriver::StrokeRect(const BRect &r, const DrawData *d)
|
||||||
{
|
{
|
||||||
Lock();
|
Lock();
|
||||||
StrokePatternLine(r.LeftTop(),r.RightTop(),d);
|
StrokeLine(r.LeftTop(),r.RightTop(),d);
|
||||||
StrokePatternLine(r.LeftTop(),r.LeftBottom(),d);
|
StrokeLine(r.LeftTop(),r.LeftBottom(),d);
|
||||||
StrokePatternLine(r.RightTop(),r.RightBottom(),d);
|
StrokeLine(r.RightTop(),r.RightBottom(),d);
|
||||||
StrokePatternLine(r.LeftBottom(),r.RightBottom(),d);
|
StrokeLine(r.LeftBottom(),r.RightBottom(),d);
|
||||||
Unlock();
|
Unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DisplayDriver::StrokeRect(const BRect &r, DisplayDriver* driver, SetHorizontalLineFuncType setHLine, SetVerticalLineFuncType setVLine)
|
|
||||||
{
|
|
||||||
(driver->*setHLine)((int)ROUND(r.left), (int)ROUND(r.right), (int)ROUND(r.top));
|
|
||||||
(driver->*setVLine)((int)ROUND(r.right), (int)ROUND(r.top), (int)ROUND(r.bottom));
|
|
||||||
(driver->*setHLine)((int)ROUND(r.left), (int)ROUND(r.right), (int)ROUND(r.bottom));
|
|
||||||
(driver->*setVLine)((int)ROUND(r.left), (int)ROUND(r.top), (int)ROUND(r.bottom));
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Convenience function for server use
|
\brief Convenience function for server use
|
||||||
\param r BRegion to be stroked
|
\param r BRegion to be stroked
|
||||||
@ -2385,20 +2332,14 @@ void DisplayDriver::StrokeRoundRect(const BRect &r, const float &xrad, const flo
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void DisplayDriver::StrokeRoundRect(const BRect &r, const float &xrad, const float &yrad, const DrawData *d)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Called for all BView::StrokeRoundRect calls
|
\brief Called for all BView::StrokeRoundRect calls
|
||||||
\param r The rect itself
|
\param r The rect itself
|
||||||
\param xrad X radius of the corner arcs
|
\param xrad X radius of the corner arcs
|
||||||
\param yrad Y radius of the corner arcs
|
\param yrad Y radius of the corner arcs
|
||||||
\param setHLine Horizontal line drawing function
|
\param d DrawData containing all other options
|
||||||
\param setVLine Vertical line drawing function
|
|
||||||
\param setPixel Pixel drawing function
|
|
||||||
*/
|
*/
|
||||||
void DisplayDriver::StrokeRoundRect(const BRect &r, const float &xrad, const float &yrad, DisplayDriver* driver, SetHorizontalLineFuncType setHLine, SetVerticalLineFuncType setVLine, SetPixelFuncType setPixel)
|
void DisplayDriver::StrokeRoundRect(const BRect &r, const float &xrad, const float &yrad, const DrawData *d)
|
||||||
{
|
{
|
||||||
int hLeft, hRight;
|
int hLeft, hRight;
|
||||||
int vTop, vBottom;
|
int vTop, vBottom;
|
||||||
@ -2412,17 +2353,20 @@ void DisplayDriver::StrokeRoundRect(const BRect &r, const float &xrad, const flo
|
|||||||
bRight = hRight -xrad;
|
bRight = hRight -xrad;
|
||||||
bTop = vTop + yrad;
|
bTop = vTop + yrad;
|
||||||
bBottom = vBottom - yrad;
|
bBottom = vBottom - yrad;
|
||||||
StrokeArc(BRect(bRight, r.top, r.right, bTop), 0, 90, driver, setPixel);
|
|
||||||
(driver->*setHLine)(hRight, hLeft, (int)ROUND(r.top));
|
|
||||||
|
|
||||||
StrokeArc(BRect(r.left,r.top,bLeft,bTop), 90, 90, driver, setPixel);
|
Lock();
|
||||||
(driver->*setVLine)((int)ROUND(r.left),vTop,vBottom);
|
StrokeArc(BRect(bRight, r.top, r.right, bTop), 0, 90, d);
|
||||||
|
StrokeLine(BPoint(hRight, r.top), BPoint(hLeft, r.top), d);
|
||||||
|
|
||||||
StrokeArc(BRect(r.left,bBottom,bLeft,r.bottom), 180, 90, driver, setPixel);
|
StrokeArc(BRect(r.left,r.top,bLeft,bTop), 90, 90, d);
|
||||||
(driver->*setHLine)(hLeft, hRight, ROUND(r.bottom));
|
StrokeLine(BPoint(r.left, vTop), BPoint(r.left, vBottom), d);
|
||||||
|
|
||||||
StrokeArc(BRect(bRight,bBottom,r.right,r.bottom), 270, 90, driver, setPixel);
|
StrokeArc(BRect(r.left,bBottom,bLeft,r.bottom), 180, 90, d);
|
||||||
(driver->*setVLine)((int)ROUND(r.right),vBottom,vTop);
|
StrokeLine(BPoint(hLeft, r.bottom), BPoint(hRight, r.bottom), d);
|
||||||
|
|
||||||
|
StrokeArc(BRect(bRight,bBottom,r.right,r.bottom), 270, 90, d);
|
||||||
|
StrokeLine(BPoint(r.right, vBottom), BPoint(r.right, vTop), d);
|
||||||
|
Unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
//void DisplayDriver::StrokeShape(SShape *sh, const DrawData *d, const Pattern &pat)
|
//void DisplayDriver::StrokeShape(SShape *sh, const DrawData *d, const Pattern &pat)
|
||||||
@ -2447,9 +2391,9 @@ void DisplayDriver::StrokeTriangle(BPoint *pts, RGBColor &color)
|
|||||||
void DisplayDriver::StrokeTriangle(BPoint *pts, const DrawData *d)
|
void DisplayDriver::StrokeTriangle(BPoint *pts, const DrawData *d)
|
||||||
{
|
{
|
||||||
Lock();
|
Lock();
|
||||||
StrokePatternLine(pts[0],pts[1],d);
|
StrokeLine(pts[0],pts[1],d);
|
||||||
StrokePatternLine(pts[1],pts[2],d);
|
StrokeLine(pts[1],pts[2],d);
|
||||||
StrokePatternLine(pts[2],pts[0],d);
|
StrokeLine(pts[2],pts[0],d);
|
||||||
Unlock();
|
Unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3013,11 +2957,13 @@ void DisplayDriver::FillPatternRect(const BRect &rect, const DrawData *d)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Draws a line with pensize 1. Coordinates are guarenteed to be in bounds */
|
||||||
void DisplayDriver::StrokeSolidLine(const BPoint &start, const BPoint &end, RGBColor &color)
|
void DisplayDriver::StrokeSolidLine(const BPoint &start, const BPoint &end, RGBColor &color)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void DisplayDriver::StrokePatternLine(const BPoint &start, const BPoint &end, const DrawData *d)
|
/* Draws a line with pensize 1. Coordinates are guarenteed to be in bounds */
|
||||||
|
void DisplayDriver::StrokePatternLine(int32 x1, int32 y1, int32 x2, int32 y2, const DrawData *d)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user