Here's a quick cross-tab example specific to your situation:
SELECT D.PersonID,
MAX(CASE WHEN D.Activity = 'Woke Up' THEN D.ActivityTime END) AS WakeUpTime,
MAX(CASE WHEN D.Activity = 'Had Breakfast' THEN D.ActivityTime END) AS BreakfastTime,
MAX(CASE WHEN D.Activity = 'Got Dressed' THEN D.ActivityTime END) AS DressTime
--,...
FROM #data D
GROUP BY D.PersonID
ORDER BY D.PersonID
SQL DBA,SQL Server MVP(07, 08, 09) "It's a dog-eat-dog world, and I'm wearing Milk-Bone underwear." "Norm", on "Cheers". Also from "Cheers", from "Carla": "You need to know 3 things about Tortelli men: Tortelli men draw women like flies; Tortelli men treat women like flies; Tortelli men's brains are in their flies".