blockly > Workspace

Workspace 課程

工作區的類別。這是包含區塊的資料結構。沒有 UI,可無頭建立。

Signature:

export declare class Workspace 

建構函式

建構函式 修飾符 說明
(建構函式)(opt_options) 建構 Workspace 類別的新例項

屬性

屬性 修飾符 類型 說明
connectionChecker IConnectionChecker
connectionDBList ConnectionDB[] 這組資料庫可快速查詢連線位置。
horizontalLayout 布林值
id 字串
isFlyout readonly 布林值 這個工作區是否為飛出視窗的介面?
isMutator readonly 布林值 這個工作區是否為變異器介面?
MAX_UNDO 數字 堆疊中的復原事件數量上限。0 會關閉復原功能,Infinity 則會將復原次數設為無限制。
選項 選項
redoStack_ protected Abstract[]
rendered 布林值 如果工作區可見,則傳回 true;如果工作區無周邊,則傳回 false
RTL 布林值
SCAN_ANGLE static 數字 將角度從水平方向移開,掃描是否有方塊。執行順序通常是由上而下,但只要稍微調整角度,掃描就會略微偏向由左至右 (如果是 RTL 語言,則會反向)。單位為度數。請參閱:https://tvtropes.org/pmwiki/pmwiki.php/Main/DiagonalBilling
toolboxPosition toolbox.Position
undoStack_ protected Abstract[]

方法

方法 修飾符 說明
addChangeListener(func) 當這個工作區中的內容有所變更時,請呼叫函式。請注意,堆疊中可能已有幾個近期事件。因此,系統可能會使用變更監聽器新增前幾毫秒發生的事件,呼叫新的變更監聽器。
addTopBlock(block) 將區塊新增至頂端區塊清單。
addTypedBlock(block) 將區塊新增至以型別為鍵的區塊清單。
allInputsFilled(opt_shadowBlocksAreFilled) 檢查工作區中的所有值和陳述式輸入是否都已填入積木。
clear() 捨棄工作區中的所有方塊和註解。
clearUndo() 清除復原/重做堆疊。
createVariable(name, opt_type, opt_id) 建立具有指定名稱、選用型別和選用 ID 的變數。
deleteVariableById(id) 透過傳入的 ID 刪除變數,並從這個工作區中刪除所有變數用法。可能會提示使用者確認。
dispose() 處置這個工作區。從所有 DOM 元素取消連結,避免記憶體流失。
fireChangeListener(event) 觸發變更事件。
getAll() static 找出所有工作區。
getAllBlocks(ordered) 找出工作區中的所有方塊。區塊可依位置排序,由上到下 (略微偏向 LTR 或 RTL)。
getAllVariableNames() 傳回所有類型的所有變數名稱。
getAllVariables() 傳回所有型別的所有變數。
getBlockById(id) 找出這個工作區中具有指定 ID 的區塊。
getBlocksByType(type, ordered) 找出具有相關聯型別的區塊並傳回。區塊可依位置排序,由上到下 (略微偏向 LTR 或 RTL)。
getById(id) static 找出具有指定 ID 的工作區。
getCommentById(id) 找出這個工作區中具有指定 ID 的留言。
getPotentialVariableMap() 傳回包含「潛在」變數的變數對應。這些項目會顯示在飛出式視窗中,但不會顯示在工作區中。
getProcedureMap() 傳回工作區中所有程序的對應。
getRootWorkspace()

如果工作區有父項,則傳回這個工作區的根工作區。

舉例來說,彈出式視窗和迷你工作區泡泡中的工作區都有父項工作區。

getTopBlocks(ordered) 找出並傳回頂層區塊。區塊可依位置排序,由上到下 (略微偏向 LTR 或 RTL)。
getVariable(name, opt_type) 依指定名稱尋找變數並傳回。如果找不到,則傳回空值。
getVariableById(id) 依據指定 ID 找出變數並傳回。如果找不到,則傳回空值。
getVariableMap() 傳回工作區中所有變數的地圖。
getVariableMapClass() protected
getVariablesOfType(type) 找出指定類型的變數。如果型別為空值,則傳回型別為空字串的變數清單。
getVariableUsesById(id) 找出指定變數的所有用途 (以 ID 識別)。
getWidth() 傳回工作區的水平偏移量。適用於 XML 中的 LTR/RTL 相容性。不適用於無頭工作區。
hasBlockLimits() 檢查工作區是否對方塊數量上限或特定類型方塊數量上限設有限制。
isCapacityAvailable(typeCountsMap) 檢查是否還有剩餘容量,可建立指定計數的區塊。如果地圖代表的區塊總數超過剩餘總容量,則會傳回 false。如果某個型別的計數超過該型別的剩餘容量,則會傳回 false。
isReadOnly() 傳回這個工作區是否處於唯讀模式。
newBlock(prototypeName, opt_id) 取得新建立的區塊。
newComment(id) 取得新建立的留言。
remainingCapacity() 可新增至工作區的方塊數量,達到 maxBlocks 前。
remainingCapacityOfType(type) 可新增至工作區的指定類型方塊數量,達到該類型允許的 maxInstances 之前。
removeChangeListener(func) 停止監聽這個工作區的變更。
removeTopBlock(block) 從熱門積木清單中移除積木。
removeTypedBlock(block) 從依類型鍵入的區塊清單中移除區塊。
renameVariableById(id, newName) 如要重新命名變數,請在變數對應表中更新變數名稱。使用指定 ID 找出要重新命名的變數。
setIsReadOnly(readOnly) 設定這個工作區是否處於唯讀模式。
sortByOrigin(a, b) protected 依據工作區中受限元素的位置排序,由上到下 (略微偏向 LTR 或 RTL)。
復原(重做) 復原或重做上一個動作。