mirror of https://github.com/buggins/dlangui.git
308 lines
16 KiB
HTML
308 lines
16 KiB
HTML
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
|
|
<html>
|
|
<head>
|
|
<meta charset='utf-8'>
|
|
<meta http-equiv="X-UA-Compatible" content="chrome=1">
|
|
<link href='https://fonts.googleapis.com/css?family=Chivo:900' rel='stylesheet' type='text/css'>
|
|
<link rel="stylesheet" type="text/css" href="stylesheets/stylesheet.css" media="screen" />
|
|
<link rel="stylesheet" type="text/css" href="stylesheets/pygment_trac.css" media="screen" />
|
|
<link rel="stylesheet" type="text/css" href="stylesheets/print.css" media="print" />
|
|
<!--[if lt IE 9]>
|
|
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
|
<![endif]-->
|
|
<title>DlangUI - cross platform GUI library for D programming language - index</title>
|
|
</head>
|
|
<body>
|
|
<div id="container">
|
|
<div class="inner">
|
|
<header>
|
|
<h1>DlangUI</h1>
|
|
<h2>Cross Platform GUI for D programming language</h2>
|
|
</header>
|
|
<section id="downloads" class="clearfix">
|
|
<a href="index.html" id="home" class="button"><span>Home</span></a>
|
|
<a href="ddox/index.html" id="home" class="button"><span>API Docs</span></a>
|
|
<a href="screenshots.html" id="home" class="button"><span>Screenshots</span></a>
|
|
<a href="https://github.com/buggins/dlangui/zipball/master" id="download-zip" class="button"><span>Download .zip</span></a>
|
|
<!--a href="https://github.com/buggins/dlangui/tarball/master" id="download-tar-gz" class="button"><span>Download .tar.gz</span></a-->
|
|
<a href="https://github.com/buggins/dlangui" id="view-on-github" class="button"><span>View on GitHub</span></a>
|
|
</section>
|
|
|
|
<hr>
|
|
<section id="main_content">
|
|
|
|
|
|
<h1>
|
|
<a name="dlang-ui" class="anchor" href="#dlang-ui"><span class="octicon octicon-link"></span></a>Dlang UI</h1>
|
|
|
|
<p>GUI for D programming language, written in D.</p>
|
|
|
|
<p><a href="https://gitter.im/buggins/dlangui?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge"><img src="https://camo.githubusercontent.com/da2edb525cde1455a622c58c0effc3a90b9a181c/68747470733a2f2f6261646765732e6769747465722e696d2f4a6f696e253230436861742e737667" alt="Gitter" data-canonical-src="https://badges.gitter.im/Join%20Chat.svg" style="max-width:100%;"></a> <a href="https://travis-ci.org/buggins/dlangui"><img src="https://camo.githubusercontent.com/0d872aabafbba7506cfc8b0032d3dee4cef3897d/68747470733a2f2f7472617669732d63692e6f72672f62756767696e732f646c616e6775692e7376673f6272616e63683d6d6173746572" alt="Build Status" data-canonical-src="https://travis-ci.org/buggins/dlangui.svg?branch=master" style="max-width:100%;"></a></p>
|
|
|
|
<ul>
|
|
<li>Crossplatform (Win32 and Linux are supported in current version); can use SDL2 as a backend.</li>
|
|
<li>Mostly inspired by Android UI API (layouts, styles, two phase layout, ...)</li>
|
|
<li>Supports highly customizable UI themes and styles</li>
|
|
<li>Supports internationalization</li>
|
|
<li>Hardware acceleration using OpenGL (when built with version USE_OPENGL)</li>
|
|
<li>Fallback to Win32 API / XCB when OpenGL is not available</li>
|
|
<li>Actually it's a port (with major refactoring) of GUI library for cross platform OpenGL based implementation of Cool Reader app project from C++.</li>
|
|
<li>Almost ready for 2D games development</li>
|
|
<li>Goal: provide set of widgets suitable for building of IDE.</li>
|
|
<li>Non thread safe</li>
|
|
</ul>
|
|
|
|
<h2><a name="widgets" class="anchor" href="#widgets"><span class="octicon octicon-link"></span></a>Widgets</h2>
|
|
|
|
<ul>
|
|
<li>Widget - base class for all widgets and widget containers, similar to Android's View</li>
|
|
</ul><p>Currently implemented widgets:</p>
|
|
|
|
<ul>
|
|
<li>TextWidget - simple static text (TODO: implement multiline formatting)</li>
|
|
<li>ImageWidget - static image</li>
|
|
<li>Button - simple button with text label</li>
|
|
<li>ImageButton - image only button</li>
|
|
<li>TextImageButton - button with icon and label</li>
|
|
<li>CheckBox - check button with label</li>
|
|
<li>RadioButton - radio button with label</li>
|
|
<li>EditLine - single line edit</li>
|
|
<li>EditBox - multiline editor</li>
|
|
<li>VSpacer - vertical spacer - just an empty widget with layoutHeight == FILL_PARENT, to fill vertical space in layouts</li>
|
|
<li>HSpacer - horizontal spacer - just an empty widget with layoutWidth == FILL_PARENT, to fill horizontal space in layouts</li>
|
|
<li>ScrollBar - scroll bar</li>
|
|
<li>TabControl - tabs widget, allows to select one of tabs</li>
|
|
<li>TabHost - container for pages controlled by TabControl</li>
|
|
<li>TabWidget - combination of TabControl and TabHost</li>
|
|
<li>GridWidgetBase - abstract Grid widget</li>
|
|
<li>StringGrid - grid view with strings content</li>
|
|
<li>TreeWidget - tree view</li>
|
|
<li>ComboBox - combo box with text items</li>
|
|
<li>ToolBar - tool bar with buttons</li>
|
|
<li>StatusLine - control to show misc application statuses</li>
|
|
<li>AppFrame - base class for easy implementation of apps with main menu, toolbars, status bar</li>
|
|
</ul>
|
|
|
|
<h2><a name="layouts" class="anchor" href="#layouts"><span class="octicon octicon-link"></span></a>Layouts</h2>
|
|
|
|
Similar to layouts in Android
|
|
|
|
<ul>
|
|
<li>LinearLayout - layout children horizontally or vertically depending on orientation</li>
|
|
<li>VerticalLayout - just a LinearLayout with vertical orientation</li>
|
|
<li>HorizontalLayout - just a LinearLayout with vertical orientation</li>
|
|
<li>FrameLayout - all children occupy the same place; usually onle one of them is visible</li>
|
|
<li>TableLayout - children are aligned into rows and columns of table</li>
|
|
</ul><h2>
|
|
<a name="list-views" class="anchor" href="#list-views"><span class="octicon octicon-link"></span></a>List Views</h2>
|
|
|
|
<p>Lists are implemented similar to Android UI API.</p>
|
|
|
|
<ul>
|
|
<li>ListWidget - layout dynamic items horizontally or vertically (one in row/column) with automatic scrollbar; can reuse widgets for similar items</li>
|
|
<li>ListAdapter - interface to provide data and widgets for ListWidget</li>
|
|
<li>WidgetListAdapter - simple implementation of ListAdapter interface - just a list of widgets (one per list item) to show</li>
|
|
</ul>
|
|
|
|
<h2>
|
|
<a name="resources" class="anchor" href="#resources"><span class="octicon octicon-link"></span></a>Resources</h2>
|
|
|
|
<p>Resources like fonts and images use reference counting. For proper resource freeing, always destroy widgets implicitly.</p>
|
|
|
|
<ul>
|
|
<li>FontManager: provides access to fonts</li>
|
|
<li>Images: .png or .jpg images; if filename ends with .9.png, it's autodetected as nine-patch image (see Android drawables description)</li>
|
|
<li>StateDrawables: .xml file can describe list of other drawables to choose based on widget's State (.xml files from android themes can be used directly)</li>
|
|
<li>imageCache allows to cache unpacked images</li>
|
|
<li>drawableCache provides access by resource id (string, usually filename w/o extension) to drawables located in specified list of resource directories.</li>
|
|
</ul><h2>
|
|
<a name="styles-and-themes" class="anchor" href="#styles-and-themes"><span class="octicon octicon-link"></span></a>Styles and Themes</h2>
|
|
|
|
<p>Styles and themes are a bit similar to ones in Android API.</p>
|
|
|
|
<ul>
|
|
<li>Theme is a container for styles. Can be load from XML theme resource file.</li>
|
|
<li>Styles are accessible in theme by string ID.</li>
|
|
<li>Styles can be nested to form hiararchy - when some attribute is missing in style, value from base style will be used.</li>
|
|
<li>State substyles are supported: allow to change widget appearance dynamically based on its state.</li>
|
|
<li>Widgets use style attributes directly from assigned style. When some attribute is being changed in widget, it creates its own copy of base style,
|
|
which allows to modify some of attributes, while getting base style attributes if they are not changed in widget. This trick can minimize memory usage for widget attributes when
|
|
standard values are used.</li>
|
|
</ul><h2>
|
|
<a name="win32-builds" class="anchor" href="#win32-builds"><span class="octicon octicon-link"></span></a>Win32 builds</h2>
|
|
|
|
<ul>
|
|
<li>Under windows, uses SDL2 or Win32 API as backend.</li>
|
|
<li>Optionally, may use OpenGL acceleration via DerelictGL3/WGL.</li>
|
|
<li>Uses Win32 API for font rendering.</li>
|
|
<li>Optinally can use FreeType for font rendering.</li>
|
|
</ul><p>Build and run using DUB:</p>
|
|
|
|
<pre class="d_code"> git clone https:<font color=green>//github.com/buggins/dlangui.git
|
|
</font> cd dlangui
|
|
dub run dlangui:example1
|
|
</pre>
|
|
|
|
<p>To develop using Visual-D, download sources for dlangui and dependencies into some directory:</p>
|
|
|
|
<pre class="d_code"> git clone https:<font color=green>//github.com/buggins/dlangui.git
|
|
</font> git clone https:<font color=green>//github.com/DerelictOrg/DerelictUtil.git
|
|
</font> git clone https:<font color=green>//github.com/DerelictOrg/DerelictGL3.git
|
|
</font> git clone https:<font color=green>//github.com/DerelictOrg/DerelictFT.git
|
|
</font> git clone https:<font color=green>//github.com/DerelictOrg/DerelictSDL2.git
|
|
</font> git clone https:<font color=green>//github.com/gecko0307/dlib.git
|
|
</font> git clone https:<font color=green>//github.com/Devisualization/image.git de_image
|
|
</font></pre>
|
|
|
|
<p>Then open .sln using Visual D.</p>
|
|
|
|
<h2>
|
|
<a name="linux-builds" class="anchor" href="#linux-builds"><span class="octicon octicon-link"></span></a>Linux builds</h2>
|
|
|
|
<ul>
|
|
<li>Uses SDL2 or XCB as a backend (SDL2 is recommended, since has better support now).</li>
|
|
<li>Uses shared memory images for faster drawing.</li>
|
|
<li>Uses FreeType for font rendering.</li>
|
|
<li>TODO: Use FontConfig to get font list.</li>
|
|
<li>OpenGL is now working under SDL2 only.</li>
|
|
<li>Entering of unicode characters is now working under SDL2 only.</li>
|
|
</ul><p>For linux build with SDL2 backend, following libraries are required:</p>
|
|
|
|
<pre class="d_code"> libsdl2
|
|
</pre>
|
|
|
|
<p>To build dlangui apps with XCB backend, development packages for following libraries required for XCB backend build:</p>
|
|
|
|
<pre class="d_code"> xcb, xcb-util, xcb-shm, xcb-image, xcb-keysyms, X11-xcb, X11
|
|
</pre>
|
|
|
|
<p>E.g. in Ubuntu, you can use following command to enable SDL2 backend builds:</p>
|
|
|
|
<pre class="d_code"> sudo apt-get install libsdl2-dev
|
|
</pre>
|
|
|
|
<p>or (for XCB backend)</p>
|
|
|
|
<pre class="d_code"> sudo apt-get install libxcb-image0-dev libxcb-shm0-dev libxcb-keysyms1-dev libfreeimage-dev
|
|
</pre>
|
|
|
|
|
|
<p>In runtime, .so for following libraries are being loaded (binary packages required):</p>
|
|
|
|
<pre class="d_code"> freetype, opengl, freeimage
|
|
</pre>
|
|
|
|
<p>Build and run on Linux using DUB:</p>
|
|
|
|
<pre class="d_code"> dub run dlangui:example1
|
|
</pre>
|
|
|
|
<p>Development using Mono-D: </p>
|
|
|
|
<ul>
|
|
<li>open solution dlangui/dlanguimonod.sln </li>
|
|
<li>build and run project example1</li>
|
|
</ul><p>You need fresh version of MonoDevelop to use Mono-D. It can be installed from PPA repository.</p>
|
|
|
|
<pre class="d_code"> sudo add-apt-repository ppa:ermshiperete/monodevelop
|
|
sudo apt-get update
|
|
sudo apt-get install monodevelop-current
|
|
</pre>
|
|
|
|
<h2>
|
|
<a name="other-platforms" class="anchor" href="#other-platforms"><span class="octicon octicon-link"></span></a>Other platforms</h2>
|
|
|
|
<ul>
|
|
<li>Other platforms support may be added easy</li>
|
|
</ul><h2>
|
|
<a name="third-party-components-used" class="anchor" href="#third-party-components-used"><span class="octicon octicon-link"></span></a>Third party components used</h2>
|
|
|
|
<ul>
|
|
<li>DerelictGL3 - for OpenGL support</li>
|
|
<li>DerelictFT + FreeType library support under linux and optionally under Windows.</li>
|
|
<li>DerelictFI + FreeImage library support for decoding of images</li>
|
|
<li>DerelictSDL2 + SDL2 for cross platform support</li>
|
|
<li>WindowsAPI bindings from <a href="http://www.dsource.org/projects/bindings/wiki/WindowsApi">http://www.dsource.org/projects/bindings/wiki/WindowsApi</a> (patched)</li>
|
|
<li>XCB and X11 bindings (patched) when SDL2 is not used; TODO: provide links</li>
|
|
</ul><h2>
|
|
<a name="hello-world" class="anchor" href="#hello-world"><span class="octicon octicon-link"></span></a>Hello World</h2>
|
|
|
|
Sample code:
|
|
|
|
<pre class="d_code"><font color=green>// main.d
|
|
</font><font color=blue>import</font> dlangui.all;
|
|
<font color=blue>mixin</font> DLANGUI_ENTRY_POINT;
|
|
|
|
<font color=green>/// entry point for dlangui based application
|
|
</font><font color=blue>extern</font> (C) <font color=blue>int</font> UIAppMain(string[] args) {
|
|
<font color=green>// resource directory search paths
|
|
</font> string[] resourceDirs = [
|
|
appendPath(exePath, <font color=red>"../res/"</font>), <font color=green>// for Visual D and DUB builds
|
|
</font> appendPath(exePath, <font color=red>"../../res/"</font>) <font color=green>// for Mono-D builds
|
|
</font> ];
|
|
|
|
<font color=green>// setup resource directories - will use only existing directories
|
|
</font> Platform.instance.resourceDirs = resourceDirs;
|
|
<font color=green>// select translation file - for english language
|
|
</font> Platform.instance.uiLanguage = <font color=red>"en"</font>;
|
|
<font color=green>// load theme from file "theme_default.xml"
|
|
</font> Platform.instance.uiTheme = <font color=red>"theme_default"</font>;
|
|
|
|
<font color=green>// create window
|
|
</font> Window window = Platform.instance.createWindow(<font color=red>"My Window"</font>, <font color=blue>null</font>);
|
|
<font color=green>// create some widget to show in window
|
|
</font> window.mainWidget = (<font color=blue>new</font> Button()).text(<font color=red>"Hello world"d</font>).textColor(0xFF0000); <font color=green>// red text
|
|
</font> <font color=green>// show window
|
|
</font> window.show();
|
|
<font color=green>// run message loop
|
|
</font> <font color=blue>return</font> Platform.instance.enterMessageLoop();
|
|
}
|
|
</pre>
|
|
|
|
Sample dub.json:
|
|
<pre class="d_code">{
|
|
<font color=red>"name"</font>: <font color=red>"myproject"</font>,
|
|
<font color=red>"description"</font>: <font color=red>"sample DLangUI project"</font>,
|
|
<font color=red>"homepage"</font>: <font color=red>"https://github.com/buggins/dlangui"</font>,
|
|
<font color=red>"license"</font>: <font color=red>"Boost"</font>,
|
|
<font color=red>"authors"</font>: [<font color=red>"Vadim Lopatin"</font>],
|
|
|
|
<font color=red>"targetName"</font>: <font color=red>"example"</font>,
|
|
<font color=red>"targetPath"</font>: <font color=red>"bin"</font>,
|
|
<font color=red>"targetType"</font>: <font color=red>"executable"</font>,
|
|
|
|
<font color=red>"sourcePaths"</font>: [<font color=red>"src"</font>],
|
|
|
|
<font color=red>"sourceFiles"</font>: [
|
|
<font color=red>"src/app.d"</font>
|
|
],
|
|
|
|
<font color=red>"copyFiles-windows"</font>: [
|
|
<font color=red>"lib/FreeImage.dll"</font>
|
|
],
|
|
|
|
<font color=red>"copyFiles"</font>: [
|
|
<font color=red>"res"</font>
|
|
],
|
|
|
|
<font color=red>"dependencies"</font>: {
|
|
<font color=red>"dlangui"</font>: <font color=red>"~master"</font>
|
|
}
|
|
}
|
|
</pre>
|
|
|
|
There is sample project which is using DLangUI.
|
|
|
|
<a href="https://github.com/buggins/dlangide">https://github.com/buggins/dlangide</a>
|
|
|
|
</section>
|
|
<footer>
|
|
Dlangui is maintained by <a href="https://github.com/buggins">buggins</a><br>
|
|
This page was generated by <a href="http://pages.github.com">GitHub Pages</a>. Tactile theme by <a href="https://twitter.com/jasonlong">Jason Long</a>.
|
|
</footer>
|
|
|
|
</div>
|
|
</div>
|
|
</body>
|
|
</html>
|