#webview #applications #electron #window #integration #web-apps #html

webview_app

Simple integration of a web view in an application window for windows and linux similar to Electron

41 releases

new 1.0.0-beta.38 Nov 6, 2024
1.0.0-beta.7 Sep 28, 2024
0.5.1 Jul 24, 2021

#131 in GUI

Download history 34/week @ 2024-07-25 5/week @ 2024-08-01 670/week @ 2024-09-26 281/week @ 2024-10-03 1058/week @ 2024-10-10 1446/week @ 2024-10-17 540/week @ 2024-10-24 278/week @ 2024-10-31

3,469 downloads per month

MIT license

76KB
1.5K SLoC

webview-app

A Rust Web View Application for Windows and Linux similar to Electron. It offers the possibility to make web requests from the web site to the rust app and to send events from rust to the web site. The web site can be hosted as integrated resource, of course alternatively via HTTP(s):// or file://.

Sample webview_app: Sample WebView app

webview_app >= version 1.0.0 is completely redesigned and it doesn't include a warp server anymore.

Features

webview_app includes following features:

  • Functional approach with a builder pattern
  • (almost) the same setup for Windows and Linux version
  • Uses WebView2 on Windows and WebKitGtk-6.0 on Linux
  • Can serve the web site via resources (single file approach)
  • Optional save and restore of window bounds
  • Has an integrated event sink mechanismen, so you can retrieve javascript events from the Rust app
  • Offers the possibility to serve requests from javascript to Rust
  • You can expand the Gtk4 Window (on Linux) with a custom header bar
  • You can alternatively disable the Windows titlebar and borders, and you can build a title bar in HTML with standard Windows logic for closing, maximizing, restoring resizing, snap to dock, ...

Functional approach with webview builder:

fn on_activate(app: &Application)->WebView {
    let webview = WebView::builder(app)
        .title("Website form custom resources 🦞")
        .save_bounds()
        .devtools(true)
        .webroot(include_dir!("webroots/custom_resources"))
        .query_string("?param1=123&param2=456")
        .default_contextmenu_disabled()
        .build();

     webview
}

fn main() {
    Application::new("de.uriegel.hello")
    .on_activate(on_activate)
    .run();
}

Sample of a Windows App with custom titlebar: custom titlebar

Prerequisites on Linux (Fedora)

  • sudo dnf install gtk4-devel
  • sudo dnf install webkitgtk6.0-devel
  • sudo dnf install libadwaita-devel

Prerequisites on Linux (Ubuntu)

  • sudo apt install libgtk-4-dev
  • sudo apt install libwebkitgtk-6.0-dev
  • sudo apt install libadwaita-1-dev

Run examples

cargo run --example hello

oder

cargo run --example hello --release

Icon in Windows

Use winres and build-script build.rs with res.set_icon(). This Icon will be the web view windows icon.

Dependencies

~0.7–49MB
~716K SLoC