TweetFollow Us on Twitter

Animation Contest
Volume Number:1
Issue Number:5
Column Tag:Mousehole

Animation Contest

By David E. Smith

Last month we presented a complete application shell program in assembly that supported desk accessories, cut and past and “about” dialog boxes. But the application itself was rather boring, simply drawing nested boxes in the window. This month, we concentrate on the application itself. To eliminate confusion, we will use the simple shell program from the December issue of MacTutor that simply opens a window. This allows us to concentrate on the application, which is to animate a paddle and ball. Once we understand animation, we can combine our paddle and ball program with the shell program published last month to create a complete Mac game application. But first, the problem of animation.

Animation Contest

The Mousehole recently held a programming contest sponsored by MacTutor on the problem of moving a paddle with the mouse. “Brett” offered an interesting solution: “Have the user blink a lot and pretend!” Another interesting solution offered by “Lone Falcon” and “Chief Wizard” and expanded on by “The Jerk” was to make the cursor a paddle and constrain the cursor to a given rectangle. The trap call “_PinRect” can be used to change the rectangle in which the cursor is allowed to move. Or the rectangle can be poked into the global variable at $834 as mentioned by “The Jerk”. One problem with this solution is that of providing an “escape” for the cursor when you want to go to the menu bar to quit the game!

A simple technique to move the paddle is to draw the paddle rectange where the mouse now is and erase it from where the paddle used to be. The following example code shows how this might be done:


; Copy current paddle to old paddle

LEApaddle, A0
LEAoldpaddle, A1
MOVE.W  0(A0), 0(A1) ;top of rect
MOVE.W  2(A0), 2(A1) ;left of rect
MOVE.W  4(A0), 4(A1) ;bottom 
MOVE.W  6(A0), 6(A1) ;right

; Update paddle position from mouse

; _GetMouse trap previously called
; and mouse coord. saved in Mouse.
; Since paddle moves vertically, only
; the top and bottom coordinates need
; be updated.

LEAMouse, A0;get mouse
LEApaddle, A1  ;get paddle
MOVE.W  (A0), (A1) ;update top
MOVE.W  (A0), D0 ;get top
ADD.W Paddlelength, D0  ;add length
MOVE.W  D0, 4(A1);update bottom

; Erase old paddle position

PEAoldpaddle;push old pad.
_EraseRect;erase it

; Draw new paddle

PEApaddle ;push paddle
PEAPaddlepattern ;push fill pat.
_FillRect ;draw paddle

The Paddle Blinks!

The problem with the above solution, and hence the contest, is that the paddle will blink as it moves up and down. The problem is to improve on the above technique to eliminate the blinking. The reason for the blinking is shown in figure 1.

As shown in figure 1, the paddle blinks because we are erasing and drawing part of the paddle that overlaps, causing it to blink on and off. The solution is to determine the non-overlapping part and erase only that part. One way to do this is to replace the bottom of the old paddle with the top of the new paddle. Then the modified old paddle rectange would be only the cross-hatched area shown in figure 1 as the non-over-lapping part. But that only works for the paddle moving down. If the paddle moves up, then the opposite condition applies as shown in the following code segment:


; create difference rectange

LEApaddle, A0  ;new paddle
LEAoldpaddle, A1 ;old paddle
MOVE.W  (A0), D0 ;get new paddle
MOVE.W  (A1), D1 ;get old paddle
SUB.W D1, D0;top difference
BMIUP ;moving up?

DN: MOVE.W (A0), 4(A1)  ;update bottom
     JMP Eraseit

UP: MOVE.W 4(A0), (A1)  ;update top

Eraseit:  PEA oldpaddle


The above method works fine for a rectangular paddle moving up or down. But what about the ball? The winning solution to our animation contest was posted by “Don L.” in which he explained how regions could be used in a manner similar to what was done above for rectangles. Moreover, the toolbox has a special trap for finding the difference of two regions but does not have a similar trap for rectangles. The solution then is to form a union region of the old and new paddle regions, and then take the difference between the new paddle and this union region. The difference region is then erased and the paddle re-drawn. The result is a non-blinking paddle but using regions instead of rectangles.

