starling

The "Cross-Platform Game Engine", a popular Stage3D framework

Github stars Tracking Chart

Simplified BSD License NPM Version Haxelib Version Build Status

Starling Framework

The Cross Platform Game Engine

The Starling Framework allows you to create hardware accelerated apps in ActionScript 3, Haxe, TypeScript or JavaScript. The main target is the creation of 2D games, but Starling may be used for any graphical application. Thanks to Adobe AIR, Starling-based applications can be deployed to mobile devices (iOS, Android), the desktop (Windows, OS X), and to the browser (via the Flash plugin).

You can also pair Starling with OpenFL to deploy native builds for iOS, Android, Windows, OS X, Linux or WebAssembly, as well as Flash/AIR or regular HTML5 releases without WebAssembly. HTML5 support is available in TypeScript, Haxe, ES5 JavaScript or ES6+ JavaScript.

While Starling mimics the classic display tree architecture of Adobe AIR/Flash, it provides much better performance than the Adobe version: all objects are rendered directly by the GPU (using the Stage3D API). When paired with OpenFL, Starling provides an alternative GPU renderer with helpful features. The complete architecture was designed for working well with the GPU; common game development tasks were built right into its core. Starling hides Stage3D internals from developers, but makes it easy to access them for those who need full performance and flexibility.

Starling aims to be as lightweight and easy to use as possible. As an open-source project, much care was taken to make the source code easy to read, understand and extend. With under 15k lines of code, experienced developers can easily grasp it in its entirety, or modify it to their needs.

Getting Started (NPM)

You can install the Yeoman generator to create an empty project:

npm install -g yo starling-framework-generator
mkdir StarlingProject
cd StarlingProject
yo starling-framework

You can also try the Starling demo:

git clone https://github.com/openfl/starling
cd starling/samples/demo_npm/typescript
npm install
npm start -s

There are ES5, ES6, Haxe and TypeScript versions of the demo available.

Getting Started (Haxelib)

You can easily install Starling using haxelib:

haxelib install starling

To add it to an OpenFL project, add this to your project file:

<haxelib name="starling" />

You can also create a new empty project like this:

openfl create starling:project StarlingProject

You can also try the Starling demo:

openfl create starling:demo
cd demo
openfl test flash

News and Updates

Main metrics

Overview
Name With Owneropenfl/starling
Primary LanguageHaxe
Program languageHaxe (Language Count: 5)
Platform
License:Other
所有者活动
Created At2014-09-04 14:30:47
Pushed At2025-04-23 16:44:08
Last Commit At2025-04-23 09:43:55
Release Count26
Last Release Name2.7.1 (Posted on 2025-03-28 15:25:19)
First Release Name1.8.0 (Posted on )
用户参与
Stargazers Count245
Watchers Count35
Fork Count68
Commits Count640
Has Issues Enabled
Issues Count123
Issue Open Count11
Pull Requests Count40
Pull Requests Open Count0
Pull Requests Close Count14
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private