へっぽこプログラマーの備忘録
プログラムを中心とした個人的なメモ用のブログです。 タイトルは迷走中。
内容の保証はできませんのであしからずご了承ください。
menu
keyboard_arrow_up
Top
search
close
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
Home
›
Visual Studio
›
Visual Studio で .NET Core + Electron.NET を使う
2017/11/17
Visual Studio で .NET Core + Electron.NET を使う
update
event_note
label
.NET Core
label
Electron.NET
label
Visual Studio
.NET Core ではデスクトップアプリケーションは作成できないと思っていましたが、Electron の .NET 版があるのを知りました。 そして、Windows で .NET を使うならやはり Visual Studio を使いたいので、試してみました。
尚、私は Electron 自体は使ったことありません。 Node.js も昔に少し使ったことがあるという程度です。 ## 環境 - Visual Studio 2017 - .NET Core 2.0 (ASP.NET Core 2.0) - Node.js v8.9.1 - [Electron.NET](https://github.com/ElectronNET/Electron.NET) v0.0.7 ちなみにデモアプリケーションもあります。 - [Electron.NET API Demos](https://github.com/ElectronNET/electron.net-api-demos) ## 準備 絶対に必要なのは以下の2つなので、あらかじめインストールしておきます。 - [.NET Core SDK](https://www.microsoft.com/net/download/core#/) (2.0 以上) - [Node.js](https://nodejs.org/ja/) (v8 以上) - 参考:[Node.js のインストールとプロキシの設定](http://kuttsun.blogspot.jp/2017/11/nodejs.html) また、今回は Visual Studio を使うので、Visual Studio もインストールします。 - Visual Studio 2017 ## プロジェクトの作成 Visual Studio を起動します。 [ファイル] > [新規作成] > [プロジェクト] を選択します。 [ASP.NET Core Web アプリケーション] を選択します。
[Web アプリケーション (モデル ビュー コントローラー)] を選択します。
## Electron.NET を使用するための設定 [公式](https://github.com/ElectronNET/Electron.NET)で説明されている通りに設定を行います。 ### ElectronNET.API NuGet パッケージのインストール [ツール] > [NuGet パッケージマネージャー] > [パッケージ マネージャー コンソール] を選択します。 以下のコマンドを入力してパッケージをインストールします。 ```sh PM> Install-Package ElectronNET.API ``` ### Program.cs の変更 `Program.cs` を開き、`BuildWebHost` メソッドに `UseElectron` を追加します。 ```cs using ElectronNET.API; // 中略 public static IWebHost BuildWebHost(string[] args) { return WebHost.CreateDefaultBuilder(args) .UseElectron(args) .UseStartup
() .Build(); } ``` ### Startup.cs の変更 `Startup.cs` を開き、`Configure` メソッドの最後に `Electron.WindowManager.CreateWindowAsync` を追加します。 ```cs using ElectronNET.API; // 中略 public void Configure(IApplicationBuilder app, IHostingEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); app.UseBrowserLink(); } else { app.UseExceptionHandler("/Home/Error"); } app.UseStaticFiles(); app.UseMvc(routes => { routes.MapRoute( name: "default", template: "{controller=Home}/{action=Index}/{id?}"); }); // Open the Electron-Window here Task.Run(async () => await Electron.WindowManager.CreateWindowAsync()); } ``` ### .csproj の変更 Visual Studio 上でプロジェクト名を右クリックし、[(プロジェクト名).csproj を編集する] を選択します。 `ItemGroup` の中に、`
` を追加します。 ```xml
netcoreapp2.0
``` ## NuGet パッケージの復元 ここまで完了したら、一度 Visual Studio を終了し、`dotnet-electronize` を使うために NuGet パッケージの復元を行います。 コマンドプロンプト(または PowerShell)を開き、プロジェクトの場所に移動してから以下のコマンドを実行します。 ```sh > dotnet restore ``` ## Electron.NET プロジェクトの初期化 続いて以下のコマンドを入力してプロジェクトの初期化を行います。 ```sh > dotnet electronize init ``` プロジェクト配下に `electronnet.manifest.json` というファイルが作成されます。 .csproj ファイルの変更されています。 次に以下のコマンドを打って、ビルドが正常にできることを確認します。 ```sh > dotnet electronize build ``` ## Electron.NET プロジェクトの実行 以上で準備は完了です。 Visual Studio を起動してソリューションを開きます。 すると、ターゲットに [Electron.NET App] というのが選択されていると思います。
この状態で F5 を押すと、Electron を使ったデスクトップアプリケーションが起動します。 が、ちょっと重いですね・・・。 (私の環境が貧弱なだけ?) Electron.NET はまだ登場したばかりで今後どうなるかわかりませんが、とりあえず動向はチェックしておこうと思います。 ## 参考 URL - https://qiita.com/katachi/items/6bba28d3b382e11e2535 - https://qiita.com/ikuhanaRock/items/42fc4d70494833db2653 - http://www.myrefblog.com/archives/11374
tweet
facebook
Pocket
B!
はてブ
LINE
chevron_left
chevron_right
Translate
Popular Posts
TortoiseGit でコミットメッセージを変更する
image
NO IMAGE
smbclient で session setup failed: NT_STATUS_LOGON_FAILURE が表示される
Docker for Windows の設定
image
NO IMAGE
マージ元ブランチとマージ先ブランチ
image
NO IMAGE
TortoiseSVN ロック状態のチェック
image
NO IMAGE
Visual Studio で文字がにじむ(ぼやける)
TortoiseGit でブランチ間の差分を見る
image
NO IMAGE
AsciidocFX をビルドする
image
NO IMAGE
PowerShellでブレークポイントが設定できない場合
[Python] 文字列の判定で、None と空文字を同時に判定する
Labels
.NET Core
31
.NET Framework
17
.NET Standard
2
AdminLTE
1
AI
1
Apache
3
AppVeyor
2
AsciiDoc
7
ASP.NET Core
55
Atom
4
AWS
5
AWS Cloud9
4
blockdiag
1
Blogger
13
Bootstrap
3
C/C++
6
C#
106
CentOS
3
Chrome
1
Chronograf
3
chrony
1
Codecov
1
CSS
1
Docker
80
DokuWiki
4
Doxygen
1
draw.io
1
EasyTag
1
Electron
1
Electron.NET
2
Entity Framework Core
9
Excel
2
FFmpeg
3
Firefox
6
Flask
1
Git
19
GitBook
4
GitBucket
7
GitHub
7
GitLab
39
Go
1
Google
1
Google Cloud Platform
1
Grafana
13
GStreamer
2
HTML
5
IIS
8
InfluxDB
14
JavaScript
15
Jekyll
2
Jenkins
7
Linux
34
Log4View
1
MahApps.Metro
3
MaterialDesignInXamlToolkit
1
MkDocs
2
MongoDB
5
MVC
1
MVVM
6
nginx
3
NLog
3
Node.js
8
npm
1
NVIDIA
3
onvif
1
OpenAPI
2
OpenCV
4
OpenSSL
3
OpenVINO
2
ownCloud
2
pandas
1
Pine Script
1
PlantUML
5
Portainer
3
PowerShell
8
Prism
2
PySide
19
Python
88
PyTorch
1
RabbitVCS
1
Razor
3
redis
1
Redmine
33
Redoc
1
remark.js
2
rocketchat
10
Ruby
3
scikit-learn
1
shotcut
1
SignalR
1
Slack
1
Socket.IO
1
SonarQube
5
Sphinx
10
SQL Server
5
SQLite
1
StableDiffusion
1
Subversion
2
Swagger
1
Swarmpit
1
Syslog
3
Telegraf
6
Tesseract
3
TestLink
2
Tomcat
2
TortoiseGit
11
TortoiseSVN
2
Trading View
1
Traefik
3
Travis CI
1
Ubuntu
31
Visual Studio
39
Visual Studio Code
10
VSCode
8
Vue.js
8
Windows
62
Windows 10
5
Windows ADK
1
Windows API
2
Windows Embedded
4
wkhtmltopdf
2
Word
3
WPF
12
WSL
5
WSL2
5
Xamarin
1
xUnit
5
yaml
1
yolo
1
アプリケーション
1
デザインパターン
1
テスト
1
バッチファイル
2
プログラミング
4
ライセンス
1
暗号資産(仮想通貨)
1
英語
2
確定申告
1
機械学習
1
強化学習
1
雑記
1
書籍
1
数学
1
正規表現
1
動画編集
1
Blog Archive
►
2024
(18)
►
9月
(5)
►
8月
(1)
►
7月
(2)
►
6月
(1)
►
4月
(2)
►
3月
(1)
►
2月
(5)
►
1月
(1)
►
2023
(30)
►
12月
(3)
►
11月
(5)
►
10月
(2)
►
9月
(1)
►
8月
(2)
►
7月
(4)
►
6月
(2)
►
5月
(3)
►
4月
(2)
►
3月
(2)
►
2月
(3)
►
1月
(1)
►
2022
(106)
►
12月
(5)
►
11月
(1)
►
10月
(3)
►
9月
(6)
►
8月
(7)
►
7月
(6)
►
6月
(13)
►
5月
(9)
►
4月
(15)
►
3月
(11)
►
2月
(14)
►
1月
(16)
►
2021
(85)
►
12月
(11)
►
11月
(6)
►
10月
(4)
►
9月
(10)
►
8月
(8)
►
7月
(4)
►
6月
(18)
►
5月
(7)
►
4月
(8)
►
3月
(2)
►
2月
(2)
►
1月
(5)
►
2020
(56)
►
12月
(1)
►
11月
(3)
►
10月
(3)
►
9月
(3)
►
8月
(3)
►
7月
(7)
►
6月
(7)
►
5月
(2)
►
4月
(6)
►
3月
(6)
►
2月
(3)
►
1月
(12)
►
2019
(92)
►
12月
(13)
►
11月
(9)
►
10月
(3)
►
9月
(2)
►
8月
(3)
►
7月
(5)
►
6月
(11)
►
5月
(6)
►
4月
(17)
►
3月
(9)
►
2月
(6)
►
1月
(8)
►
2018
(100)
►
12月
(1)
►
11月
(11)
►
10月
(8)
►
9月
(6)
►
8月
(10)
►
7月
(10)
►
6月
(8)
►
5月
(9)
►
4月
(8)
►
3月
(14)
►
2月
(4)
►
1月
(11)
▼
2017
(117)
►
12月
(14)
▼
11月
(20)
Visual Studio のビルド後イベントで配布用の ZIP ファイルを自動生成する
.NET アプリケーションを XCOPY 配置で配布する
ファイル選択ダイアログとフォルダ選択ダイアログ
GitHub と AppVeyor で .NET アプリケーションの継続的インテグレーションを行う
C# におけるコマンドライン引数の解析
Visual Studio で .NET Core + Electron.NET を使う
Firefox 57 用にアドオンのインストールと設定変更を行う
Node.js のインストールとプロキシの設定
GitLab CI で .NET Core の継続的インテグレーションを行う
GitLab をアップグレードしたら Redmine へのリンクが解除された
GitHub と Travis CI で .NET Core の継続的インテグレーションを行う
GitLab で LDAP 認証するとメールアドレスが勝手に設定されるのを直す
GitLab のバージョンアップを行った
GitLab のバックアップとリストア
Visual Studio 2017 Update 4 (15.4) で .NET Core プロジ...
ASP.NET Core におけるバリデーションの基本
[C#] 非同期メソッドを同期メソッドとして扱いたい場合
ASP.NET Core における css と js ファイルの Bundle と Minify
ASP.NET Core アプリケーションを外部に公開するための Windows ファイアウォールの設定
ASP.NET Core アプリケーションを IIS でホストする
►
10月
(17)
►
9月
(19)
►
8月
(10)
►
7月
(8)
►
6月
(3)
►
5月
(6)
►
4月
(5)
►
3月
(2)
►
2月
(8)
►
1月
(5)
►
2016
(91)
►
12月
(5)
►
11月
(9)
►
10月
(11)
►
9月
(9)
►
8月
(6)
►
7月
(14)
►
6月
(14)
►
5月
(11)
►
4月
(10)
►
3月
(2)
►
2015
(23)
►
12月
(4)
►
11月
(2)
►
10月
(8)
►
9月
(8)
►
7月
(1)
►
2013
(3)
►
11月
(1)
►
9月
(1)
►
7月
(1)
►
2012
(2)
►
7月
(1)
►
6月
(1)
►
2011
(1)
►
9月
(1)
►
2009
(1)
►
7月
(1)
►
2008
(2)
►
11月
(1)
►
7月
(1)
►
2007
(3)
►
10月
(3)