C# と VB.NET の質問掲示板
ASP.NET、C++/CLI、Java 何でもどうぞ
掲示板トップ
C# と VB.NET 入門
新規作成
利用方法
ツリー表示
トピック表示
ランキング
記事検索
過去ログ
ログ内検索
キーワードを複数指定する場合は 半角スペース で区切ってください。
検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
[返信]をクリックすると返信ページへ移動します。
キーワード
/
検索条件
/
(AND)
(OR)
検索範囲
/
(現在のログ)
(全過去ログ)
(過去ログ1)
(過去ログ2)
(過去ログ3)
(過去ログ4)
(過去ログ5)
(過去ログ6)
(過去ログ7)
(過去ログ8)
(過去ログ9)
(過去ログ10)
(過去ログ11)
(過去ログ12)
(過去ログ13)
(過去ログ14)
(過去ログ15)
(過去ログ16)
(過去ログ17)
(過去ログ18)
(過去ログ19)
(過去ログ20)
(過去ログ21)
(過去ログ22)
(過去ログ23)
(過去ログ24)
(過去ログ25)
(過去ログ26)
(過去ログ27)
(過去ログ28)
(過去ログ29)
(過去ログ30)
(過去ログ31)
(過去ログ32)
(過去ログ33)
(過去ログ34)
(過去ログ35)
(過去ログ36)
(過去ログ37)
(過去ログ38)
(過去ログ39)
(過去ログ40)
(過去ログ41)
(過去ログ42)
(過去ログ43)
(過去ログ44)
(過去ログ45)
(過去ログ46)
(過去ログ47)
(過去ログ48)
(過去ログ49)
(過去ログ50)
(過去ログ51)
(過去ログ52)
(過去ログ53)
(過去ログ54)
(過去ログ55)
(過去ログ56)
(過去ログ57)
(過去ログ58)
(過去ログ59)
(過去ログ60)
(過去ログ61)
(過去ログ62)
(過去ログ63)
(過去ログ64)
(過去ログ65)
(過去ログ66)
(過去ログ67)
(過去ログ68)
(過去ログ69)
(過去ログ70)
(過去ログ71)
(過去ログ72)
(過去ログ73)
(過去ログ74)
(過去ログ75)
(過去ログ76)
(過去ログ77)
(過去ログ78)
(過去ログ79)
(過去ログ80)
(過去ログ81)
(過去ログ82)
(過去ログ83)
(過去ログ84)
(過去ログ85)
(過去ログ86)
(過去ログ87)
(過去ログ88)
(過去ログ89)
(過去ログ90)
(過去ログ91)
(過去ログ92)
(過去ログ93)
(過去ログ94)
(過去ログ95)
(過去ログ96)
(過去ログ97)
(過去ログ98)
(過去ログ99)
(過去ログ100)
(過去ログ101)
(過去ログ102)
(過去ログ103)
(過去ログ104)
(過去ログ105)
(過去ログ106)
(過去ログ107)
(過去ログ108)
(過去ログ109)
(過去ログ110)
(過去ログ111)
(過去ログ112)
(過去ログ113)
(過去ログ114)
(過去ログ115)
(過去ログ116)
(過去ログ117)
(過去ログ118)
(過去ログ119)
(過去ログ120)
(過去ログ121)
(過去ログ122)
(過去ログ123)
(過去ログ124)
(過去ログ125)
(過去ログ126)
(過去ログ127)
(過去ログ128)
(過去ログ129)
(過去ログ130)
(過去ログ131)
(過去ログ132)
(過去ログ133)
(過去ログ134)
(過去ログ135)
(過去ログ136)
(過去ログ137)
(過去ログ138)
(過去ログ139)
(過去ログ140)
(過去ログ141)
(過去ログ142)
(過去ログ143)
(過去ログ144)
(過去ログ145)
(過去ログ146)
(過去ログ147)
(過去ログ148)
(過去ログ149)
(過去ログ150)
(過去ログ151)
(過去ログ152)
(過去ログ153)
(過去ログ154)
(過去ログ155)
(過去ログ156)
(過去ログ157)
(過去ログ158)
(過去ログ159)
(過去ログ160)
(過去ログ161)
(過去ログ162)
(過去ログ163)
(過去ログ164)
(過去ログ165)
(過去ログ166)
(過去ログ167)
(過去ログ168)
(過去ログ169)
(過去ログ170)
(過去ログ171)
(過去ログ172)
(過去ログ173)
(過去ログ174)
(過去ログ175)
(過去ログ176)
(過去ログ177)
(過去ログ178)
(過去ログ179)
強調表示
/
ON
(自動リンクOFF)
結果表示件数
/
20件
30件
40件
50件
100件
記事No検索
/
ON
大文字と小文字を区別する
No.94070 の関連記事表示
ヒット / 10件
(1-10 を表示)
<<
0
>>
■94070
excelと画面の表示スケール
□投稿者/ だんぼ -
(2020/03/10(Tue) 19:52:36)
分類:[C#]
Windowsフォームでexcelを起動させるプログラムを作りました。
しかしアプリ側からexcelを立ち上げるとexcelの表示文字がぼやけているようになります。
恐らくPCのディスプレイの表示スケールを125%にしているのが原因ではないかと考えています。
フォームアプリを使わずに立ち上げるとぼやけずに起動します。
表示スケールを変更してもぼやけずにexcelを起動させるにはどうしたらいいでしょうか?
サンプルコード、もしくは参考になるサイトがあったら教えてください。
それとも別の原因も考えられるのでしょうか?
親記事 /過去ログ163より /
関連記事表示
削除チェック/
■94071
Re[1]: excelと画面の表示スケール
□投稿者/ 魔界の仮面弁士 -
(2020/03/10(Tue) 20:42:28)
■
No94070
(だんぼ さん) に返信
> フォームアプリを使わずに立ち上げるとぼやけずに起動します。
そういうことが起きるのですね…。(試していません)
お使いの .NET Framework のバージョンは何でしょうか。
また、manifest による高 DPI 対応について、どのように設定されていますか?
> サンプルコード、もしくは参考になるサイトがあったら教えてください。
直接の解決策になるかは分かりませんが:
2019-07-30 [Windowsフォームでの高DPI(Hi-DPI)対応のコツ]
https://qiita.com/mono1729/items/a93505a5cb3fe194b7dc
2019-05-26 [WindowsのDPIスケーリング処理について一考察]
https://www.timbreofprogram.info/blog/archives/1528
2018-11-19 [高DPI環境で作るフォームアプリケーション(C#)]
https://elesynd.blogspot.com/2018/11/hDpiForm.html
2017-05-16 [Windows フォームでの高 DPI サポート]
https://docs.microsoft.com/ja-jp/dotnet/framework/winforms/high-dpi-support-in-windows-forms
2017-01-24 [Windows Formsアプリケーションの高DPI対応]
https://qiita.com/felis_silv/items/efee4b1a397b0b95100a
記事No.94070 のレス /過去ログ163より /
関連記事表示
削除チェック/
■94075
Re[2]: excelと画面の表示スケール
□投稿者/ だんぼ -
(2020/03/11(Wed) 10:58:40)
■
No94071
(魔界の仮面弁士 さん) に返信
> お使いの .NET Framework のバージョンは何でしょうか。
> また、manifest による高 DPI 対応について、どのように設定されていますか?
.NET Frameworkのバージョンは4.6です。
manifestは使っていませんでしたので追加し、下記の部分だけコメントアウトを外しました。
<application xmlns="urn:schemas-microsoft-com:asm.v3">
<windowsSettings>
<dpiAware xmlns="
http://schemas.microsoft.com/SMI/2005/WindowsSettings">true</dpiAware>
</windowsSettings>
</application>
フォームのAutoScaleModeプロパティもDpiモードに変更しました。
変更後デバッグしてみると
シート数をカウント⇒シート名をリストボックスにセット⇒アクティブシートの確認で例外になってしまうようになりました。
error CS103;現在のコンテキストに'ActiveSheet'という名前は存在しません。
workbookのparentプロパティでネイティブコードのデバッグを有効・・・云々
プロジェクトのプロパティのデバッグの欄で”ネイティブコードデバッグを有効にする”にチェックを入れましたが変化ありません。
// Excelを開く
excelApp.Visible = true;
// Excel でブックを開く
workBook = excelApp.Workbooks.Open(path);
// リストボックス初期化
listBoxSheet.Items.Clear();
//シート数をカウント
for (int i = 1; i <= workBook.Sheets.Count; i++)
{
listBoxSheet.Items.Add(workBook.Sheets(i).Name);
if (workBook.ActiveSheet.Name == workBook.Sheets(i).Name) ←ここで例外
{
listBoxSheet.SelectedIndex = i - 1;
workBook.ActiveSheet.Range("A1").Select();
}
}
スキルが足りず、対処方法がわかりません。よろしくお願いします。
ちなみにmanifestを追加する前までは問題なく動作していました。
記事No.94070 のレス /過去ログ163より /
関連記事表示
削除チェック/
■94076
Re[3]: excelと画面の表示スケール
□投稿者/ 魔界の仮面弁士 -
(2020/03/11(Wed) 12:43:52)
■
No94075
(だんぼ さん) に返信
> <dpiAware xmlns="
http://schemas.microsoft.com/SMI/2005/WindowsSettings">true</dpiAware>
dpiAware で指定できる値は、「True」「False」「True/PM」「Per-Monitor」の 4 種ですね。
実行 OS にも依存します。
http://grabacr.net/archives/1132
> error CS103;現在のコンテキストに'ActiveSheet'という名前は存在しません。
CS103 というのは、CS0103 の書き間違いでしょうか。
https://docs.microsoft.com/ja-jp/dotnet/csharp/language-reference/compiler-messages/cs0103
ActiveSheet プロパティを持っているのは、Global 系を除けば
Excel.Application オブジェクト
Excel.Window オブジェクト
Excel.Workbook オブジェクト
の 3 つですね。
> if (workBook.ActiveSheet.Name == workBook.Sheets(i).Name) ←ここで例外
workBook 変数のデータ型は、以下のうちどれにしていますか?
(3) であれば大丈夫と思いますが、もし (1) ならばエラーになりそう。
(1) object 型 (System.Object クラス)
(2) dynamic 型
(3) Workbook 型 (Excel.Workbook インターフェイス)
(4) WorkbookClass 型 (非推奨)
> workBook = excelApp.Workbooks.Open(path);
上記の部分は、
workbooks = excelApp.Workbooks;
workBook = workbooks.Open(path);
の形にしておくことをお奨めします。
COM オブジェクトを変数として受け取っておかないと、
処理後に Workbooks コレクションを明示的に解放できなくなってしまいますので。
※ここでいう解放処理とは、Marshal クラスの (Final)ReleaseComObject メソッドの事です
workBook.Sheets.Count や workBook.ActiveSheet.何某 も同様です。
string acitveSheetName = "";
dynamic activeSheet = excelApp.ActiveSheet;
if (activeSheet != null) {
// activeSheetが null になることはほぼ無いが、一応念のため
acitveSheetName = activeSheet.Name;
}
Excel.Sheets sheets = workBook.Sheets;
listBoxSheet.BeginUpdate();
int selectedIndex = -1;
for (int i = 1; i <= sheets.Count; i++) {
// どちらの構文がサポートされるのかは、
// C# バージョンおよび相互運用アセンブリによって異なります。
dynamic sheet = sheets[i] または sheets(i);
listBoxSheet.Items.Add(sheet.Name);
if (sheet.Name == activeSheetName) {
selectedIndex = i - 1;
}
if (Marshal.IsComObject(sheet)) { Marshal.ReleaseComObject(sheet); }
}
listBoxSheet.SelectedIndex = i - 1;
listBoxSheet.EndUpdate();
if (activeSheet != null) {
Excel.Range a1 = activeSheet.Range("A1");
a1.Select();
if (Marshal.IsComObject(a1)) { Marshal.ReleaseComObject(a1); }
if (Marshal.IsComObject(activeSheet)) { Marshal.ReleaseComObject(activeSheet); }
}
記事No.94070 のレス /過去ログ163より /
関連記事表示
削除チェック/
■94077
Re[4]: excelと画面の表示スケール
□投稿者/ furu -
(2020/03/11(Wed) 14:17:17)
■
No94076
(魔界の仮面弁士 さん) に返信
いつもみても参考になります。
重箱の隅を突くようですみません。
> ■
No94075
(だんぼ さん) に返信
> listBoxSheet.SelectedIndex = i - 1;
forループ変数を外で使用してしまっています。
正 listBoxSheet.SelectedIndex = selectedIndex;
記事No.94070 のレス /過去ログ163より /
関連記事表示
削除チェック/
■94085
Re[5]: excelと画面の表示スケール
□投稿者/ 魔界の仮面弁士 -
(2020/03/11(Wed) 18:27:21)
■
No94077
(furu さん) に返信
> 重箱の隅を突くようですみません。
御指摘感謝。助かります。
実際にテストしていないことがバレますね…(^^;
開発環境ではなく、掲示板上に直接書いたコードなので、
動くかどうかは保証できません。
記事No.94070 のレス /過去ログ163より /
関連記事表示
削除チェック/
■94093
Re[4]: excelと画面の表示スケール
□投稿者/ だんぼ -
(2020/03/12(Thu) 11:48:11)
■
No94076
(魔界の仮面弁士 さん) に返信
> ■
No94075
(だんぼ さん) に返信
> dpiAware で指定できる値は、「True」「False」「True/PM」「Per-Monitor」の 4 種ですね。
Per-Monitorにしてみました。
>
>>error CS103;現在のコンテキストに'ActiveSheet'という名前は存在しません。
> CS103 というのは、CS0103 の書き間違いでしょうか。
CS0103の間違いでした。失礼しました。
>
> workBook 変数のデータ型は、以下のうちどれにしていますか?
> (3) であれば大丈夫と思いますが、もし (1) ならばエラーになりそう。
>
> (1) object 型 (System.Object クラス)
> (2) dynamic 型
> (3) Workbook 型 (Excel.Workbook インターフェイス)
> (4) WorkbookClass 型 (非推奨)
(2)でしたので(3)に変更しました。
ソースコードをそのまま使わせていただいたら表示ボケが改善されました。
魔界の仮面弁士さん、furuさん
ありがとうございました。
記事No.94070 のレス /過去ログ163より /
関連記事表示
削除チェック/
■94094
Re[5]: excelと画面の表示スケール
□投稿者/ だんぼ -
(2020/03/12(Thu) 11:48:38)
2020/03/12(Thu) 11:58:23 編集(投稿者)
2020/03/12(Thu) 11:58:18 編集(投稿者)
解決したと思ったのですが再度質問させていただきます。
上記の話の続きですがアプリから開いたexcelファイルの表示ボケは直ったのですが
元々開いてた別のエクセルファイルがアプリから開いたexcelが立ち上がると同時に表示ボケしました。これはmanifestの設定次第って事でしょうか?
記事No.94070 のレス /過去ログ163より /
関連記事表示
削除チェック/
■94097
Re[6]: excelと画面の表示スケール
□投稿者/ 魔界の仮面弁士 -
(2020/03/12(Thu) 13:08:38)
■
No94094
(だんぼ さん) に返信
> 上記の話の続きですがアプリから開いたexcelファイルの表示ボケは直ったのですが
> 元々開いてた別のエクセルファイルがアプリから開いたexcelが立ち上がると同時に表示ボケしました。これはmanifestの設定次第って事でしょうか?
環境を用意して検証実験する余裕が無いので、今はちょっと分からないです。
Excel のバージョンに依存している様子はありますか?
Per-Monitor 設定の場合、ディスプレイモニタごとの設定にあわせて
表示が変わる可能性がありますが、Excel の表示が起動元アプリの
manifest に依存しているのかどうかは把握していません。
https://hide.maruo.co.jp/software/hidemarunew/v869_1.html
識者の登場を待ちたい所。
記事No.94070 のレス /過去ログ163より /
関連記事表示
削除チェック/
■94100
Re[7]: excelと画面の表示スケール
□投稿者/ だんぼ -
(2020/03/12(Thu) 14:04:22)
■
No94097
(魔界の仮面弁士 さん) に返信
> 環境を用意して検証実験する余裕が無いので、今はちょっと分からないです。
> Excel のバージョンに依存している様子はありますか?
Excel2007,Win10で差異はありませんでした。
> Per-Monitor 設定の場合、ディスプレイモニタごとの設定にあわせて
> 表示が変わる可能性がありますが、Excel の表示が起動元アプリの
> manifest に依存しているのかどうかは把握していません。
dpiAwareの値をtrue/PMにしてみたらアプリで立ち上げたexcelも普通に立ち上げたexcelも表示ボケしませんでした。
とりあえずこれで検証してみようと思います。
魔界の仮面弁士さん、ありがとうございました。
また、何かありましたらよろしくお願いします。
記事No.94070 のレス / END /過去ログ163より /
関連記事表示
削除チェック/
<<
0
>>
パスワード/
-
Child Tree
-