Graphical Environment

This article is only applicable only to Termux installations running on Android 7.0 or higher.

Termux provides support for programs that use X Window System. However, there no hardware acceleration for rendering and user will have to install a third party application to view graphical output.

To use X11-enabled programs, please, make sure that at least one of the following programs is installed:


 * VNC Viewer - the best choice for interacting with graphical environment. Requires a running VNC server.


 * XServer XSDL - this one may be unstable but it provides a standalone Xorg server so you don't have to setup VNC.

Enabling the X11 Repository
X11 packages are available in a separate APT repository. You can enable it by running the following command:

pkg install x11-repo

It will automatically add appropriate sources.list file and PGP key.

To disable this repository, you need to uninstall package.

Server
If you decided to use VNC for graphical output, follow these instructions for properly setting up VNC server.

1. Install package `tigervnc`:

pkg install tigervnc

2. After installation, execute this:

vncserver -localhost

At first time, you will be prompted for setting up passwords:

You will require a password to access your desktops.

Password: Verify: Would you like to enter a view-only password (y/n)? n

Note that passwords are not visible when you are typing them and maximal password length is 8 characters.

3. If everything is okay, you will see this message:

New 'localhost:1 ' desktop is localhost:1

Creating default startup script /data/data/com.termux/files/home/.vnc/xstartup Creating default config /data/data/com.termux/files/home/.vnc/config Starting applications specified in /data/data/com.termux/files/home/.vnc/xstartup Log file is /data/data/com.termux/files/home/.vnc/localhost:1.log

It means that X (vnc) server is available on display 'localhost:1'.

4. Finally, to make programs do graphical output to the display 'localhost:1', set environment variable like shown here (yes, without specifying 'localhost'):

export DISPLAY=":1"

You may even put this variable to your bashrc or profile so you don't have to always set it manually unless display address will be changed.

Client
Here will be assumed that you use this Android VNC client: VNC Viewer (developed by RealVNC Limited).

1. Determine port number on which VNC server listens. It can be calculated like this:. So for display 'localhost:1' the port will be 5901.

2. Now open the VNC Viewer application and create a new connection with the following information (assuming that VNC port is 5901):

Address: 127.0.0.1:5901

Name: Termux

3. Now launch it. You will be prompted for password that you entered on first launch of 'vncserver'. Depending on packages you installed, you may see either entirely black screen or terminal prompt (only if 'aterm' is installed).

Setting up Xserver XSDL
Xserver XSDL setup is nearly same as for VNC. The only differences are that you don't have to configure authentication and variable "DISPLAY" should be set like

export DISPLAY=localhost:0

Note that you don't need to set variable "PULSE_SERVER" like application suggests because Termux has own implementation.

Fluxbox


Simplest way to get a working graphical environment is to install Fluxbox:

pkg install fluxbox

It can be started automatically on VNC server startup. To do this, edit file  as shown here:

Openbox


Openbox requires a more complicated configuration than Fluxbox. Firstly you need to install some packages:

pkg install openbox pypanel xorg-xsetroot

Put the following lines to your :

Don't put anything else to file  but only lines shown above since Openbox has own autostart script. It is located at  (or alternatively at  ). Edit this file like here: