ユーザーによるウィンドウサイズの手動変更を禁止(固定)する方法を紹介します。
計算機のようなツールや、特定のレイアウトを厳密に維持したいアプリに適しています。
tauri.conf.json での初期設定、および実行時に動的にリサイズ可否を切り替える手順について解説します。
前提条件
Permissions (権限) の設定
src-tauri/capabilities/default.json に以下の権限を追加します。
{
"permissions": [
...,
"core:window:allow-set-resizable",
"core:window:default"
]
}
1. 静的な設定 (tauri.conf.json)
{
"app": {
"windows": [
{
"resizable": false
}
]
}
}
2. フロントエンドから変更する (TypeScript)
サンプルコード
import { getCurrentWindow } from '@tauri-apps/api/window';
const appWindow = getCurrentWindow();
// リサイズを禁止
await appWindow.setResizable(false);
// リサイズを許可
await appWindow.setResizable(true);
3. バックエンドから変更する (Rust)
use tauri::Manager;
#[tauri::command]
fn set_resizable(app_handle: tauri::AppHandle, enable: bool) {
if let Some(window) = app_handle.get_webview_window("main") {
window.set_resizable(enable).unwrap();
}
}