- Small bug fix with getAllMasks not cleaning erased maks/tags
- Remove sorting of regions by area. So that user can navigate regions in the order of they were created
- Addition of semantic segmentation or brush/eraser control to annotate an image at pixel level.
CT Library Changes
- CanvasTools.Editor api is updated to include
enableMask
.
var editor = new CanvasTools.Editor(
container: HTMLDivElement,
areaSelector?: AreaSelector,
regionsManager?: RegionsManager,
filterPipeline?: FilterPipeline,
enableMask?: boolean).api
- When
enableMask = true
, themasksManager
is initialized that helps in annotating an image at pixel level. - 2 callbacks -
onMaskDrawingBegin
&onMaskDrawingEnd
are exposed on CanvasTools.Editor api. These needs to be defined.
// Callback for `MasksManager` called when the drawing mask begins. Returns a tagDescriptor
onMaskDrawingBegin: () => TagsDescriptor;
// Callback for `MasksManager` called when the mask is drawn.
onMaskDrawingEnd: () => void;
addContentSource
takes in a new callbackonContentLoadCb
. Callback is executed after the image onLoad is fired.
addContentSource(source: HTMLCanvasElement | HTMLImageElement | HTMLVideoElement, onContentLoadCb?: () => void): Promise<void>;
CT Tags Changes
Tag
now accpets a new parametersequenceNumber
while initialization. This parameter is required for the purpose of semantic segmentation. ThesequenceNumber
can be number starting at 1 which indicates the order number of a tag w.r.t to its color. Each color/tag would havbe an uniquesequenceNumber
.
new Tag(name: string, color: number|string|Color, id: string, sequenceNumber: number)
CT Selector Changes
- 2 more
SelectionMode
namedBrush
&Eraser
are added.
CT MaskManager Changes
setSelection
function is used the set the selection mode to brush or eraser and also disable mask mode.
setSelection(enabled: boolean, mode?: MaskSelectorMode): void;
setBrushSize
function sets the brush and eraser size
setBrushSize(size: IBrushSize): void;
eraseAllMasks
function removes all masks and resets mask layer
eraseAllMasks(): void;
getAllMasks
function gets the mask layer for the entire image. If image is ofw
width andh
height, it has wh pixels. Mask(imageData) is anumber[]
of sizewh
where each entry or pixel is denoted by thesequenceNumber
of the corresponding tag color on it.tags
represents all the tags present in the mask
getAllMasks(): => IMask;
export interface IMask {
imageData: number[];
tags: TagsDescriptor[];
}
loadAllMasks
function loads the mask layer on the image
loadAllMasks(allMasks: IMask): void;
polygonsToMask
function converts any polygon drawn to a mask
polygonsToMask(): void;
Samples
The samples folder has new example to showcase semantic segmentation. Eg. samples/editor-with-mask/index.html
- Users of
RegionManager.updateRegionVisibility()
can now supply callbacks that can accept a region object in addition to tagsDescriptor for theshouldHideThisRegion
parameter. - NOTE: The
tagsDescriptor
parameter will be removed in upcoming release and users are recommended to useregion.tag
in the callback body instead.
- Expose getters to frameWidth and frameHeight on
Editor
- Added a new ZoomType
CursorCenter
which allows users to set the zoom around cursor position.
- Add an
enablePathRegions
editor configuration to enable/disable path region types (Bezier curve support).
const editor = new CanvasTools.Editor(...);
editor.enablePathRegions(true);
- Add a new "PathRegion" type which will be created in place of polygon region types when
enablePathRegions
is enabled. - Replace bounding box calculation in region metadata with Snap.SVG path getBBox utility to accommodate BBox of complex paths.
- Add Bezier control information to region metadata.
- Add midpoint line markers, when clicked will assign bezier control data to that line.
- Add Bezier control anchors to lines with bezier control data to allow manipulation of line shape.
- Deprecate "setPoints" region data method in favor of "splicePoints". Use of setPoints is not compatible with "PathRegion" region types.
- Add
.toggleTagsTextVisibility()
toRegionManager
for toggling visibility of tags text on region.
CT Library Changes
- CanvasTools.Editor api is updated to include
zoomProperties
var editor = new CanvasTools.Editor(container: HTMLDivElement, areaSelector?: AreaSelector, regionsManager?: RegionsManager,
filterPipeline?: FilterPipeline) {
filterPipeline?: FilterPipeline, zoomProperties?: ZoomProperties).api
- ZoomType and isZoomEnabled can now be set on ZoomProperties.
- ZoomType allows users to set the zoom around a point like image center or view port center.
- Add
.reset()
null check for before if called before the editor is loaded or if no selector is present
- Add public
.reset()
toAreaSelector
- Improve render time significantly, by caching values expensive svg calculation call
- Remove unnecessary re-render calls on add new region and complete region
- Small bug fixed with ghost anchor
- Fix bugs with ghost anchor (add and remove points) for polygon
- Add new toolbar control for easier accessing ghost anchors
- Add
.updateRegionVisibility()
toRegionManager
for easier region visibility toggling - Fix a bug with add region accessibility announcing
- Fix a bug with
PolygonSelector
where calling.show
after deleting a box could cause an unwanted selection to start - Add
.undo()
and.redo()
methods onAreaSelector
(currently only works when the selector is aPolygonSelector
) - Add
.onNextSelectionPoint()
callback for when a new point is drawn by thePolygonSelector
- The functionality of tabbing has been heavily changed
key | previous functionality | current functionality |
---|---|---|
Tab | Moves selection forward through region list, looping back to the start when it reaches the last selection. Does not prevent HTML focus movement. | Moves selection forward through region list, unfocusing the editor if Tab is pressed while the last region is selected. Prevents HTML focus movement while the editor has focus |
Shift + Tab | No Shift + Tab functionality | Moves selection backward through region list, unfocusing the editor if Shift + Tab is pressed while the first region is selected. Prevents HTML focus movement while the editor has focus. |
- Removes a bug introduced in 2.2.10 in which the tag announced is displayed in an element under the editor.
- The "Template-based box" selector can now be used with keyboard controls. Similar to the Rect selector keyboard controls, these controls are enabled by pressing
K
when the Template-based box selector is active. - Functions related to enabling and disabling keyboard controls are now made public to allow external scripts to incorporate those functions into their own logic.
- The UI elements corresponding to the Template-based box selector have also been updated to use an
AlternatingCrossElement
for higher visibility. - The announcer that reads the TagsDescriptor after a region is added now reads from the TagsDescriptors
toString()
method instead of only its primary tag.
- The
Toolbar
can now be navigated with standard HTML5 controls.- All
ToolbarIcon
s can now be tabbed through. - A focused
ToolbarIcon
can be activated with the Enter or space key.
- All
- Upon
Region
creation, screen reader technologies will now announce the primary tag of that region.
- The colors used for the styles of
RegionMenu.ts
andToolbar.ts
previously contained hues of gray with different shades and opacities. They have been changed to three colors,#fff
,#000
, and#157ff0
, which all possess luminosity ratios above 3:1 against the other two. This is to ensure visibility for people with vision disabilities. These changes are noted in the table below:
class | property | previous color | current color |
---|---|---|---|
.menuRectStyle | fill | rgba(64, 64, 64, 0.8) | #000 |
.menuItemBack | fill | rgb(32, 32, 32) | #000 |
.menuIcon | fill | rgb(64, 64, 64) | #fff |
.menuItem | stroke | rgba(198, 198, 198, 0.2) | #fff |
.menuItem:hover | stroke | rgba(198, 198, 198, 0.8) | #157ff0 |
.toolbarBGStyle | fill | #666 | #000 |
.iconStyle.selector:hover .iconBGRectStyle | fill | rgba(68, 68, 68, 0.5) | #157ff0 |
.iconStyle.selector.selected .iconBGRectStyle | fill | #333 | #157ff0 |
.iconStyle.switch:hover .iconBGRectStyle | fill | rgba(68, 68, 68, 0.5) | #157ff0 |
.iconStyle.switch .iconImageStyle | stroke | #333 | #fff |
_.iconStyle.separator line | stroke | #333 | #fff |
- The
CrossElement
nodes ofRectSelector.ts
have been replaced withAlternateCrossElement
nodes, which are derived fromCrossElement
. WhileCrossElement
is composed of lines with a dotted grey pattern,AlternateCrossElement
is composed of lines with an alternating black-and-white pattern. This ensures that the cross is visible on background images of all colors. - Keyboard controls have been changed in the following ways:
- In order to start using keyboard controls for the
RectSelector
, the user will now press theK
key instead of the space bar. This is to avoid collision with existing HTML5 functionalities that use the space bar. - While users previously used the
UHJK
keys to move the selection cross, the functionality has moved to holding the shift key in conjunction with the arrow keys. This reduces the number of keys with enhanced functionality.
- In order to start using keyboard controls for the
Keyboard controls are now available when using the RectSelector.
Bug fixes related to zoom feature
CT Library Changes
resetZoomOnContentLoad
is introduced onZoomManager
so that the zoom behavior can be reset before new content load.
Unit Tests
- Jest and ts-jest is setup now in this repo.
- Added Unit tests for
ZoomManager
file.
CT Library Changes
- Zoom feature is introduced to zoom in/out the image for region selection & manipulation.
- The feature is specifically introduced only for Rect related region selection and can be optionally initialized.
- Max zoom is set to 400% and min zoom at 100%. The scale to increase or decrease zoom is 50%.
- CanvasTools.Editor api is updated to include
isZoomEnabled
var editor = new CanvasTools.Editor(container: HTMLDivElement, areaSelector?: AreaSelector, regionsManager?: RegionsManager, filterPipeline?: FilterPipeline) { filterPipeline?: FilterPipeline, isZoomEnabled?: boolean).api
onZoomEnd
is introduced onEditor.api
as a callback which is called after zoom is updated.editor.onZoomEnd = (zoom: ZoomData) => { // callback function implementation }
setMaxZoomScale
andsetZoomScale
are added to ZoomManager. Also available inEditor
throughZM
.
CT Toolbar
- Zoom in and Zoom out buttons are added to Rect only toolbar set.
Samples
- The samples folder has new example to showcase zoom feature.
- Eg.
samples/editor-with-zoom/index.html
folder
CT Library Changes
- Update
registerRegion()
inRegionsManager
to unselect the region after it is registered. - Unselect all regions after updating tags in
updateTagsForSelectedRegions
inRegionsManager
.
Update repo links and add new interface method getAllRegions
in RegionsManager
. Also available in Editor
through RM
or api
.
New versioning approach 2.2.0 and further updates will consider releasing new features/fixes under beta-version packages till stabilization.
CT Library Changes
- Fixed major compatibility issues with Edge and Firefox.
- Fixed minor interaction bugs and visual glitches.
- Changed model for emitting (internal)
onManipulation*
events. Reduced number of generated events and internal emitters. - Removed mask from rect-selection.
CT Library Changes
- Polyline default background fix
Fix to missing /Core folder in the package.
2.1.26 - Background toggling from the v2-toolbar-background-toggle branch
CT Library Changes
- Exposed the
toggleBackground
method forRegionsManager
as public. - Removed
KeyB
-event listener from theRegionsManager
. Use toolbar instead. - Updated styles for the light theme without background.
CT Toolbar
- Added background toggling button to the toolbar icon sets.
2.1.25 - Trigger button type for Toolbar from the v2-toolbar-clear-regions branch
CT Library Changes
- Added new
ToolbarTriggerIcon
type for Toolbar, allowing adding buttons that trigger some action but does not change state. - Added new "Delete all regions" button to default toolbar presets.
2.1.24 - API Update from the v2-rect-select-manipulate-update branch
CT Library Changes
- Added a new
getSelectedRegions
method to replace deprecatedgetSelectedRegionsBounds
inRegionsManager
. Also available inEditor
throughRM
orapi
. - Selection mode (
AreaSelector
):- Extracted new
ISelectorSettings
interface to use insetSelectionMode
(wraps previous selectionMode and options). - Added new signature for the
setSelectionMode
method to useISelectorSettings
object instead ofselectionMode
.
// new way: editor.AS.setSelectionMode({ mode: SelectionMode.NONE }); // old way (still available but not recommended): editor.AS.setSelectionMode(mode: SelectionMode.NONE); // new way with template editor.AS.setSelectionMode({ mode: SelectionMode.COPYRECT, template: new Rect(r.regionData.width, r.regionData.height), }); // note: the old way with setting a template for 'COPYRECT' mode as a second arg is not available any more
- Moved
SelectionMode
definition to theISelectorSettings
file. - Added new
getSelectorSettings
method for theAreaSelector
to get current settings.
- Extracted new
2.1.23 - Rect resizing update from the v2-rect-select-manipulate-update branch
CT Library Changes
- Fix for the issue #42 with rects overflowing canvas edge when created using the copy-rect tool.
- Added rect resizing by dragging edges (issue #30).
CT Library Changes
- Updated
Editor
properties to use named function types instead of hardcoded ones. regionData
param is now optional for all callbacks on theEditor
-- following theRegionUpdateFunction
type definition.
2.1.21 - New color infrastructure from the v3-color-lab branch
New color infrastructure
- Implementation of core color spaces: sRGB, RGB, HSL, XYZ and CIE LAB, including conversion between formats. Added new classes under
CanvasTools.Core.Colors.*
:SRGBColor
,RGBColor
,HSLColor
,XYZColor
andLABColor
. TheColor
class is a wrapper around various formats. - Implementation for the color difference algorithms in the CIE LAB color space.
- New
Palette
class to generate color swatches or expand color swatches in a specified lightness plane of the LAB color space. - New samples to use the color infrastructure:
palette-swatches
,palette-swatch-iterator
andpalette-editor
. - Updated readme and basic
editor-*
samples to use the new infrastructure.
CT Library Changes
- Added the
color
property toITag
andTag
. UsingcolorHue
is now deprecated. Consider using theColor
class or hex-string when creating new tags. - Updated styling of regions to use the new
Color
infrastructure. - Partially refactored the
canvastools.css
file to use variables to define cursors and colors. - Added
regionData
to theonRegionDeleted
callback. - Fixed a bug with the menu positioning when a region is deleted.
- Changed the shift-key to the ctrl-key for multiselection.
Fix to expose the multiselection
flag in the onRegionSelected
callback.
Changed compiler options for lib
to preserve comments.
Docs
- Added jsdocs for all classes and interfaces.
CT Library Changes
Editor
class now exposes the internalfilterPipeline
object asFP
instead ofFilterPipeline
to follow other shortcuts namings (likeRM
andAS
).- For
PointRegion
,PolygonRegion
,PolylineRegion
andRectRegion
classes aligned the constructor signature with theRegion
class. - Small refactorings for internal methods and classes naming.
Samples
- Moved the
/test
folder to a newsamples
folder to better reflect that those are usage samples, not tests. - Splitted original sample into 1)
/editor
and 2)/filters
. Extracted common media and js files into/shared
folder. - Extracted new sample without toolbar under the
/editor-no-toolbar
folder. - Updated
package.json
andwebpack.config.js
to reflect changes.
Added onRegionMoveBegin
and onRegionMoveEnd
callbacks to the Editor
and the RegionsManager
classes. Usage:
editor.onRegionMoveBegin = (id, regionData) => {
console.log(`Move Begin ${id}: {${regionData.x}, ${regionData.y}} x {${regionData.width}, ${regionData.height}}`);
};
editor.onRegionMove = (id, regionData) => {
console.log(`Moving ${id}: {${regionData.x}, ${regionData.y}} x {${regionData.width}, ${regionData.height}}`);
};
editor.onRegionMoveEnd = (id, regionData) => {
console.log(`Move End ${id}: {${regionData.x}, ${regionData.y}} x {${regionData.width}, ${regionData.height}}`);
};
Updated README
and sample under the /test
folder.
-
Added a new
api
proxy to theEditor
class. It wraps accessing to all the public methods ofEditor
,RegionsManager
,AreaSelector
andFilterPipeline
. So instead of writingeditor.RM.addRegion(...)
, you can use the following approach:var editor = new ct.Editor(editorDiv).api; editor.addRegion(...) editor.setSelectionMode(...)
-
Removed from the
Editor
class itself thesetSelectionMode
method. Use instead the approach above oreditor.AS.setSelectionMode(...)
. -
Added new overloads for the
Editor
classconstructor
. You can now also provide custom components (AreaSelector
,RegionsManager
orFilterPipeline
). E.g., to createEditor
with customRegionsManager
:let editor = new ct.Editor(sz, null, regionsManager);
Note: editor will override the
callbacks
properties forAreaSelector
andRegionsManager
to ensure they crossreference and can work together.