[简体中文](./CONTRIBUTING.md) | 繁體中文 | [English](./CONTRIBUTING_en.md) ## 參與開發 歡迎參與虛擬桌寵模擬器的開發!為了保證程式碼的可維護性及遊戲性,若想要開發新的功能,請先[電子郵件聯絡](mailto:zoujin.dev@exlb.org)或提交[Issue](https://github.com/LorisYounger/VPet/issues),標題為想要新增的功能/玩法,以確保該功能/玩法適用於虛擬桌寵模擬器,以免在您完成開發後,因不適合而被拒絕(而浪費您的時間)。<br/> 如果是修正錯誤或BUG,則不需要先行聯絡,修好後直接提交即可。 當您提供的想法被贊同後,您可以使用[Fork](https://github.com/LorisYounger/VPet/fork)功能,將專案程式碼整個複製至個人的Github上,以便撰寫自己的程式碼。撰寫完畢後,使用[Pull Requests](https://github.com/LorisYounger/VPet/compare)提交。<br/> 若您的想法並未被同意,也可以另起爐灶,開發一個不同版本及功能的桌寵軟體。須遵守[Apache License 2.0](https://github.com/LorisYounger/VPet/blob/main/LICENSE)及[動畫版權聲明與授權](https://github.com/LorisYounger/VPet/blob/main/README_zht.md#%E5%8B%95%E7%95%AB%E7%89%88%E6%AC%8A%E8%81%B2%E6%98%8E%E8%88%87%E6%8E%88%E6%AC%8A)。<br/> 註:一般而言,加入新功能都可以透過撰寫模組來達成,詳情請見:[VPet.Plugin.Demo](https://github.com/LorisYounger/VPet.Plugin.Demo) 作者可能會修改、刪減部分您所提交的程式碼,以確保該功能/玩法適用於虛擬桌寵模擬器。 ## 動畫版權聲明與授權 在Github中,[桌寵動畫檔案](https://github.com/LorisYounger/VPet/tree/main/VPet-Simulator.Windows/mod/0000_core/pet/vup)之動畫版權歸[虛擬主播模擬器製作組](https://www.exlb.net/VUP-Simulator)所有,在使用本類別庫時,您可能會需要自行準備動畫檔,或遵循下列協定: ### 非商業用途授權 * 需要向使用者告知動畫檔案的來源,並提供造訪[本頁面](https://github.com/LorisYounger/VPet)的連結 * 當您完成上述要求後,可以免費使用動畫檔案 ### 商業用途授權(低於10萬) * 在使用者第一次使用時,需跳出視窗,並醒目向使用者告知動畫檔案的來源,並提供造訪[本頁面](https://github.com/LorisYounger/VPet)的連結 * 在對應的頁面上(使用者能快速造訪的),向使用者告知動畫檔案的來源,並提供造訪[本頁面](https://github.com/LorisYounger/VPet)的連結 * 當您完成上述要求後,可以免費使用動畫檔案 ### 商業用途授權(高於10萬或其他) * 請[電子郵件聯絡](mailto:zoujin.dev@exlb.org)本軟體作者 ### 轉發動畫檔案 * 需要告知上述所有授權資訊 * 需要提供造訪[本頁面](https://github.com/LorisYounger/VPet)的連結 * 轉發動畫檔案時,禁止任何付費或收費行為 ## 桌面應用程式部署方式 1. 下載本專案,透過VisualStudio開啟`VPet.sln`檔案 2. 在「建置」選項中,選擇位元數`x64`及建置專案`Vpet-Simulator.Windows` ![image-20230208004330895](README.assets/image-20230208004330895.png) 3. 點擊「開始」,若一切順利將會報錯`缺少Core模組,無法啟動桌寵` 4. 以管理員身分執行`mklink.bat`,這會讓模組檔案連結至產生的位置 5. 再次點擊啟動即可正常執行 ## 軟體架構 * **VPet-Simulator.Windows: 適用於桌面端的虛擬桌寵模擬器** * *Function 功能性程式碼儲存位置* * CoreMOD 模組管理 * MWController 視窗控制器 * *WinDesign 視窗及UI設計 * winBetterBuy 更好買視窗 * winCGPTSetting ChatGPT設定 * winSetting 軟體設定、模組視窗 * winConsole 開發控制台 * winGameSetting 遊戲設定 * winReport 意見回饋中心 * MainWindows 主視窗、儲存及展示Core * PetHelper 快速切換圖示 * **VPet-Simulator.Tool: 方便製作模組的工具(例如:產生動態圖片)** * **VPet-Simulator.Core: 軟體核心,方便內建至任何的WPF應用程式(例如:VUP-Simulator)** * Handle 介面及控制項 * IController 視窗控制(呼叫相關功能及設定,例如:移動到側邊等) * Function 通用功能 * GameCore 遊戲核心,包含各種資料數據等內容 * GameSave 遊戲存檔 * IFood 食物及物品介面 * PetLoader 寵物圖片載入器 * Graph 圖形渲染 * IGraph 動畫基本介面 * GraphCore 動畫顯示核心 * GraphHelper 動畫幫助 * GraphInfo 動畫資訊 * FoodAnimation 食物動畫,支援顯示前中後三層夾心動畫,不一定只用於食物,只是叫這個名字 * PNGAnimation 桌寵動態動畫元件 * Picture 桌寵靜態動畫元件 * Display 顯示 * basestyle/Theme 基礎風格主題 * Main.xaml 核心顯示元件 * MainDisplay 核心顯示方法 * MainLogic 核心顯示邏輯 * ToolBar 點擊人物時的工具欄 * MessageBar 人物說話時的對話框 * WorkTimer 運作計時器