Files
FTXUI/zh-TW/installation_cmake.html
2025-12-13 19:38:34 +00:00

422 lines
17 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<!-- HTML header for doxygen 1.9.8-->
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=11"/>
<meta name="generator" content="Doxygen 1.12.0"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>FTXUI: CMake</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<script type="text/javascript" src="doxygen-awesome-fragment-copy-button.js"></script>
<script type="text/javascript" src="doxygen-awesome-paragraph-link.js"></script>
<script type="text/javascript" src="doxygen-awesome-interactive-toc.js"></script>
<script type="text/javascript" src="doxygen-awesome-tabs.js"></script>
<script type="module">
DoxygenAwesomeFragmentCopyButton.init()
DoxygenAwesomeParagraphLink.init()
DoxygenAwesomeInteractiveToc.init()
DoxygenAwesomeTabs.init()
await new Promise(r => window.addEventListener('DOMContentLoaded', r));
// Remove title when a img[alt='title-img'] is present.
// Find an image with the alt "img-title".
const img = document.querySelector("img[alt='title-img']");
const header = document.querySelector(".headertitle");
if (img && header) {
// Hide the header title progressively.
header.style.display = "none";
// Show progressively the image.
img.style.maxHeight = "40vh";
img.style.maxWidth = "100%";
img.style.objectFit = "contain";
}
// In the "examples.html" page. Turn every link with text
// "examples/<...>
//
// Add a "demo" link toward.
// https://arthursonzogni.github.io/FTXUI/examples/?file=<...>
const examples = document.querySelectorAll("a")
examples.forEach((example) => {
if (!example.textContent.startsWith("examples/")) {
return;
}
// Remove the ".cpp" extension from the example name.
const exampleName = example.textContent.replace("examples/", "").replace(".cpp", "");
const a = document.createElement("a");
a.textContent = "[demo]";
a.href = "https://arthursonzogni.github.io/FTXUI/examples/?file=" + exampleName;
a.style.marginRight= "1em";
a.style.fontWeight = "bold";
example.parentElement.insertBefore(a, example)
});
// If the current URL ends with -example.html, we can add a link to the demo
// as well using the div.title textContent.
const url = new URL(window.location.href);
if (url.pathname.endsWith("-example.html")) {
// Get the title text.
const title = document.querySelector("div.title").textContent;
const example = title.replace("examples/", "").replace(".cpp", "");
// Create a link to the demo.
const a = document.createElement("a");
a.textContent = "[demo]";
a.href = "https://arthursonzogni.github.io/FTXUI/examples/?file=" + example;
a.style.marginLeft = "1em";
a.style.fontWeight = "bold";
a.style.display = "inline-block";
// Insert the link after the title.
const titleDiv = document.querySelector("div.title");
if (titleDiv) {
titleDiv.insertBefore(a, titleDiv.nextSibling);
}
}
</script>
<script type="module">
// Click on the navtree, except for the main page where this is already done
// automatically.
let delay = 0;
while(true) {
const navtree = document.querySelector("div.item.selected");
if (!navtree) {
delay *= 2;
delay += 1;
await new Promise(resolve => setTimeout(resolve, delay));
continue;
}
// Include only selected navtree items.
console.log("navtree.textContent", navtree.textContent);
if (!navtree.textContent.includes("Getting Started") &&
!navtree.textContent.includes("Installation") &&
!navtree.textContent.includes("ftxui / screen") &&
!navtree.textContent.includes("ftxui / dom") &&
!navtree.textContent.includes("ftxui / component") &&
!navtree.textContent.includes("Reference")) {
break;
}
// Find the first link inside the navtree.
const link = navtree.querySelector("a");
if (link) {
// Simulate a click on the link.
link.click();
break;
}
}
</script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="navtreedata.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="cookie.js"></script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/searchdata.js"></script>
<script type="text/javascript" src="search/search.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
<link href="doxygen-awesome.css" rel="stylesheet" type="text/css"/>
<link href="stylesheet.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr id="projectrow">
<td id="projectalign">
<div id="projectname">FTXUI<span id="projectnumber">&#160;6.1.9</span>
</div>
<div id="projectbrief">C++ functional terminal UI.</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.12.0 -->
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
var searchBox = new SearchBox("searchBox", "search/",'.html');
/* @license-end */
</script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function() { codefold.init(0); });
/* @license-end */
</script>
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function() {
initMenu('',true,false,'search.php','Search',true);
$(function() { init_search(); });
});
/* @license-end */
</script>
<div id="main-nav"></div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
<div id="nav-tree">
<div id="nav-tree-contents">
<div id="nav-sync" class="sync"></div>
</div>
</div>
<div id="splitbar" style="-moz-user-select:none;"
class="ui-resizable-handle">
</div>
</div>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function(){initNavTree('installation_cmake.html',''); initResizable(true); });
/* @license-end */
</script>
<div id="doc-content">
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>
<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<div id="MSearchResults">
<div class="SRPage">
<div id="SRIndex">
<div id="SRResults"></div>
<div class="SRStatus" id="Loading">Loading...</div>
<div class="SRStatus" id="Searching">Searching...</div>
<div class="SRStatus" id="NoMatches">No Matches</div>
</div>
</div>
</div>
</div>
<div><div class="header">
<div class="headertitle"><div class="title">CMake</div></div>
</div><!--header-->
<div class="contents">
<div class="toc"><h3>Table of Contents</h3>
<ul>
<li class="level1">
<a href="#整合方法">整合方法</a>
<ul>
<li class="level2">
<a href="#使用-fetchcontent">使用 FetchContent</a>
</li>
<li class="level2">
<a href="#使用-find_package">使用 find_package</a>
</li>
<li class="level2">
<a href="#使用-git-submodule">使用 git submodule</a>
</li>
</ul>
</li>
<li class="level1">
<a href="#可選的-cmake-旗標">可選的 CMake 旗標</a>
</li>
<li class="level1">
<a href="#驗證整合">驗證整合</a>
</li>
</ul>
</div>
<div class="textblock"><p>本頁說明如何使用 <a href="https://cmake.org">CMake</a> 依賴 FTXUI。</p>
<h1><a class="anchor" id="整合方法"></a>
整合方法</h1>
<h2><a class="anchor" id="使用-fetchcontent"></a>
使用 FetchContent</h2>
<p>這種方法會在配置時下載 FTXUI不需要全系統安裝。</p>
<div class="fragment"><div class="line">include(FetchContent)</div>
<div class="line"> </div>
<div class="line">FetchContent_Declare(ftxui</div>
<div class="line"> GIT_REPOSITORY https://github.com/ArthurSonzogni/FTXUI</div>
<div class="line"> GIT_TAG v6.1.9 # 請替換為版本、標籤或提交雜湊</div>
<div class="line">)</div>
<div class="line"> </div>
<div class="line">FetchContent_MakeAvailable(ftxui)</div>
<div class="line"> </div>
<div class="line">add_executable(main main.cpp)</div>
<div class="line">target_link_libraries(main</div>
<div class="line"> PRIVATE ftxui::screen</div>
<div class="line"> PRIVATE ftxui::dom</div>
<div class="line"> PRIVATE ftxui::component</div>
<div class="line">)</div>
</div><!-- fragment --><p>這確保了可重現的構建和輕鬆的依賴管理。</p>
<h2><a class="anchor" id="使用-find_package"></a>
使用 find_package</h2>
<p>如果 FTXUI 已在系統範圍內安裝或透過套件管理器(例如 vcpkg 或 Conan安裝您可以使用</p>
<div class="fragment"><div class="line">find_package(ftxui REQUIRED)</div>
<div class="line"> </div>
<div class="line">add_executable(main main.cpp)</div>
<div class="line">target_link_libraries(main</div>
<div class="line"> PRIVATE ftxui::screen</div>
<div class="line"> PRIVATE ftxui::dom</div>
<div class="line"> PRIVATE ftxui::component</div>
<div class="line">)</div>
</div><!-- fragment --><p>請確保該套件在您的 <code>CMAKE_PREFIX_PATH</code> 中可見。</p>
<h2><a class="anchor" id="使用-git-submodule"></a>
使用 git submodule</h2>
<p>您也可以將 FTXUI 作為 <a href="https://git-scm.com/book/en/v2/Git-Tools-Submodules">Git 子模組</a> 添加,使其成為您儲存庫的一部分:</p>
<div class="fragment"><div class="line">git submodule add https://github.com/ArthurSonzogni/FTXUI external/ftxui</div>
<div class="line">git submodule update --init --recursive</div>
</div><!-- fragment --><p>當克隆已包含 FTXUI 作為子模組的儲存庫時,請確保使用以下命令獲取子模組:</p>
<div class="fragment"><div class="line">git clone --recurse-submodules &lt;your-repo&gt;</div>
<div class="line"># 或者,如果已克隆:</div>
<div class="line">git submodule update --init --recursive</div>
</div><!-- fragment --><p>然後在您的 <code>CMakeLists.txt</code> 中:</p>
<div class="fragment"><div class="line">add_subdirectory(external/ftxui)</div>
<div class="line"> </div>
<div class="line">add_executable(main main.cpp)</div>
<div class="line">target_link_libraries(main</div>
<div class="line"> PRIVATE ftxui::screen</div>
<div class="line"> PRIVATE ftxui::dom</div>
<div class="line"> PRIVATE ftxui::component</div>
<div class="line">)</div>
</div><!-- fragment --><p>如果您想在自己的儲存庫中供應 FTXUI這種方法效果很好。</p>
<h1><a class="anchor" id="可選的-cmake-旗標"></a>
可選的 CMake 旗標</h1>
<p>FTXUI 支援以下 CMake 選項:</p>
<table class="markdownTable">
<tr class="markdownTableHead">
<th class="markdownTableHeadNone">選項 </th><th class="markdownTableHeadNone">描述 </th><th class="markdownTableHeadNone">預設值 </th></tr>
<tr class="markdownTableRowOdd">
<td class="markdownTableBodyNone">FTXUI_BUILD_EXAMPLES </td><td class="markdownTableBodyNone">構建捆綁的範例 </td><td class="markdownTableBodyNone">OFF </td></tr>
<tr class="markdownTableRowEven">
<td class="markdownTableBodyNone">FTXUI_BUILD_DOCS </td><td class="markdownTableBodyNone">構建文件 </td><td class="markdownTableBodyNone">OFF </td></tr>
<tr class="markdownTableRowOdd">
<td class="markdownTableBodyNone">FTXUI_BUILD_TESTS </td><td class="markdownTableBodyNone">啟用測試 </td><td class="markdownTableBodyNone">OFF </td></tr>
<tr class="markdownTableRowEven">
<td class="markdownTableBodyNone">FTXUI_ENABLE_INSTALL </td><td class="markdownTableBodyNone">生成安裝目標 </td><td class="markdownTableBodyNone">ON </td></tr>
<tr class="markdownTableRowOdd">
<td class="markdownTableBodyNone">FTXUI_MICROSOFT_TERMINAL_FALLBACK </td><td class="markdownTableBodyNone">改善 Windows 相容性 </td><td class="markdownTableBodyNone">ON/OFF </td></tr>
</table>
<p>要啟用選項:</p>
<div class="fragment"><div class="line">cmake -DFTXUI_BUILD_EXAMPLES=ON ..</div>
</div><!-- fragment --><h1><a class="anchor" id="驗證整合"></a>
驗證整合</h1>
<p>要確認設置正常,請構建並運行一個最小範例。 如果您需要完整的範本,請參閱:<a href="https://github.com/ArthurSonzogni/ftxui-starter">ftxui-starter</a></p>
<div class="section_buttons"></div><div class="section_buttons"><table class="markdownTable">
<tr class="markdownTableHead">
<th class="markdownTableHeadLeft">上一個 </th></tr>
<tr class="markdownTableRowOdd">
<td class="markdownTableBodyLeft"><a href="getting-started.html">入門</a> </td></tr>
</table>
</div><div class="section_buttons"></div> </div></div><!-- contents -->
</div><!-- PageDoc -->
</div><!-- doc-content -->
<!-- HTML footer for doxygen 1.9.8-->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
</div>
<script>
document.addEventListener('DOMContentLoaded', function() {
const projectNumber = document.getElementById('projectname');
if (!projectNumber) {
console.warn('Doxygen element with ID "projectnumber" not found. Cannot add version switcher.');
return;
}
const langs = ["en", "es", "fr", "ja", "zh-CH", "zh-TW"];
const lang_paths = {"en": "../index.html", "es": "../es/index.html", "fr": "../fr/index.html", "ja": "../ja/index.html", "zh-CH": "../zh-CH/index.html", "zh-TW": "index.html"};
const lang_display = {"en": "English", "es": "Espa\u00f1ol", "fr": "Fran\u00e7ais", "ja": "\u65e5\u672c\u8a9e", "zh-CH": "\u4e2d\u6587 (\u7b80\u4f53)", "zh-TW": "\u4e2d\u6587 (\u7e41\u9ad4)"};
const versions = ["main"];
const version_paths = {"main": "index.html"};
const currentLang = "zh-TW";
const currentVersion = "main";
// Helper function to create a styled select element
const createSelect = (options, current, paths, label, displayMap = null) => {
const select = document.createElement('select');
select.title = label;
select.onchange = function() {
const selectedValue = this.value;
if (selectedValue in paths) {
window.location.href = paths[selectedValue];
}
};
// Sort versions: 'main' first, then others numerically descending.
options.sort((a, b) => {
if (a === 'main') return -1;
if (b === 'main') return 1;
return b.localeCompare(a, undefined, { numeric: true, sensitivity: 'base' });
});
options.forEach(v => {
const option = document.createElement('option');
option.value = v;
// Use the displayMap if provided, otherwise default to the value (v)
option.textContent = displayMap ? displayMap[v] : v;
if (v === current) {
option.selected = true;
}
select.appendChild(option);
});
// Apply some styling to make it look good.
Object.assign(select.style, {
backgroundColor: 'rgba(0, 0, 0, 0.8)',
color: 'white',
border: '1px solid rgba(255, 255, 255, 0.2)',
padding: '5px',
borderRadius: '5px',
fontSize: '14px',
fontFamily: 'inherit',
margin: '0 5px 0 0',
cursor: 'pointer'
});
return select;
};
// 1. Create Language Switcher, passing the language display names map
const langSelect = createSelect(langs, currentLang, lang_paths, 'Select Language', lang_display);
// 2. Create Version Switcher
const versionSelect = createSelect(versions, currentVersion, version_paths, 'Select Version');
// 3. Create FTXUI title.
const ftxuiTitle = document.createElement('span');
ftxuiTitle.textContent = 'FTXUI: ';
Object.assign(ftxuiTitle.style, {
color: 'white',
fontSize: '20px',
fontWeight: 'bold',
marginRight: '10px'
});
// 3. Create a container to hold both selectors
const container = document.createElement('div');
container.id = 'version-lang-switchers';
Object.assign(container.style, {
display: 'flex',
alignItems: 'center',
justifyContent: 'flex-end',
width: 'auto'
});
container.appendChild(ftxuiTitle);
container.appendChild(langSelect);
container.appendChild(versionSelect);
Object.assign(container.style, {
backgroundColor: 'rgba(0, 0, 0, 0.5)',
padding: '5px 10px',
borderRadius: '8px'
});
// Replace the Doxygen project number element with our container.
projectNumber.replaceWith(container);
// Clean up the original Doxygen project number text if it still exists nearby
const parent = container.parentElement;
if (parent) {
const textNode = Array.from(parent.childNodes).find(n => n.nodeType === 3 && n.textContent.trim() !== '');
if (textNode) {
textNode.remove();
}
}
});
</script>
</body>
</html>