144

GitHub - manateelazycat/emacs-application-framework: Emacs application framework

 5 years ago
source link: https://github.com/manateelazycat/emacs-application-framework
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

README.md

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 python-pymediainfo
  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, Ctrl + LeftButton open link in new tab
  • 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

Report bug

If you found eaf message "eaf exited abnormally with ...", it mean something wrong in python.

Please switch buffer eaf and paste content of eaf to me.

Thanks!

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.add_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, import plugins buffer module and change new_buffer function to launch plugin buffer
from app.foo.buffer import FooBuffer

...

    @dbus.service.method(EAF_DBUS_NAME, in_signature="ss", out_signature="s")
    def new_buffer(self, buffer_id, url):
        ...

        if url.endswith(".foo"):
	    self.create_buffer(buffer_id, FooBuffer(buffer_id, url, emacs_width, emacs_height))

...
  1. Try new plugin:
  • Call command eaf-stop-process to kill old python process first.
  • Then call command `eaf-open' to test new plugin

Todo list

  • Browser: add cookie support
  • Browser: support pop window, such as emacs-china.org
  • Browser: add progressbar
  • ImageViewer: add zoom support
  • VideoPlayer: use ffmpeg implement QGraphicsItem

Contact me

lazycat dot manatee at gmail dot com

Any suggestions and patches are welcome, happy hacking!


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK