allegro5

The official Allegro 5 git repository. Pull requests welcome!

Github星跟蹤圖

Welcome to Allegro!

Allegro is a cross-platform library mainly aimed at video game and
multimedia programming. It handles common, low-level tasks such as
creating windows, accepting user input, loading data, drawing images,
playing sounds, etc. and generally abstracting away the underlying
platform. However, Allegro is not a game engine: you are free to design
and structure your program as you like.

Allegro 5 has the following additional features:

  • Supported on Windows, Linux, Mac OSX, iPhone and Android
  • User-friendly, intuitive C API usable from C++ and many other languages
  • Hardware accelerated bitmap and graphical primitive drawing support (via OpenGL or Direct3D)
  • Audio recording support
  • Font loading and drawing
  • Video playback
  • Abstractions over shaders and low-level polygon drawing
  • And more!

This readme contains general information which applies to all platforms
that Allegro builds on.

README_cmake.txt discusses some build options for cmake.

README_msvc.txt discusses compilation on Windows with Microsoft Visual C/C++.

README_make.txt discusses compilation with GNU make. This applies to Unix-like
operating systems such as Linux, MacOS X and MinGW on Windows.

README_macosx.txt has a few additional notes for MacOS X.

README_iphone.txt discusses iPhone operating systems.

Requirements

We assume you have C and C++ compilers installed and functioning.
We support gcc, clang and MSVC.

Allegro also requires CMake 2.8.5 or later to build.
You may download it from http://www.cmake.org/

Library dependencies

Allegro is divided into a core library and a number of addon libraries.
The core library depends on certain libraries to function. If you don't have
those, nothing will work. These are required for the core library:

  • DirectX SDK (Windows only)

    You can get this for MSVC from the Microsoft web site (large download).

    Alternatively, smaller downloads for MSVC and MinGW are available
    here: http://liballeg.org/download.html#miscellaneous-files. Some
    MinGW distributions come with sufficient DirectX SDK to support
    compiling Allegro.

  • X11 development libraries (Linux/Unix only)
    The libraries will be part of your Linux distribution, but you may have to
    install them explicitly.

  • OpenGL development libraries (optional only on Windows)

The addons, too, may require additional libraries. Since the addons are
strictly optional, they are not required to build Allegro, but a lot of
functionality may be disabled if they are not present.

Windows users may find some precompiled binaries for the additional libraries
from http://gnuwin32.sourceforge.net/. You need to get the bin and lib
packages. The bin packages contain DLLs, and the lib packages contain the
headers and import libraries.

Mac users may find some dependencies in Homebrew, Fink or MacPorts.
http://brew.sh/, http://www.finkproject.org/ and
http://www.macports.org/

Linux users likely have all the dependencies already, except PhysicsFS
and DUMB. If your distribution uses separate development packages, they
will need to be installed. The packages are probably named *-dev or *-devel.

These are the dependencies required for the addons:

On Windows it may be a pain to place all these libraries such that they can be
found. Please see the README_cmake.txt section on the "deps subdirectory"
when the time comes.

API documentation

To build the documentation you will need Pandoc.
Pandoc's home page is http://johnmacfarlane.net/pandoc/

Installing Pandoc from source can be challenging, but you can build Allegro
without building the documentation.

Online documentation is available on the Allegro web site:
http://docs.liballeg.org/

Building with CMake

Building with CMake is a two step process. During the configuration step,
cmake will detect your compiler setup and find the libraries which are
installed on your system. At the same time, you may select options to
customise your build. If you are unsure of what you are doing, leave all the
options at the defaults.

Once the configuration step is successful, you will invoke another tool to
build Allegro. The tool depends on your compiler, but is usually either
make, or your IDE.

To avoid problems, unpack Allegro into a directory without spaces or other
"weird" characters in the path
. This is a known problem.

Now read README_msvc.txt, README_make.txt or README_macosx.txt.

主要指標

概覽
名稱與所有者liballeg/allegro5
主編程語言C
編程語言CMake (語言數: 10)
平台
許可證Other
所有者活动
創建於2010-10-19 11:53:14
推送於2025-10-20 00:03:14
最后一次提交2025-10-19 17:03:04
發布數181
最新版本名稱5.2.10.1 (發布於 2024-12-28 19:53:25)
第一版名稱start (發布於 2000-05-14 20:17:25)
用户参与
星數2k
關注者數87
派生數310
提交數12.1k
已啟用問題?
問題數1016
打開的問題數351
拉請求數459
打開的拉請求數18
關閉的拉請求數137
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?