UWP: 通過命令行啟動 UWP 應用

来源:https://www.cnblogs.com/wpinfo/archive/2018/01/26/uwp_commandline_launch.html
-Advertisement-
Play Games

最近在開發應用的過程中,我遇到瞭如標題所述的需求,其實主要是為了能夠快捷啟動應用,正像我們可以在“運行”對話框中可以輸入一些可執行程式的名稱後,就能夠直接啟動它;這樣做,可以增加 App 的易用性。在查了一些文檔後,得知在 Windows Build 16266 之後,就加入相關的 API,因此要實 ...


最近在開發應用的過程中,我遇到瞭如標題所述的需求,其實主要是為了能夠快捷啟動應用,正像我們可以在“運行”對話框中可以輸入一些可執行程式的名稱後,就能夠直接啟動它;這樣做,可以增加 App 的易用性。在查了一些文檔後,得知在 Windows Build 16266 之後,就加入相關的 API,因此要實現以及使用這一功能,Window 系統和 SDK 的版本都要大於 16266,Fall Creators Update (Build 16299) 則完全滿足這一條件。

實現

要使用命令行啟動 UWP 應用,其實非常簡單,只需要兩步:首先,在 Package.appxmanifest 中添加 appExecutionAlias 擴展;然後,在 App.OnActived 事件中做相應的處理。

1. 修改Package.appxmanifest

右擊項目中的 Package.appxmanifest 文件,在快捷菜單中選擇“打開方式“->”XML 文本編輯器“。打開後,對它的內容按以下修改:

<Package
  xmlns="http://schemas.microsoft.com/appx/manifest/foundation/windows10"
  xmlns:mp="http://schemas.microsoft.com/appx/2014/phone/manifest"
  xmlns:uap="http://schemas.microsoft.com/appx/manifest/uap/windows10"
  xmlns:uap5="http://schemas.microsoft.com/appx/manifest/uap/windows10/5"
  IgnorableNamespaces="uap mp uap5">
  ...
  <Applications>
    <Application
        ...
      <Extensions>        
          <uap5:Extension
            Category="windows.appExecutionAlias"
            Executable="TestCmdLineApp.exe"
            EntryPoint="TestCmdLineApp.App">
            <uap5:AppExecutionAlias>
              <uap5:ExecutionAlias Alias="App.exe" />
            </uap5:AppExecutionAlias>
          </uap5:Extension>        
      </Extensions>
    </Application>
  </Applications>
  ...
</Pakage>

其中加粗部分是我們需要補充的內容。可以看到,我們添加了一個名為 appExecutionAlias  的擴展 (Extension)。在 Extension 節點中包括了幾個屬性,它們的意義分別如下:

1) Category 屬性指明 Extension 的類別,對於我們當前的需求,它的值固定為 windows.appExecutionAlias,即為應用的運行提供別名;
2) Executable 屬性指明當前應用的 exe 名稱,也即:程式集名稱 + ".exe";
3) EntryPoint 屬性指明當前應用的入口點,也即 App 類的完整名稱(包含其所在的命名空間);
4) 在 AppExecutionAlias\ExecutionAlias  節點中的 Alias 屬性,就是我們為要為當前應用定義的命令行啟動名稱;這裡需要說明三點:

a) 它可以與前面 Executable 屬性值相同,也可以不同,比如更簡短一些,便於用戶記住與輸入;
b) 如果定義的別名,已經被當前機器上安裝的其它應用占用了,那麼它就不會生效,也即,誰先占用就對誰有效(當然,如果先前占用的應用被卸載了,那麼這個別名就可以被你的應用使用);
c) 可以添加多個 ExecutionAlias  節點,為應用指定多個別名。通過為應用提供更多的別名,可以解決別名被占用的問題(如果確實存在這個問題)。

2. 處理 OnActivated 事件

在 App.OnActived 事件中,我們對 IActivatedEventArgs 參數類型判斷,如果其 Kind 屬性為 CommandLineLaunch,則認為是命令行啟動,接下來所做的就像在 OnLaunched 事件中一樣,對 Frame 初始化並導航到應用的主頁,如下:

        protected override void OnActivated(IActivatedEventArgs args)
        {
            if (args.Kind == ActivationKind.CommandLineLaunch)
            {
                // ...
            }

            Frame rootFrame = Window.Current.Content as Frame;

            if (rootFrame == null)
            {
                rootFrame = new Frame();
                rootFrame.NavigationFailed += OnNavigationFailed;
                Window.Current.Content = rootFrame;
            }

            rootFrame.Navigate(typeof(MainPage));

            Window.Current.Activate();
            base.OnActivated(args);
        }

3. 參數處理