In our example program we use “Don L.”’s method to move the ball as a region, and the rectangular method for moving the less complicated paddle rectangle. See the subroutine MOVEPADDLE for the rectangular implmentation discussed above and the subroutine MOVEBALL for the region solution submitted by Don. The tricky part is getting the regions properly defined with NewRgn, OpenRgn and CloseRgn.

Detecting Collisions

Once we have a moving paddle responding to the mouse, and a ball moving towards us, we need to detect if the ball has hit the paddle. A simple way to do this is to use the trap _RectInRgn, which tells if the given rectange intersects with the given region. We have used this trap by pushing the paddle rectange as the given rectange, and the ball region as the given region and tested the returning byte for true or false. If true, then the ball has “hit” the paddle, and we erase the ball and start a new one. If not, then the paddle has “missed” the ball and the game ends on a click of the mouse. Of course, in the final game, we really want the ball to “bounce” and move away from the paddle if there is a hit. We will leave the problem of bouncing for next month.


Our sample program includes all of the topics we’ve discussed this month in a complete program. To conserve space, none of the fancy user interface support we did last month is included. The program opens a window and displays our game field with a rectangular paddle, and launches a ball. If the user hits the ball, it disappears and another ball is launched. If the user misses the ball, the game stops until the button is pressed, at which point the finder is invoked. This is the basic animation required for a pinball type of game. Make note of the INITBALL routine that sets up the three temporary regions for use with the ball, and the MOVEBALL routine which erases the ball by only erasing the non-over-lapping region. Using these techniques, the paddle and ball should move smoothly over the shaded playing field.


The speed of the ball is determined by the increment used to update the ball region. The trap “_OffSetRgn” is used to incrementaly move the ball a small distance (dh, dv). In our example, dh is set at -1 and dv is zero, making the ball move horizontally one pixel left at a time. For a faster moving ball, the horiztonal increment should be doubled in a loop, until the user misses. Try this and see how fast the ball appears to move. Note that moving the paddle very quickly does produce an effect on the speed of the ball slightly.

In figure 2 we see the output from this month’s program. The white ball moves on a field of gray towards the black paddle. The white area was added in MacPaint to reduce the amount of gray, which does not print well.

Resources and Linker Files

The resource and linker files included are the minimum necessary to get an icon to pop up on the desktop. Our icon is shown at the top of the column header, and was produced using the Icon Converter Utility from issue 2 and “included” into our resource source code.

; ANIMATE (MacTutor 1-5)
; VERSION 27 FEB 1985
; (C) 1985 MacTutor by David E. Smith

;    Macro subset for Toolbox stuff

MACRO _InitGraf =  DC.W $A86E|
MACRO _InitWind =DC.W $A912| 
MACRO _NewWindow = DC.W $A913|
MACRO _setport = DC.W $A873|
MACRO _InitFont =DC.W $A8FE|
MACRO _InitMenu =DC.W $A930|
MACRO _InitDialog =DC.W $A97B|
MACRO _TEInit   =DC.W $A9CC|
MACRO _Initpack =         DC.W $A9E5|
MACRO _FlushEvents = DC.W $A032|
MACRO _InitCursor =DC.W $A850|
MACRO _GetNextEvent =DC.W $A970|
MACRO _FrameRect = DC.W $A8A1|
MACRO _BackPat = DC.W $A87C|
MACRO _EraseRect = DC.W $A8A3|
MACRO _NewRgn =  DC.W $A8D8|
MACRO _OpenRgn = DC.W $A8DA|
MACRO _CloseRgn =DC.W $A8DB|
MACRO _FrameRgn =  DC.W $A8D2|
MACRO _FrameRoundRect =   DC.W $A8B0|
MACRO _FillRect =DC.W $A8A5|
MACRO _FillRgn = DC.W $A8D6|
MACRO _BeginUpdate = DC.W $A922|
MACRO _EndUpdate = DC.W $A923|
MACRO _ClipRect =  DC.W $A87B|
MACRO _GetMouse =  DC.W $A972|
MACRO _CopyRgn = DC.W $A8DC|
MACRO _OffsetRgn = DC.W $A8E0|
MACRO _OffsetRect =  DC.W $A8A8|
MACRO _UnionRgn =  DC.W $A8E5|
MACRO _DiffRgn = DC.W $A8E6|
MACRO _MoveTo =  DC.W $A893|
MACRO _DrawChar =  DC.W $A883|
MACRO _RectInRgn = DC.W $A8E9|


