The Cocoa application layer is primarily responsible for the appearance of apps and their responsiveness to user actions. In addition, many of the features that define the OS X user experience—such as Notification Center, full-screen mode, and Auto Save—are implemented by the Cocoa layer.
Read writing about Cocoa in macOS App Development. Stories and technical tips about building apps for macOS (previously OS X). 100 days of OSX Development video tutorials Learn to build Mac. The app makes it easy to add CocoaPods to a new project, or remove it from an existing one. Interesting Tech Swift, CocoaPods, Objective-C, C, XPC, Ruby, RubyCocoa, Storyboards and available for inspection. Note that if you choose to use the -user-install option, you will still have to configure your.bashprofile file to set the PATH or use the command prepended by the full path. You can find out where a gem is installed with gem which cocoapods. $ gem install cocoapods -user-install $ gem which cocoapods /Users/eloy/.gem/ruby/2.0.0/gems/cocoapods-0.29.0/lib/cocoapods.rb $ /Users/eloy/.gem/ruby/2.0.0/bin/pod install. This book aims to provide beginners with an introduction to programming Mac OS X Apps with Cocoa, using XCode, the free developer tools provided by Apple, Inc.Some knowledge of another programming language, preferably Objective C Programming is assumed.
Note: In this book, Cocoa usually refers to the application layer of OS X. In other Apple technical documents, Cocoa frequently refers to all programmatic interfaces that you might use to develop an app, regardless of the layer in which those interfaces reside.
The term Aqua refers to the overall appearance and behavior of OS X. The Aqua look and feel is characterized by consistent, user-friendly behaviors combined with a masterful use of layout, color, and texture. Although much of the Aqua look and feel comes for free when you use Cocoa technologies to develop your app, there are still many steps you should take to distinguish your app from the competition. To create a beautiful, compelling app that users will love, be sure to follow the guidance provided in OS X Human Interface Guidelines.
High-Level Features
The Cocoa (Application) layer implements many features that are distinctive aspects of the OS X user experience. Users expect to find these features throughout the system, so it’s a good idea to support all the features that make sense in your app.
Notification Center
Notification Center provides a way for users to receive and view app notifications in an attractive, unobtrusive way. For each app, users can specify how they want to be notified of an item’s arrival; they can also reveal Notification Center to view all the items that have been delivered.
The Notification Center APIs, which help you configure the user-visible portions of a notification item, schedule items for delivery, and find out when items have been delivered. You can also determine whether your app has launched as a result of a notification, and if it has, whether that notification is a local or remote (that is, push) notification.
To learn about integrating the Notification Center into your app, see NSUserNotificationCenter Class Reference and NSUserNotification Class Reference. To ensure that your app gives users the best Notification Center experience, read Notification Center. In addition, you can add items to the Today view using a Today extension, see Today in the App Extension Programming Guide.
Game Center
Game Center accesses the same social-gaming network as on iOS, allowing users to track scores on a leaderboard, compare their in-game achievements, invite friends to play a game, and start a multiplayer game through automatic matching. Game Center functionality is provided in three parts:
The Game Center app, in which users sign in to their account, discover new games and new friends, add friends to their gaming network, and browse leaderboards and achievements.
The Game Kit framework, which contains the APIs developers use to support live multiplayer or turn-based games and adopt other Game Center features, such as in-game voice chat and leaderboard access.
The online Game Center service supported by Apple, which performs player authentication, provides leaderboard and achievement information, and handles invitations and automatching for multiplayer games. You interact with the Game Center service only indirectly, using the Game Kit APIs.
Note: To support Game Center in a game developed for OS X, you must sign the app with a provisioning profile that enables Game Center. To learn more about provisioning profiles, see Provisioning Your System.
In your game, use the Game Kit APIs to post scores and achievements to the Game Center service and to display leaderboards in your user interface. You can also use Game Kit APIs to help users find others to play with in a multiplayer game.
To learn more about adding Game Center support to your app, see Game Center Programming Guide.
Sharing
The sharing service provides a consistent user experience for sharing content among many types of services. For example, a user might want to share a photo by posting it in a Twitter message, attaching it to an email, or sending it to another Mac user via AirDrop.
Use the AppKit NSSharingService
class to get information about available services and share items with them directly. As a result, you can display a custom UI to present the services. You can also use the NSSharingServicePicker
class to display a list of sharing services (including custom services that you define) from which the user can choose. When a service is performed, the system-provided sharing window is displayed, where the user can comment or add recipients.
Resume
Resume is a systemwide enhancement of the user experience that supports app persistence. A user can log out or shut down the operating system, and on next login or startup, OS X automatically relaunches the apps that were last running and restores the windows that were last opened. If your app provides the necessary support, reopened windows have the same size and location as before; in addition, window contents are scrolled to the previous position and selections are restored.
To support app persistence, you must also implement automatic and sudden app termination, user interface preservation, and Auto Save. See, Automatic and Sudden Termination of Apps, User Interface Preservation, and Documents Are Automatically Saved in the Mac App Programming Guide.
Full-Screen Mode
When an app enters full-screen mode it opens its frontmost app or document window in a separate space. Enabling full-screen mode adds an Enter Full Screen menu item to the View menu or, if there is no View menu, to the Window menu. When a user chooses this menu item, the frontmost app or document window fills the entire screen.
The AppKit framework provides support for customizing the appearance and behavior of full-screen windows. For example, you can set a window-style mask and can implement custom animations when an app enters and exits full-screen mode.
You enable and manage full-screen support through methods of the NSApplication
and NSWindow
classes and the NSWindowDelegate Protocol
protocol. To find out more about this feature, read Implementing the Full-Screen Experience in Mac App Programming Guide.
Cocoa Auto Layout
Cocoa Auto Layout is a rule-based system designed to implement the layout guidelines described in OS X Human Interface Guidelines. It expresses a larger class of relationships and is more intuitive to use than springs and struts.
Using Auto Layout brings you a number of benefits:
Localization through swapping of strings alone, instead of also revamping layouts
Mirroring of UI elements for right-to-left languages such as Hebrew and Arabic
Better layering of responsibility between objects in the view and controller layers
A view object usually knows best about its standard size and its positioning within its superview and relative to its sibling views. A controller can override these values if something nonstandard is required.
The entities you use to define a layout are Objective-C objects called constraints. You define constraints by combining attributes—such as leading, trailing, left, right, top, bottom, width, and height—that encapsulate the relationships between UI elements. (Leading and trailing are similar to left and right, but they are more expressive because they automatically mirror the constraint in a right-to-left environment.) In addition, you can assign priority levels to constraints, to identify the constraints that are most important to satisfy.
You can use Interface Builder to add and edit constraints for your interface. When you need more control, you can work with constraints programatically.
For more information on Auto Layout, see Auto Layout Guide.
Popovers
A popover is a view that displays additional content related to existing content onscreen. AppKit provides the NSPopover
class to support popovers. AppKit automatically positions a popover relative to the view containing the existing content—known as the positioning view—and it moves the popover when the popover’s positioning view moves.
You configure the appearance and behavior of a popover, including which user interactions cause the popover to close. And by implementing the appropriate delegate method, you can configure a popover to detach itself and become a separate window when a user drags it.
For more information, see NSPopover Class Reference and NSPopoverDelegate Protocol Reference. For guidelines on using popovers, see Popovers in OS X Human Interface Guidelines.
Software Configuration
OS X programs commonly use property list files (also known as plist files) to store configuration data. A property list is a text or binary file used to manage a dictionary of key-value pairs. Apps use a special type of property list file, called an information property list (Info.plist
) file, to communicate key attributes of the app—such as the app’s name, unique identification string, and version information—to the system. Apps also use property list files to store user preferences or other custom configuration data.
The advantage of property list files is that they are easy to edit and modify from outside the runtime environment of your app. Xcode includes a built-in property list editor for editing your app’s Info.plist
file. To learn more about information property list files and the keys you put in them, see Runtime Configuration Guidelines and Information Property List Key Reference. To learn how to edit a property list file in Xcode, see Edit Keys and Values.
Inside your app, you can read and write property list files programmatically using facilities found in both Core Foundation and Cocoa. For more information on creating and using property lists programmatically, see Property List Programming Guide or Property List Programming Topics for Core Foundation.
Accessibility
Accessibility is the successful access to information and information technologies by the millions of people who have some type of disability or special need. OS X provides many built-in features and assistive technologies that help users with special needs benefit from the Mac. OS X also provides software developers with the functions they need to create apps that are accessible to all users.
Apps that use Cocoa interfaces receive significant support for accessibility automatically. For example, apps get the following support for free:
Zoom features let users increase the size of onscreen elements.
Sticky keys let users press keys sequentially instead of simultaneously for keyboard shortcuts.
Mouse keys let users control the mouse with the numeric keypad.
Full keyboard access mode lets users complete any action using the keyboard instead of the mouse.
Speech recognition lets users speak commands rather than type them.
Text-to-speech reads text to users with visual disabilities.
VoiceOver provides spoken user interface features to assist visually impaired users.
Although Cocoa integrates accessibility support into its APIs, there might still be times when you need to provide more descriptive information about your windows and controls. The Accessibility section of the Xcode Identity inspector makes it easy to provide custom accessibility information about the UI elements in your app. Or you can use the appropriate accessibility interfaces to change the settings programmatically.
For more information about accessibility, see Accessibility Programming Guide for OS X.
AppleScript
OS X employs AppleScript as the primary language for making apps scriptable. With AppleScript, users can write scripts that link together the services of multiple scriptable apps.
When designing new apps, you should consider AppleScript support early in the process. The key to a good design that supports AppleScript is choosing an appropriate data model for your app. The design must not only serve the purposes of your app but also make it easy for AppleScript implementers to manipulate your content. After you settle on a data model, you can implement the Apple event code needed to support scripting.
To learn how to support AppleScript in your programs, see Applescript Overview.
Spotlight
Spotlight provides advanced search capabilities for apps. The Spotlight server gathers metadata from documents and other relevant user files and incorporates that metadata into a searchable index. The Finder uses this metadata to provide users with more relevant information about their files. For example, in addition to listing the name of a JPEG file, the Finder can also list its width and height in pixels.
App developers use Spotlight in two different ways. First, you can search for file attributes and content using the Spotlight search API. Second, if your app defines its own custom file formats, you should incorporate any appropriate metadata information in those formats and provide a Spotlight importer plug-in to return that metadata to Spotlight.
Note: You should not use Spotlight for indexing and searching the general content of a file. Spotlight is intended for searching only the metainformation associated with files. To search the actual contents of a file, use Search Kit. For more information on Search Kit, see Other Frameworks in the Core Services Layer.
For more information on using Spotlight in your apps, see Spotlight Overview.
Ink Services
Ink Services provides handwriting recognition for apps that support the Cocoa and WebKit text systems and any text system that supports input methods. The automatic support is for text and handwriting gestures (which are defined in the Ink panel). The Ink framework offers several features that you can incorporate into your apps, including the following:
Enabling or disabling handwriting recognition programmatically
Accessing Ink data directly
Supporting either deferred recognition or recognition on demand
Supporting the direct manipulation of text by means of gestures
The Ink Services feature is implemented by the Ink framework (Ink.framework
). The Ink framework is not intended solely for developers of end-user apps. Hardware developers can also use it to implement a handwriting recognition solution for a new input device. You might also use the Ink framework to implement your own correction model to provide users with a list of alternate interpretations for handwriting data.
The Ink framework is a subframework of Carbon.framework
; you should link to it directly with the umbrella framework, not with Ink.framework
. For more information on using Ink Services in Cocoa apps, see Using Ink Services in Your Application.
Frameworks
The Cocoa (Application) layer includes the frameworks described in the following sections.
Cocoa Umbrella Framework
The Cocoa umbrella framework (Cocoa.framework
) imports the core Objective-C frameworks for app development: AppKit, Foundation, and Core Data.
AppKit (
AppKit.framework
). This is the only framework of the three that is actually in the Cocoa layer. See AppKit for a summary of AppKit features and classes.Foundation (
Foundation.framework
). The classes of the Foundation framework (which resides in the Core Services layer) implement data management, file access, process notification, network communication, and other low-level features. AppKit has a direct dependency on Foundation because many of its methods and functions either take instances of Foundation classes as parameters, or return the instances as values.To find out more about Foundation, see Foundation and Core Foundation.
Core Data (
CoreData.framework
). The classes of the Core Data framework (which also resides in the Core Services layer) manage the data model of an app based on the Model-View-Controller design pattern. Although Core Data is optional for app development, it is recommended for apps that deal with large data sets.For more information about Core Data, see Core Data.
AppKit
AppKit is the key framework for Cocoa apps. The classes in the AppKit framework implement the user interface (UI) of an app, including windows, dialogs, controls, menus, and event handling. They also handle much of the behavior required of a well-behaved app, including menu management, window management, document management, Open and Save dialogs, and pasteboard (Clipboard) behavior.
In addition to having classes for windows, menus, event handling, and a wide variety of views and controls, AppKit has window- and data-controller classes and classes for fonts, colors, images, and graphics operations. A large subset of classes comprise the Cocoa text system, described in Text, Typography, and Fonts. Other AppKit classes support document management, printing, and services such as spellchecking, help, speech, and pasteboard and drag-and-drop operations.
Apps can participate in many of the features that make the user experience of OS X such an intuitive, productive, and rewarding experience. These features include the following:
Gestures. Users appreciate being able to use fluid, intuitive Multi-Touch gestures to interact with OS X. AppKit classes make it easy to adopt these gestures in your app and to provide a better zoom experience without redrawing your content. For example,
NSScrollView
includes built-in support for the smart zoom gesture (that is, a two-finger double-tap on a trackpad). When you provide the semantic layout of your content,NSScrollView
can intelligently magnify the content under the pointer. You can also use this class to respond to the lookup gesture (that is, a three-finger tap on a trackpad). To learn more about the gesture support thatNSScrollView
provides, see NSScrollView Class Reference.Spaces. Spaces lets the user organize windows into groups and switch back and forth between groups to avoid cluttering up the desktop. AppKit provides support for sharing windows across spaces through the use of collection behavior attributes on the window. For information about setting these attributes, see NSWindow Class Reference.
Fast User Switching. With this feature, multiple users can share access to a single computer without logging out. One user’s session can continue to run, while another user logs in and accesses the computer. To support fast user switching, be sure that your app avoids doing anything that might affect another version of the app running in a different session. To learn how to implement this behavior, see Multiple User Environment Programming Topics.
Xcode includes Interface Builder, a user interface editor that contains a library of AppKit objects, such as controls, views, and controller objects. With it, you can create most of your UI (including much of its behavior) graphically rather than programatically. With the addition of Cocoa bindings and Core Data, you can also implement most of the rest of your app graphically.
For an overview of the AppKit framework, see the introduction to the Application Kit Framework Reference. Mac App Programming Guide offers a practical discussion of how you use mostly AppKit classes to implement an app’s user interface, its documents, and its overall behavior.
Game Kit
The Game Kit framework (GameKit.framework
) provides APIs that allow your app to participate in Game Center. For example, you can use Game Kit classes to display leaderboards in your game and to give users the opportunity to share their in-game achievements and play multiplayer games.
To learn more about using Game Kit in your app, see Game Kit Framework Reference.
Preference Panes
The Preference Panes framework (PreferencePanes.framework
) lets you create plug-ins containing a user interface for setting app preferences. At runtime, the System Preferences app (or your app) can dynamically load the plug-in and present the settings UI to users. In System Preferences, each icon in the Show All view represents an individual preference pane plug-in. You typically implement preference pane plug-ins when your app lacks its own user interface or has a very limited UI but needs to be configurable. In these cases, you create both the plug-in and the app-specific code that reads and writes the preference settings.
For more information about creating preference-pane plug-ins, see Preference Pane Programming Guide.
Screen Saver
The Screen Saver framework (ScreenSaver.framework
) contains classes for creating dynamically loadable bundles that implement screen savers. Users can select your screen saver in the Desktop & Screen Saver pane of the System Preferences app. Screen Saver helps you implement the screen saver view and preview and manage screen saver preferences.
To learn more about creating screen savers, see Screen Saver Framework Reference. Also read the technical note Building Screen Savers for Snow Leopard for additional information.
Security Interface
The Security Interface framework (SecurityInterface.framework
) contains classes that provide UI elements for programs implementing security features such as authorization, access to digital certificates, and access to items in keychains. There are classes for creating custom views and standard security controls, for creating panels and sheets for presenting and editing certificates, for editing keychain settings, and for presenting and allowing selection of identities.
For more information about the Security Interface framework, see Security Interface Framework Reference.
Copyright © 2004, 2015 Apple Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2015-09-16
Home > Store
Register your product to gain access to bonus material or receive a coupon.
- By Aaron Hillegass
- Published May 5, 2008 by Addison-Wesley Professional.
Book
- Sorry, this book is no longer in print.
Description
- Copyright 2008
- Edition: 3rd
- Book
- ISBN-10: 0-321-50361-9
- ISBN-13: 978-0-321-50361-9
The best-selling introduction to Cocoa, once again updated to cover the latest Mac programming technologies, and still enthusiastically recommended by experienced Mac OS X developers.
“Aaron’s book is the gold standard for Mac OS X programming books—beautifully written, and thoughtfully sculpted. The best book on Leopard development.”
—Scott Stevenson, www.theocacao.com
“This is the first book I’d recommend for anyone wanting to learn Cocoa from scratch. Aaron’s one of the few (perhaps only) full-time professional Cocoa instructors, and his teaching experience shows in the book.”
—Tim Burks, software developer and creator of the Nu programming language, www.programming.nu
“If you’re a UNIX or Windows developer who picked up a Mac OS X machine recently in hopes of developing new apps or porting your apps to Mac users, this book should be strongly considered as one of your essential reference and training tomes.”
—Kevin H. Spencer, Apple Certified Technical Coordinator
If you’re developing applications for Mac OS X, Cocoa® Programming for Mac® OS X, Third Edition, is the book you’ve been waiting to get your hands on. If you’re new to the Mac environment, it’s probably the book you’ve been told to read first. Covering the bulk of what you need to know to develop full-featured applications for OS X, written in an engaging tutorial style, and thoroughly class-tested to assure clarity and accuracy, it is an invaluable resource for any Mac programmer.
Specifically, Aaron Hillegass introduces the three most commonly used Mac developer tools: Xcode, Interface Builder, and Instruments. He also covers the Objective-C language and the major design patterns of Cocoa. Aaron illustrates his explanations with exemplary code, written in the idioms of the Cocoa community, to show you how Mac programs should be written. After reading this book, you will know enough to understand and utilize Apple’s online documentation for your own unique needs. And you will know enough to write your own stylish code.
Updated for Mac OS X 10.4 and 10.5, this revised edition includes coverage of Xcode 3, Objective-C 2, Core Data, the garbage collector, and CoreAnimation.
Extras
Related Articles
Author's Site
Please visit the author's website at www.bignerdranch.com.
Sample Content
Online Sample Chapter
Sample Pages
Table of Contents
Preface xvii
Acknowledgments xix
Chapter 1: Cocoa: What Is It? 1
A Little History 1
Tools 3
Language 4
Objects, Classes, Methods, and Messages 4
Frameworks 6
How to Read This Book 6
Typographical Conventions 7
Common Mistakes 7
How to Learn 8
Chapter 2: Let’s Get Started 9
In Xcode 9
In Interface Builder 13
Back in Xcode 23
Documentation 29
What Have You Done? 30
Chapter 3: Objective-C 33
Creating and Using Instances 33
Using Existing Classes 35
Creating Your Own Classes 46
The Debugger 58
What Have You Done? 62
For the More Curious: How Does Messaging Work? 62
Challenge 64
Chapter 4: Memory Management 65
Turning the Garbage Collector On and Off 66
Living with the Garbage Collector 68
Living with Retain Counts 68
What Have You Done? 77
Chapter 5: Target/Action 79
Some Commonly Used Subclasses of NSControl 81
Start the SpeakLine Example 85
Lay Out the Nib File 86
Implementing the AppController Class 88
For the More Curious: Setting the Target Programmatically 90
Challenge 90
Debugging Hints 92
Chapter 6: Helper Objects 95
Delegates 96
The NSTableView and Its dataSource 99
Lay Out the User Interface 102
Make Connections 103
Edit AppController.m 105
For the More Curious: How Delegates Work 108
Challenge: Make a Delegate 109
Challenge: Make a Data Source 110
Chapter 7: Key-Value Coding; Key-Value Observing 111
Key-Value Coding 111
Bindings 113
Key-Value Observing 115
Making Keys Observable 116
Properties and Their Attributes 118
For the More Curious: Key Paths 120
For the More Curious: Key-Value Observing 121
Chapter 8: NSArrayController 123
Starting the RaiseMan Application 124
Key-Value Coding and nil 132
Add Sorting 133
For the More Curious: Sorting without NSArrayController 134
Challenge 1 135
Challenge 2 135
Chapter 9: NSUndoManager 139
NSInvocation 139
How the NSUndoManager Works 140
Adding Undo to RaiseMan 142
Key-Value Observing 145
Undo for Edits 146
Begin Editing on Insert 149
For the More Curious: Windows and the Undo Manager 151
Chapter 10: Archiving 153
NSCoder and NSCoding 154
The Document Architecture 157
Saving and NSKeyedArchiver 161
Loading and NSKeyedUnarchiver 162
Setting the Extension and Icon for the File Type 163
For the More Curious: Preventing Infinite Loops 166
For the More Curious: Creating a Protocol 167
For the More Curious: Document-Based Applications without Undo 167
Universal Type Identifiers 168
Chapter 11: Basic Core Data 171
NSManagedObjectModel 171
Interface 173
How Core Data Works 180
Chapter 12: Nib Files and NSWindowController 183
NSPanel 183
Adding a Panel to the Application 184
For the More Curious: NSBundle 194
Challenge 195
Chapter 13: User Defaults 197
NSDictionary and NSMutableDictionary 198
NSUserDefaults 200
Setting the Identifier for the Application 202
Creating Keys for the Names of the Defaults 202
Registering Defaults 203
Letting the User Edit the Defaults 203
Using the Defaults 205
For the More Curious: NSUserDefaultsController 207
For the More Curious: Reading and Writing Defaults from the Command Line 207
Challenge 208
Chapter 14: Using Notifications 209
What Notifications Are 209
What Notifications Are Not 210
NSNotification and NSNotificationCenter 210
Posting a Notification 212
Registering as an Observer 213
Handling the Notification When It Arrives 214
The userInfo Dictionary 214
For the More Curious: Delegates and Notifications 215
Challenge 216
Chapter 15: Using Alert Panels 217
Make the User Confirm the Deletion 218
Challenge 221
Chapter 16: Localization 223
Localizing a Nib File 224
String Tables 226
For the More Curious: ibtool 230
For the More Curious: Explicit Ordering of Tokens in Format Strings 231
Chapter 17: Custom Views 233
The View Hierarchy 233
Getting a View to Draw Itself 235
Drawing with NSBezierPath 240
NSScrollView 242
Creating Views Programmatically 245
For the More Curious: Cells 245
For the More Curious: isFlipped 247
Challenge 248
Chapter 18: Images and Mouse Events 249
NSResponder 249
NSEvent 249
Getting Mouse Events 251
Using NSOpenPanel 251
Composite an Image onto Your View 256
The View’s Coordinate System 258
Autoscrolling 261
For the More Curious: NSImage 261
Challenge 262
Chapter 19: Keyboard Events 263
NSResponder 265
NSEvent 265
Create a New Project with a Custom View 266
For the More Curious: Rollovers 274
The Fuzzy Blue Box 275
Chapter 20: Drawing Text with Attributes 277
NSFont 277
NSAttributedString 278
Drawing Strings and Attributed Strings 280
Making Letters Appear 281
Getting Your View to Generate PDF Data 283
For the More Curious: NSFontManager 286
Challenge 1 286
Challenge 2 286
Chapter 21: Pasteboards and Nil-Targeted Actions 287
NSPasteboard 288
Add Cut, Copy, and Paste to BigLetterView 289
Nil-Targeted Actions 290
For the More Curious: Which Object Sends the Action Message? 293
For the More Curious: Lazy Copying 293
Challenge 1 294
Challenge 2 294
Chapter 22: Categories 295
Add a Method to NSString 295
For the More Curious: Declaring Private Methods 297
For the More Curious: Declaring Informal Protocols 297
Chapter 23: Drag-and-Drop 299
Make BigLetterView a Drag Source 300
Make BigLetterView a Drag Destination 303
For the More Curious: Operation Mask 307
Chapter 24: NSTimer 309
Lay Out the Interface 311
Make Connections 312
Adding Code to AppController 314
For the More Curious: NSRunLoop 316
Challenge 316
Chapter 25: Sheets 317
Adding a Sheet 318
For the More Curious: contextInfo 324
For the More Curious: Modal Windows 325
Chapter 26: Creating NSFormatters 327
A Basic Formatter 328
The delegate of the NSControl 334
Checking Partial Strings 335
Formatters That Return Attributed Strings 337
Chapter 27: Printing 339
Dealing with Pagination 339
Mac Cocoa
For the More Curious: Am I Drawing to the Screen? 344
Challenge 344
Chapter 28: Web Service 345
AmaZone 346
Lay Out the Interface 347
Write Code 349
Challenge: Add a WebView 353
Chapter 29: View Swapping 355
Design 356
Resizing the Window 362
Chapter 30: Core Data Relationships 365
Edit the Model 365
Create Custom NSManagedObject Classes 366
Lay Out the Interface 369
Events and nextResponder 372
Chapter 31: Garbage Collection 375
Non-object Data Types 376
Polynomials Example 377
Instruments 383
For the More Curious: Weak References 385
Challenge: Do Bad Things 385
Cocoa Mac App Tutorial Windows 10
Chapter 32: Core Animation 387
Creating CALayer 388
Using CALayer and CAAnimation 390
Chapter 33: A Simple Cocoa/OpenGL Application 397
Using NSOpenGLView 397
Writing the Application 398
Chapter 34: NSTask 405
Multithreading versus Multiprocessing 405
ZIPspector 406
Asynchronous Reads 410
iPing 411
Challenge: .tar and .tgz files 415
Chapter 35: The End 417
Challenge 418
Index 419
Cocoa Mac Os
More Information
Other Things You Might Like
- eBook (Watermarked) $28.79
- Book $35.99
Cocoa Mac App Tutorial Android Studio
- Book $39.99