You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

3.0 KiB

What is Emacs Application Framework?

Emacs Application Framework is a development framework that developers can develop any PyQt program and integrate into Emacs.

This framework mainly implements three functions:

  1. Integrate PyQt program window into Emacs Frame using Xlib Reparent technology
  2. Listening to EAF buffer's keyboard event flow and controlling the keyboard input of PyQt program via DBus IPC
  3. Created a window compositer to make the PyQt program window adapt Emacs's Window/Buffer design

Using this framework, you can use PyQt develop powerful graphics programs to extend Emacs

Some screenshots

Browser

img

Image Viewer

img

Video Player

img

Installation

  1. Install PyQt5 and Python-Xlib (below commands use for archlinux)
sudo pacman -S python-xlib python-pyqt5
  1. Clone this repository and add below code in your ~/.emacs
(require 'eaf)

Usage

M-x eaf-open

Such as,

  • type www.google.com to open browser
  • type /path/image.jpg to open image viewer, and press key j or k to select other image in same directory
  • type /path/video.ogg to open video player, video player only support ogg file because it implement by HTML5 video tag

Join Us

Do you want to make Emacs a real operating system?

Do you want to live in emacs more comfortably?

Want to create unparalleled plugins to extend emacs?

Join us!

How to develop new plugins?

  1. Create new python plugin file:
mkdir -p emacs-application-framework/app/foo/buffer.py
  1. Fill python file with below template:
from PyQt5.QtGui import QColor
from PyQt5.QtWidgets import QLabel
from buffer import Buffer

class FooBuffer(Buffer):
    def __init__(self, buffer_id, url, width, height):
        Buffer.__init__(self, buffer_id, url, width, height, QColor(255, 255, 255, 255))
        
        self.buffer_widget = QLabel("foo")
        self.buffer_widget.resize(self.width, self.height)
        
    def resize_buffer(self, width, height):
        self.width = width
        self.height = height
        self.buffer_widget.resize(self.width, self.height)
        
  1. Open emacs-application-framework/core/eaf.py

3.1 Add import code to import plugin buffer:

from app.foo.buffer import FooBuffer

3.2 Research function new_buffer, you can launch new plugin when user input some file, like below:

...

if url.endswith(".foo"):
    self.buffer_dict[buffer_id] = FooBuffer(buffer_id, url, emacs_width, emacs_height)

...
  1. Try new plugins:

4.1 You need call command eaf-stop-process to kill old python process first. 4.2 Then call command `eaf-open' to test.

Todo list

  • Browser: click to open link in new tab
  • Browser: update title after load finish
  • Browser: add progressbar
  • Browser: add cookie support
  • ImageViewer: add zoom support
  • VideoPlayer: use mpv or vlc instead html5 video tag

Contact me

lazycat dot manatee at gmail dot com

Any suggestions and patches are welcome, happy hacking!