XDEF  START           ; required for linker 
MouseDown equ  1
AllEvents equ  $0000FFFF
UpdateEvt equ  6 



PEA -4(A5);push qd global ptr
_InitGraf        ;init quickdraw global 
_InitFont        ; init font manager
_InitWind   ; init window manager
_InitMenu   ; init menu manager  
CLR.L -(SP) ; kill the restart 
_InitDialog ; init dialog manager
_TEInit ; init text edit (ROM) 
MOVE.W  #2,-(SP) ;  set-up
_Initpack ; init package mgr
MOVE.L  #AllEvents,D0    ;all events
_FlushEvents      ;flushed
_InitCursor      ; make cursor the arrow

CLR.L -(SP)          ;return window ptr
CLR.L -(SP)          ;window record ptr.
PEA WBOUNDS               ;window rectangle 
PEA WINDTITLE              ; window title
MOVE.W #$100,-(SP)   ; true = visible 
MOVE.W #0,-(SP)           ; doc type window
MOVE.L #-1,-(SP)          ; window in front
MOVE.W #$100,-(SP)   ; true=closebox
MOVE.L #0, -(SP)         ; reference value 
_NewWindow                ; make new window

LEA WPOINTER,A0         ; copy window ptr 
MOVE.L (SP),(A0)        ; to stacksave
_setport                  ;current window



; --EVENT LOOP ------------


JSRDOGAME ;move paddle with mouse

CLR-(SP);returned event 
MOVE  #AllEvents,-(SP)    ;mask all events
PEAEventRecord   ; event record block
_GetNextEvent    ;go check the mouse 
MOVE  (SP)+,D0   ;get event result 
CMP#0,D0;if 0 then no event 
BEQGetEvent ;loop until it happens

MOVE  What,D0    ;what to do!
CMP#MouseDown,D0     ; button down?
BEQEXIT ;yes so exit...
CMP#UpdateEvt, D0;is it an update event?
BEQUPDATE ;yes, so do it
JMP    GetEvent  ;get next event


; window needs refreshing

MOVE.L  WPOINTER,-(SP)  ;push window ptr
MOVE.L  WPOINTER,-(SP)  ;push our window ptr.
_SetPort;restore our port
 ;least an update draw in
 ;the wrong window.
BSRQDSTUFF;re-draw everything
JMP   GetEvent

; ---------- END OF MAIN ----------

;     INIT GAME VARIABLES,A0 ;set-up appl. window 
MOVE.W #5,    (A0) ; TOP
MOVE.W #5,   2(A0) ;LEFT
MOVE.W #245, 4(A0) ;BOTTOM
MOVE.W #500, 6(A0) ;RIGHT

_ClipRect ;set clip region

LEAPaddle(A5),A0 ;set-up paddle
MOVE.W #6,    (A0) ;TOP
MOVE.W #8,   2(A0) ;LEFT
MOVE.W #40, 4(A0);BOTTOM
MOVE.W #15, 6(A0);RIGHT

LEAPaddlelength(A5),A1  ;update paddle bottom
MOVE.W  (A0),D0
MOVE.W  4(A0),D1
SUB.W   D0,D1
MOVE.W  D1, (A1)

;  set up regions for ball

_NewRgn ;set new region
LEABallrgn(A5), A1 ;make ball a region
MOVE.L  (SP)+,(A1) ;save handle in ballrgn

_NewRgn ;set new region
LEAoldballrgn(A5), A1;make old ball a region
MOVE.L  (SP)+,(A1) ;save handle in oldballrg 

_NewRgn ;set new region
LEAunionrgn(A5), A1;make union ball a region
MOVE.L  (SP)+,(A1) ;save handle in unionrgn

JSRINITBALL ;set-up ball


; ------   init ball subroutine ------


LEABall(A5),A0 ;set-up ball rect
MOVE.W #100,    (A0) ;TOP
MOVE.W #300,   2(A0) ;LEFT
MOVE.W #109, 4(A0) ;BOTTOM
MOVE.W #309, 6(A0) ;RIGHT

LEABallwide(A5),A0 ;set up rounded corners
MOVE.W #6, (A0)
LEABallhigh(A5), A0
MOVE.W #6, (A0)

_OpenRgn;init ball region
MOVE.W  Ballwide(A5),-(SP)
MOVE.W  Ballhigh(A5),-(SP)
MOVE.L  Ballrgn(A5),A0
MOVE.L  A0,-(SP)

_OpenRgn;init oldball region
MOVE.W  Ballwide(A5),-(SP)
MOVE.W  Ballhigh(A5),-(SP)
MOVE.L  oldballrgn(A5),A0
MOVE.L   A0,-(SP)

_OpenRgn;init union region
MOVE.W  Ballwide(A5),-(SP)
MOVE.W  Ballhigh(A5),-(SP)
MOVE.L  unionrgn(A5),A0
MOVE.L  A0,-(SP)


; update game field during null event

LEAmouse(A5),A0  ;current mouse
LEAoldmouse(A5),A1 ;old mouse;find where mouse is
MOVE.W  (A0),D0  ;new mouse
MOVE.W  (A1),D1  ;old mouse
CMPD1,D0;has y mouse changed?
BEQstatck ;no, don’t update paddle
 ;yes, make new paddle
JSRMOVEPADDLE    ;update paddle position

JSRMOVEBALL ;advance ball
JSRBOUNCE ;change ball direction



;      copy paddle position to oldpaddle

LEApaddle(A5), A0
LEAoldpaddle(A5), A1
MOVE.W  (A0), (A1) ;top
MOVE.W  2(A0), 2(A1) ;left
MOVE.W  4(A0), 4(A1) ;bottom
MOVE.W  6(A0), 6(A1) ;right

; update paddle position

LEAmouse(A5),A0  ;get current mouse position
LEApaddle(A5),A1 ;update paddle position
MOVE.W  (A0), (A1) ;update TOP
MOVE.W  (A0),D0  ;calculate BOTTOM
ADD.W Paddlelength(A5),D0
MOVE.W  D0,4(A1) ;update BOTTOM

;   draw new paddle


;    calculate difference rectangle

LEApaddle(A5),A0 ;current paddle
LEAoldpaddle(A5),A1;old paddle
CLR.L   D0
CLR.L   D1
MOVE.W  (A0), D0
MOVE.W  (A1),D1
LEApaddle(A5), A0
LEAoldpaddle(A5), A1
SUB.W D1, D0
dn:   MOVE.W(A0), 4(A1) ;moved down
      BRA wipeout
up: MOVE.W4(A0), (A1);moved up
    BRA wipeout

; update mouse

LEAmouse(A5),A0  ;current mouse
LEAoldmouse(A5),A1 ;old mouse
MOVE.L  (A0),(A1);update old mouse

; ----      MOVE BALL SUBROUTINE ------

;      copy Ballrgn to oldballrgn

MOVE.L  Ballrgn(A5),A0
MOVE.L  A0,-(SP)
MOVE.L  oldballrgn(A5),A0
MOVE.L  A0,-(SP)

; move ball region

MOVE.L  Ballrgn(A5),A0
MOVE.L  A0,-(SP)
MOVE.W  dh,-(SP) ;horiz. increment
MOVE.W  dv, -(SP);vert. increment
_OffsetRgn;offset ball rgn

;   draw new BALL

MOVE.L  Ballrgn(A5),A0
MOVE.L  A0,-(SP)

; erase old ball difference

MOVE.L  Ballrgn(A5),A0
MOVE.L  oldballrgn(A5),A1
MOVE.L  unionrgn(A5),A3
MOVE.L  A0,-(SP)
MOVE.L  A1,-(SP)
MOVE.L  A3,-(SP)

MOVE.L  unionrgn(A5),A0
MOVE.L  Ballrgn(A5),A1
MOVE.L  unionrgn(A5),A3
MOVE.L  A0,-(SP)
MOVE.L  A1,-(SP)
MOVE.L  A3,-(SP)

MOVE.L  unionrgn(A5),A0
MOVE.L  A0,-(SP)


; ---------- BOUNCE BALL --------

PEAPaddle(A5)    ;push rect
MOVE.L  Ballrgn(A5), A0
MOVE.L  A0, -(SP);push rgn handle
MOVE.B  (SP)+, D0
CMP#0, D0 ;false?

MOVE.L  Ballrgn(A5),A0  ;no...
MOVE.L  A0,-(SP) ;erase ball
JSR INITBALL;start new ball





PEA   ;frame rectangle
_FrameRect;draw game rectangle



; ---- RETURN TO FINDER --------

EXIT:        RTS      ; return to finder

; ----LOCAL DATA AREA ----------

WPOINTER: DC.L     0      ;store window pt
WBOUNDS:DC.W   40  ;rectangle top 
 DC.W    2;left
 DC.W    335;bottom
 DC.W    508;right
WINDTITLE:     DC.B    24        ; title length
                 DC.B    ‘BALL AND PADDLE EXAMPLE ‘,0      

 What:  DC.W     0 ; what event
 Message: DC.L     0 ; ptr. to msg
 When:  DC.L     0
 Point:   DC.L     0
 Modify:  DC.W     0

BackPat0: DC.L $AA55AA55  ;playing field
 DC.L $AA55AA55

 DC.L $00000000

dv:DC.W 0
; ------   APPLICATION GLOBALS  ---- DS.W1 ;frame size storage
 DS.W 1 ;for game field rectangle
 DS.W 1
 DS.W 1
Paddle: DS.W1  ;frame size storage
 DS.W 1 ;for paddle rectangle
 DS.W 1
 DS.W 1
oldpaddle:DS.W 1 ;frame size storage
 DS.W 1 ;for paddle rectangle
 DS.W 1
 DS.W 1
Paddlelength:  DS.W1
Ball:   DS.W1  ;frame size storage
 DS.W 1 ;for ball rectangle
 DS.W 1
 DS.W 1 
Ballwide: DS.W 1
Ballhigh: DS.W 1

Ballrgn:DS.L1  ;ball region handle
oldballrgn: DS.L 1 ;old ball region handle
unionrgn: DS.L 1 ;temp region

mouse:  DS.L1
oldmouse: DS.L 1

; ------   END OF PROGRAM -------

/OUTPUT Animate Example




; resource file for the animate example
; created using the assembler
; signiture is creator tag 

 DC.B 30, ‘animate example--Feb. 27, 1985’

    DC.W 0,128 ;MAP 0 TO ICON 128
    DC.W 0,128 ;MAP 0 TO FREF 128

 DC.B ‘APPL’, 0, 0, 0


INCLUDE animate.icon.asm


Community Search:
MacTech Search:

Software Updates via MacUpdate

Trend Micro 11.0.2062 - An essential sec...
Trend Micro Antivirus provides essential security for macOS with real-time malware detection and mitigation in an affordable solution with a simple, intuitive interface. However, be aware that more... Read more
Backblaze - Online backup serv...
Backblaze is an online backup service designed from the ground-up for the Mac. With unlimited storage available for $6 per month, as well as a free 15-day trial, peace of mind is within reach with... Read more
Pro Video Formats 2.2.1 - Updates for pr...
Pro Video Formats includes support for the following professional video codecs: Apple Intermediate Codec Apple ProRes AVC-Intra 50 / 100 / 200 / 4:4:4 / LT AVC-LongG XAVC XF-AVC DVCPRO HD HDV XDCAM... Read more
Boom 3D 1.3.11 - $19.99
Boom 3D is a revolutionary app with 3D Surround Sound and phenomenally rich and intense audio that is realistic and works on any headphones. Features 3D surround sound Built-in audio player... Read more
Final Cut Pro 10.5.2 - Professional vide...
Redesigned from the ground up, Final Cut Pro combines revolutionary video editing with a powerful media organization and incredible performance to let you create at the speed of thought.... Read more
Chromium 89.0.4389.72 - Fast and stable...
Chromium is an open-source browser project that aims to build a safer, faster, and more stable way for all Internet users to experience the web. Version 89.0.4389.72: Complete list of changes can... Read more
iMovie 10.2.3 - Edit personal videos and...
With a streamlined design and intuitive editing features, iMovie lets you create Hollywood-style trailers and beautiful movies like never before. Browse your video library, share favorite moments,... Read more
OmniPlan 4.2.5 - Professional-grade proj...
With OmniPlan, you can create logical, manageable project plans with Gantt charts, schedules, summaries, milestones, and critical paths. Break down the tasks needed to make your project a success,... Read more
Compressor 4.5.2 - Adds power and flexib...
Compressor adds power and flexibility to Final Cut Pro X export. Customize output settings, work faster with distributed encoding, and tap into a comprehensive set of delivery features. Features:... Read more
Motion 5.5.1 - Create and customize Fina...
Motion is designed for video editors, Motion 5 lets you customize Final Cut Pro titles, transitions, and effects. Or create your own dazzling animations in 2D or 3D space, with real-time feedback as... Read more

Latest Forum Discussions

See All

Frogger in Toy Town's latest update...
Konami Digital Entertainment has announced today that their Apple Arcade title Frogger in Toy Town has been updated to introduce a new ranked Endurance Mode. This new game variant's arrival is also accompanied by a few other changes. [Read more] | Read more »
Mitoza is surreal adventure toy you can...
The folks behind the Rusty Lake games have just put a new title onto the App Store. Second Maze, Rusty Lake's collaborative publishing brand, has just brought this 10 year old adventure game from Gal Mamalya to mobile. The best part about all of... | Read more »
Pocket Gamer Awards 2021: You have five...
Three weeks ago our sister site, Pocket Gamer, entered the voting stage for the upcoming Pocket Gamer Awards 2021 and is now in the final stretch. You only have a few hours left to vote for the games you’ve enjoyed on mobile in the past year, as... | Read more »
Patty Stack is a casual arcade game, ava...
Patty Stack is a casual arcade title that's available now for iOS and Android. It's the debut game from developer Feeka Games tasks players with making an increasingly giant burger tower. Think of it as Tower Bloxx but more edible. [Read more] | Read more »
Distract Yourself With These Great Mobil...
There’s a lot going on right now, and I don’t really feel like trying to write some kind of pithy intro for it. All I’ll say is lots of people have been coming together and helping each other in small ways, and I’m choosing to focus on that as I... | Read more »
Genshin Impact Guide - Gacha Strategy: W...
This is part 2 of our Genshin Impact gacha strategy guides. See part 1 here. You can check out more guides for Genshin Impact here. | Read more »
Slashy Camp is a new endless runner insp...
Blue Wizard Digital has released Slashy Camp onto iOS and Android after it spent a short amount of time in early access. [Read more] | Read more »
Kinder World is a relaxing game about lo...
Lumi Interactive is releasing a game called Kinder World later this year on iOS and Android, which is all about looking after houseplants. [Read more] | Read more »
Steam Link Spotlight - Fights in Tight S...
Steam Link Spotlight is a feature where we look at PC games that play exceptionally well using the Steam Link app. Our last entry was on Hades. Read about how it plays using Steam Link over here. | Read more »
Lyxo, the light-based puzzler for mobile...
Vienna-based independent game studio Emoak has just released its unique light-based puzzler for iOS and Android. Founded in 2014 by Tobias Sturn, the company is also the creative force behind the infinite climbing game Paper Climb, as well as the... | Read more »

Price Scanner via

Weekend Sale: $100 off Apple iPad Magic Keybo...
Amazon has Apple iPad Magic Keyboards on sale for $100 off MSRP for a limited time. Amazon’s prices are the lowest available for iPad Magic Keyboard from any Apple reseller this weekend: – Magic... Read more
Gazelle now offering a full line of refurbish...
Gazelle is now offering a full range of discounted, refurbished, unlocked Apple iPhone 12 models starting at $649. iPhones are offered in Fair, Good, and Excellent conditions, and multiple colors are... Read more
These are the latest discounted iPhones Apple...
Apple has a range of Certified Refurbished iPhones available right now starting at only $339. Apple includes a standard one-year warranty, new outer shell, and shipping is free. According to Apple, “... Read more
Save up to $64 on new M1 MacBook Airs at Expe...
Apple reseller Expercom has 2020 13″ M1 MacBook Airs on sale for $51-$64 off Apple’s MSRP with prices starting at $947.96. In addition to their MacBook Air sale prices, take $50 off AppleCare+ when... Read more
Discounts available on 16″ MacBook Pros with...
Upgrade a 16″ 6-Core or 8-Core MacBook Pro from 16GB of standard RAM to 32GB at Adorama, and save $100-$210 over Apple’s price for this custom option: – 16″ 6-Core MacBook Pro/32GB RAM: $2699, save $... Read more
10.9″ iPad Airs on sale for $50-$70 off Apple...
Amazon has new 2020 10.9″ Apple WiFi iPad Airs in stock and on sale today for up to $70 off MSRP with prices starting at $549. Note that Amazon’s sale price might be restricted to certain colors (see... Read more
Apple restocks 2020 27″ 5K iMacs for up to $3...
After an initial offering in January, Apple has restocked a full line of Certified Refurbished 2020 27″ 5K iMacs starting at $1529 and up to $350 off original MSRP. Apple’s one-year warranty is... Read more
Sale! 16″ 8-Core MacBook Pro for $2449, $350...
Apple reseller Adorama has the 16″ 2.3GHz 8-Core Space Gray MacBook Pro in stock and on sale today for $2449 including free shipping. Their price is $350 off Apple’s MSRP for this model, and it’s the... Read more
Roundup of 13″ Multi-Core Intel MacBook Pro s...
Apple resellers are offering significant sales & deals this week on 2020 13″ MacBook Pros with 10th generation Intel CPUs. Take up to $250 off Apple’s MSRP, get free fast shipping, and/or pay no... Read more
64GB iPhone 8 Plus available for $379 at Appl...
Apple has the 64GB iPhone 8 Plus in Space Gray & Gold colors available for $379 today, Certified Refurbished. Each phone is unlocked and comes with Apple’s standard 1-year warranty and free... Read more

Jobs Board

Geek Squad Advanced Repair *Apple* Professi...
**795178BR** **Job Title:** Geek Squad Advanced Repair Apple Professional **Job Category:** Store Associates **Store Number or Department:** 001406-Allen Park-Store Read more
Geek Squad *Apple* Consultation Professiona...
**796549BR** **Job Title:** Geek Squad Apple Consultation Professional **Job Category:** Store Associates **Store Number or Department:** 001800-Hot Springs-Store Read more
*Apple* Mobility Specialist - Best Buy (Unit...
**796014BR** **Job Title:** Apple Mobility Specialist **Job Category:** Store Associates **Store Number or Department:** 001776-Woodmore Towne Centre-Store **Job Read more
Systems Architect, *Apple* Production Engin...
…package beginning on your first day? If so, we hope you'll keep reading! The Apple Sales Engineering and account team is looking for a stellar presales engineer with Read more
Systems Engineer, Webscale, *Apple* Retail,...
…beginning on your first day? If so, we hope you'll keep reading! The Apple Sales Engineering team is looking for a pre-sales engineer with Enterprise engineering Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.