Is there a way to have 2 icons when using elixir-desktop?

Background

I have a personal project that is an elixir desktop application for PC Windows. It works pretty well, but now I want to give it an icon.

This is usually done in the following module:

defmodule WebInterface.Application do
  # See https://hexdocs.pm/elixir/Application.html
  # for more information on OTP Applications
  @moduledoc false

  use Application

  alias Desktop
  alias Manager
  alias WebInterface.{Endpoint, Telemetry}
  alias WebInterface.Live.MenuBar

  @impl true
  def start(_type, _args) do
    children = [
      Telemetry,
      {Phoenix.PubSub, name: WebInterface.PubSub},
      Endpoint,
      Manager,
      {Desktop.Window,
       [
         app: :web_interface,
         id: WebInterface,
         title: "Market Manager",
         size: {900, 960},
         menubar: MenuBar,
         icon: "static/images/resized_logo_4.png", # THIS IS WHERE THE ICON IS SET
         url: &WebInterface.Endpoint.url/0
       ]}
    ]

    opts = [strategy: :one_for_one, name: WebInterface.Supervisor]
    Supervisor.start_link(children, opts)
  end

  @impl true
  def config_change(changed, _new, removed) do
    WebInterface.Endpoint.config_change(changed, removed)
    :ok
  end
end

Problem

The issue here is that I have to use the same image for both the Windows taskbar and the top icon of the app:

The issue here is that while the logo on the bottom Windows bar (marked yellow) is nice, the one in the top is distorted and pretty horrible.

The fix to this would be to have an icon for the bottom and one for the top.
However after checking the demo app I didn’t find a way of doing this.

Question

Is this possible to achieve? If so, how?

1 Like

There are two ways to do this:

  1. You call Desktop.Menu.set_icon after application startup to change the taskbar icon like the sample application does: desktop-example-app/menu.ex at 1661b9bf28c09bbbd2ce87ffe5e4dd1dd8e21ccf · elixir-desktop/desktop-example-app · GitHub

  2. You use the new :taskbar_icon option in v1.4.2 :

{Desktop.Window,
       [
         app: :web_interface,
         id: WebInterface,
         title: "Market Manager",
         size: {900, 960},
         menubar: MenuBar,
         icon: "static/images/resized_logo_4.png",
         taskbar_icon: "static/images/taskbar_logo.png",
         url: &WebInterface.Endpoint.url/0

Hope this helps!

4 Likes

Unfortunately for me, using:

{Desktop.Window,
       [
         app: :web_interface,
         id: WebInterface,
         title: "Market Manager",
         size: {900, 960},
         menubar: MenuBar,
         icon: "static/images/resized_logo_4.png",
         taskbar_icon: "static/images/resized_logo_5.png",
         url: &WebInterface.Endpoint.url/0

Still results in the icons being the same:

I believe to be using the latest version as well:

# Project deps
{:desktop, "~> 1.4"},

mix lock

"desktop": {:hex, :desktop, "1.4.2", "48cb5f02aa77522bd9996bfe02c4b23f8dc40d30076ada46b660f4a20bd7a3a1",

After asking in the wxWidgets forum about this same issue I got the following reply:

[…](MSW only) If the icon in the taskbar is from the active application window, I don’t think the two can be different (aside from using an overlay icon etc with wxTaskBarButton). […]

source: https://forums.wxwidgets.org/viewtopic.php?f=27&t=49813

I am lead to believe that perhaps this is not possible using desktop-elixir. Maybe I am incorrect, but I am not sure elixir-desktop uses or supports overlays with wxTaskBarButtons for this purpose.

1 Like

Ah yes, that was a misunderstanding I thought you’re talk about the little status icon in the corner :innocent:

The second one (the little corner icon) can be changed independently – but the larger one yes seems always to be the same as the main-window one. (I expect that to be a wxWidgets limitation though, not a system limit)

1 Like