mirror of
https://github.com/alfishe/amiga-bootcamp.git
synced 2026-06-13 00:26:28 +00:00
Comprehensive technical documentation covering: - Hardware: OCS/ECS/AGA custom chip registers, Copper & Blitter deep dives - Boot sequence: cold boot through startup-sequence - Binary format: HUNK executable spec, relocation, debug info - Linking & ABI: .fd files, LVO tables, register calling conventions - Exec kernel: tasks, interrupts, memory, signals, semaphores - AmigaDOS: file I/O, FFS/OFS layout, CLI/Shell scripting - Graphics: planar bitmaps, Copper programming, HAM/EHB modes - Intuition: screens, windows, IDCMP, BOOPSI - Devices: trackdisk, SCSI, serial, timer, audio, keyboard - Libraries: utility, expansion, IFFParse, locale, ARexx - Networking: bsdsocket API, SANA-II, TCP/IP stack comparison - Toolchain: GCC, vasm/vlink, SAS/C, NDK, debugging - Reverse engineering: IDA/Ghidra setup, compiler fingerprints, case studies - CPU & MMU: 68040/060 emulation libs, PMMU, cache management - Driver development: SANA-II, Picasso96/RTG, AHI audio All files include breadcrumb navigation. No local paths or proprietary content.
3.3 KiB
3.3 KiB
RastPort — Drawing Primitives and Layers
Overview
RastPort is the primary drawing context in AmigaOS. All graphics primitives (pixel, line, rectangle, polygon, text) operate through a RastPort, which links a BitMap, drawing pen colours, pattern, font, and optional Layer for clipping.
struct RastPort
/* graphics/rastport.h — NDK39 */
struct RastPort {
struct Layer *Layer; /* associated layer (NULL = no clipping) */
struct BitMap *BitMap; /* target bitmap */
UWORD *AreaPtrn; /* area fill pattern */
struct TmpRas *TmpRas; /* temp raster for area fills/floods */
struct AreaInfo *AreaInfo; /* area fill vertex buffer */
struct GelsInfo *GelsInfo; /* GEL (BOB/VSprite) list */
UBYTE Mask; /* plane mask (which planes to draw to) */
BYTE FgPen; /* foreground pen colour index */
BYTE BgPen; /* background pen colour index */
BYTE AOlPen; /* area outline pen */
BYTE DrawMode; /* JAM1, JAM2, COMPLEMENT, INVERSVID */
BYTE AreaPtSz; /* area pattern size (log2) */
BYTE linpatcnt; /* line pattern counter */
BYTE dummy;
UWORD Flags; /* FRST_DOT etc. */
UWORD LinePtrn; /* 16-bit line dash pattern */
WORD cp_x, cp_y; /* current pen position */
UWORD minterms[8];
WORD PenWidth;
WORD PenHeight;
struct TextFont *Font; /* current text font */
UBYTE AlgoStyle; /* algorithmic style flags */
UBYTE TxFlags;
UWORD TxHeight;
UWORD TxWidth;
UWORD TxBaseline;
WORD TxSpacing;
APTR *RP_User;
/* ... */
};
Draw Modes
#define JAM1 0 /* draw FgPen only; background transparent */
#define JAM2 1 /* draw FgPen and BgPen (opaque) */
#define COMPLEMENT 2 /* XOR with existing pixels */
#define INVERSVID 4 /* invert video (swap fg/bg for text) */
Drawing Primitives
/* Set pen colour: */
SetAPen(rp, 1); /* foreground = colour 1 */
SetBPen(rp, 0); /* background = colour 0 */
SetDrMd(rp, JAM1); /* transparent background */
/* Move to position: */
Move(rp, 100, 50);
/* Draw line from current position to (x,y): */
Draw(rp, 200, 100);
/* Write pixel: */
WritePixel(rp, 160, 120);
/* Read pixel: */
LONG colour = ReadPixel(rp, 160, 120);
/* Filled rectangle: */
RectFill(rp, 10, 10, 100, 50);
/* Draw text at current position: */
Move(rp, 20, 30);
Text(rp, "Hello", 5);
/* Blitter copy between RastPorts: */
ClipBlit(srcRP, sx, sy, dstRP, dx, dy, w, h, minterm);
Layers
When rp->Layer != NULL, all drawing is clipped to the layer's bounds and damage regions. Layers are managed by layers.library:
struct Layer_Info *li = NewLayerInfo();
struct Layer *layer = CreateUpfrontLayer(li, bm, x1, y1, x2, y2, flags, NULL);
rp = layer->rp; /* use this RastPort for drawing */
/* ... draw ... */
DeleteLayer(0, layer);
DisposeLayerInfo(li);
References
- NDK39:
graphics/rastport.h,graphics/gfxmacros.h - ADCD 2.1:
SetAPen,Move,Draw,Text,RectFill,ClipBlit