2D Art and Animation
We have encountered projects where 2D graphics accounted for 70% of the build size. Optimization started with replacing frame-by-frame with skeletal animation. But it's not just about converting sprites to Spine — you need to properly design the rig, atlas packing, and texture format. Our service is a full 2D cycle: from concept art and illustrations to final Spine animation optimized for mobile platforms.
A mobile game with 200 character animations takes up 800 MB just for textures. Google Play rejects the APK due to size. Meanwhile, half of the animations are variations of the same movement with minor differences. This is a classic problem for teams that chose frame-by-frame animation where skeletal animation provides a better result at a fraction of the size.
Our team creates 2D graphics and illustrations for games of any genre — from pixel art to realistic styles. We work with Unity, Unreal Engine, and Godot. Every animation is performance-checked: FPS budget, draw call count, texture size.
What's Included in the Service
- Concept art and illustrations — characters, environment, UI elements, promo
- Sprite animation — frame-by-frame in Aseprite with palette and frame optimization
- Skeletal animation — Spine (professional license), DragonBones for budget projects
- 2D effects — particle-based (Shuriken, VFX Graph) and shader-based (Shader Graph for URP/HDRP)
- Atlas optimization — TexturePacker, Unity Sprite Atlas, platform-specific compression (ASTC, ETC2, DXT)
How Skeletal Animation Reduces APK Size
Spine (Esoteric Software) is the de facto standard for skeletal animation in 2D games. Skeletal animation is a method where movement is defined by bones and vertex weights rather than entire frames. In Spine, a character animation with 15 animations takes about 2 MB, while frame-by-frame takes 10 MB (5 times more). Alternatives include DragonBones (free, fewer features) and the native 2D Animation package in Unity (convenient but weaker than Spine in tools).
The return on investment for a Spine Professional license is achieved when creating 15+ unique animations — each frame-by-frame would cost several times more in time and size. When scaled to a large number of animations, the savings on a single project can be substantial. Contact us — we will calculate the savings for your project.
When is Skeletal Animation More Effective than Frame-by-Frame?
| Criterion | Skeletal (Spine) | Frame-by-frame (Aseprite) |
|---|---|---|
| Data size | Small (bones + weights) | Large (frames as images) |
| Blending flexibility | High | None |
| Expressiveness | Depends on rigger | Full artistic freedom |
| Production time | Long rigging, fast iterations | Each animation from scratch |
| Suitable for | Characters, UI, creatures | Pixel art, unique style |
The rule that works in practice: if a character has more than 15 unique animations — Spine is more efficient in size and iteration time. If the project stylistically requires frame-by-frame (pixel art, rotoscoping, cartoon style with deliberate artifacts) — Aseprite.
Mesh Deformation in Spine is one of the key features. The character bends organically, clothes fold, cheeks puff up. Workflow:
- In Spine, create a mesh on the sprite (Tools > Mesh > Edit Mesh)
- Assign vertex weights to bones (Weights mode)
- Set the number of vertices based on the desired deformation detail — more vertices = smoother deformation, but higher computational cost
Path Constraints — a bone follows a curve. Used for tails, hair, tentacles, ropes — any elements that need to bend organically. IK Constraints in Spine work through a two- or three-bone chain. For limbs this is essential: the animator moves the IK target (hand position), and the shoulder-forearm-hand chain is set automatically. Without IK, animating limbs in FK takes twice as long.
Spine Integration in Unity
The official Spine-Unity runtime is paid (included in the Spine license) and actively supported. Components:
-
SkeletonAnimation— main component for animation -
SkeletonMecanim— integration with Unity Animator Controller (useful for reusing Mecanim logic) -
SkeletonGraphic— for Canvas/UI (rendered via CanvasRenderer, not MeshRenderer)
An important performance point: SkeletonAnimation creates a separate Mesh per instance. With 50+ characters on screen, this is at least 50 draw calls (without batching). Solution — SkeletonAnimation Batching via SubmeshSeparator + GPU instancing, or limiting the number of simultaneously visible Spine objects.
Spine Events — synchronization mechanism: an event in animation (footstep, attack_hit, spawn_particle) is dispatched to Unity code via AnimationState.Event. Correct architecture: Spine Event → UnityEvent → sound/particle/logic. Do not hardcode synchronization by time — animation can slow down via timeScale.
How to Reduce Draw Calls in 2D UI with Atlases?
Every individual sprite in Unity creates a separate draw call. 100 UI icons without an atlas = 100 draw calls just for UI. Sprite Atlas packs sprites into a single texture, allowing batching of draw calls for objects using the same atlas. Texture atlas is a technique used in 3D and 2D to reduce texture switching.
TexturePacker vs Unity Sprite Atlas
TexturePacker (CodeAndWeb) is an external tool, more flexible in packing settings. It supports many packing algorithms, transparent pixel trimming, edge extrusion to prevent bleeding, and export to platform-specific formats (PVRTC for iOS, ETC2 for Android). The license pays for itself on the first project with atlases.
Unity Sprite Atlas (built-in) is convenient for Addressables and dynamic loading. Two modes: Master Atlas (full control) and Variant Atlas (reduced version for low-end devices via Scale Factor).
Practical packing rules:
- Group by scene/screen: everything visible at once — in one atlas. Otherwise atlas doesn't help with batching
- Maximum atlas size: 2048x2048 for mobile, 4096x4096 for PC. Larger risks issues on old GPUs
- Trim transparent pixels: mandatory. A sprite with large transparent areas wastes space in the atlas
- Padding: 2-4 pixels between sprites prevents texture bleeding during mipmapping and UV filtering
Texture Compression Formats
| Platform | Recommended Format | Notes |
|---|---|---|
| Android | ETC2 (RGB) / ETC2 RGBA8 | Hardware acceleration on all modern Android |
| iOS | ASTC 4x4 / 6x6 | ASTC is universal: quality + size |
| PC/Console | DXT5 (BC3) | Or BC7 for high quality |
| WebGL | DXT5 + fallback | Check support via SystemInfo |
For atlases with many small sprites and sharp edges, ASTC 4x4 is preferable to ASTC 6x6 (fewer artifacts on fine details).
How Does 2D Asset Optimization Benefit in Practice?
Each of these points has been verified on dozens of projects: transparent pixel trimming in the atlas (saving up to 30% area), 2-4 pixel padding (eliminates bleeding), maximum atlas size 2048x2048 for mobile (stable on old GPUs), using ASTC 4x4 for iOS and ETC2 for Android, Mesh Deformation in Spine instead of extra bones for cheeks and clothing folds, grouping UI elements by screen into different atlases. Order 2D animation development with a performance guarantee — we will take into account all the nuances of your stack and platform.
What Pipeline for 2D Effects to Choose?
Particle System (Shuriken) — for most 2D effects, the built-in system is sufficient. For 2D it's important: Renderer Mode = Billboard or Horizontal Billboard, Simulation Space = World for effects that should not move with the character.
Visual Effect Graph (VFX Graph) in URP — GPU-based particles, suitable for complex effects with thousands of particles. For mobile — be cautious, requires Compute Shaders (not all devices support).
Shader Graph for 2D: dissolve effects, outline via SDF, distortion (water, heat shimmer), animated UV (lava, water). Sprite Lit Shader + custom nodes in Shader Graph — standard path for 2D in URP.
2D Animation Package (native Unity): PSDImporter for importing layers from Photoshop as separate sprites, Sprite Skin for skeletal animation inside Unity without Spine. Suitable for simple characters with a limited number of animations — if the team doesn't want to purchase a Spine license. These costs are recouped in one project if animations exceed 15.
We are ready to develop 2D graphics and animation for your game. Contact us to discuss details and get advice on asset optimization. Get an estimate of cost and timeline based on your brief — we will respond within one business day.