使用命令行啟動應用有一個很大的好處,用戶在啟動時可以攜帶參數,如: app.exe a, app.exe a b, app.exe /type:a 等,而應用則根據用戶提供的參數作相應的處理。要得到用戶傳遞的參數,只要將 IActivatedEventArgs 類型的參數轉換為  CommandLineActivatedEventArgs,通過它的  Operation.Arguments 屬性即可得到,剩下的就是對參數進行分析並根據參數進行相應的處理。除了參數,我們也能夠得到用戶是從哪個目錄啟動 App 的,這是通過 Operation.CurrentDirectoryPath 屬性得到的。完整代碼如下:

        protected async override void OnActivated(IActivatedEventArgs args)
        {
            string arugment = string.Empty;

            if (args.Kind == ActivationKind.CommandLineLaunch)
            {
                var cmdArgs = args as CommandLineActivatedEventArgs;
                StringBuilder sb = new StringBuilder();
                sb.AppendLine($"Argument: {cmdArgs.Operation.Arguments}");
                sb.AppendLine($"CurrentDirectoryPath: {cmdArgs.Operation.CurrentDirectoryPath}");
                await new MessageDialog(sb.ToString()).ShowAsync();
            }

            Frame rootFrame = Window.Current.Content as Frame;

            if (rootFrame == null)
            {
                rootFrame = new Frame();
                rootFrame.NavigationFailed += OnNavigationFailed;
                Window.Current.Content = rootFrame;
            }

            rootFrame.Navigate(typeof(MainPage), arugment);

            Window.Current.Activate();
            base.OnActivated(args);
        }

最後,要測試效果,需要部署(Deploy)應用。

部署完成後,在“運行”(Win + R)對話框中輸入上面定義的別名(和參數),即可。當然,在“命令提示符”視窗甚至在“資源管理器”視窗的地址欄中,你都可以輸入別名來啟動應用。

背後原理

為什麼在上述這些位置我們輸入別名後,就可以運行應用呢?為瞭解決這個問題,首先我們使用 where 命令得看看對應的命令究竟在哪裡。在“命令提示符”視窗中,輸入: where 別名,得到這樣的結果:

C:\Users\Admin>where app
C:\Users\Admin\AppData\Local\Microsoft\WindowsApps\App.exe

在“資源管理器”中打開對應的路徑,會看到在這個目錄下存放了當前機器中所有那些使用別名的應用,其實這裡的文件可以認為是一個快捷方式。

不僅如此,這個目錄也在 PATH 環境變數中(可在“命令提示符”中使用 path 命令查看或在“系統屬性”的“環境變數”對話框中查看),因此,我們才可以在任何位置都能啟動應用。

除此以外,作為用戶,我們還可以在桌面(或其它任何目錄)為應用創建快捷方式,右擊桌面->創建快捷方式,然後輸入別名 和參數(可選)。通過雙擊快捷方式圖標,也可以啟動應用。這一點類似於創建磁貼,不過,它要比磁貼更靈活。我們甚至還可以為不同的參數創建多個快捷方式,也可以為每個快捷方式指定不同的圖標。這樣,是不是感覺更像 Win32 應用了呢?

總結

本文主要提到瞭如何使用命令行來啟動 UWP 應用,為應用提供這一特性可以為其增加易用性以及靈活性。作為 App 的使用者,可以更便利、更靈活地打開、使用應用。這樣,使得 UWP 應用和 Win32 程式的行為更加一致。

參考資料:

Command-Line Activation of Universal Windows Apps


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最基本命令 查看埠號:netstar -aon 殺死進程:tskill PID PHP基礎 查看埠號:netstar -aon 殺死進程:tskill PID PHP基礎 PHP程式的數據採集(獲取數據) $_GET["要獲取的名稱"]; PHP數據的輸出 echo或print:輸出的是沒有經過 ...
  • 用Struts和Hibernate完成簡單的查詢資料庫,顯示類別信息的簡單案例 ...
  • C++的四種類型轉換:static_cast、dynamic_cast、const_cast、reinterpret_cast;typedef與類型別名,作用域和一些偶爾會看到的C風格工具。 ...
  • 前言 storm和kafka集群安裝是沒有必然聯繫的,我將這兩個寫在一起,是因為他們都是由zookeeper進行管理的,也都依賴於JDK的環境,為了不重覆再寫一遍配置,所以我將這兩個寫在一起。若只需一個,只需挑選自己選擇的閱讀即可。 這兩者的依賴如下: Storm集群 :JDK1.8 , Zooke ...
  • 印象中迴圈刪除list中的元素使用for迴圈的方式是有問題的,但是可以使用增強的for迴圈,然後今天在使用時發現報錯了,然後去科普了一下,再然後發現這是一個誤區。下麵就來講一講。。伸手黨可直接跳至文末。看總結。。 JAVA中迴圈遍歷list有三種方式for迴圈、增強for迴圈(也就是常說的forea ...
  • 我找到一些把字元串首字元大寫的方法。 <! more 假如需要把字元串 "red" 轉換為 "Red",把 "red house" 轉為 "Red house" 或者單詞的第一個大寫,下麵就是我從網上看到的技術。 這個方法就是拿到第一個字元,然後加上後面的字元,可以看到這個方法需要三個字元串在記憶體。 ...
  • 一、url地址傳參的第一種寫法 1.通過mvc中預設的url地址書寫格式:控制器/方法名/參數 2.實例:http://localhost:39270/RequestDemo/Index/88,預設參數名為id所以名稱為id。 如果使用其他名稱,後臺是無法讀取的會報錯 二、url地址傳參的第二種寫法 ...
  • 1、什麼是網路爬蟲 關於爬蟲百度百科這樣定義的:網路爬蟲(又被稱為網頁蜘蛛,網路機器人,在FOAF社區中間,更經常的稱為網頁追逐者),是一種按照一定的規則,自動地抓取萬維網信息的程式或者腳本。另外一些不常使用的名字還有螞蟻、自動索引、模擬程式或者蠕蟲。從搜索引擎開始,爬蟲應該就出現了,爬蟲所做的事情 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...