Roll20 uses cookies to improve your experience on our site. Cookies enable you to enjoy certain features, social sharing functionality, and tailor message and display ads to your interests on our site and others. They also help us understand how our site is being used. By continuing to use our site, you consent to our use of cookies. Update your cookie preferences .
×
Create a free account

Door Knocker v1.211 - Windows

March 20 (3 years ago)

Edited March 22 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Well, the original thread for Door Knocker automatically closed before I finished testing out the Windows update. So, here's a brand spanking new thread for the brand spanking new version of Door Knocker which was just submitted to the API scripts repo is now live, complete with a new copy of the script's help documentation.

Big thanks to Aaron and Andreas for their discoveries that allowed this update, and to Aaron for the window code!

Changes of note from the last live version of Door Knocker:

  • Windows!
  • The search behavior has been changed so that it shows the door lines on the map instead of using auras.
  • Custom ranging: You can now specify a range to manipulate or search for doors in

Door Knocker v1.211


Welcome to Door Knocker. This script helps quickly open and close doors by controlling the dynamic lighting lines. If you have any questions, comments, or find a bug; please drop by the Door Knocker forum thread.

Using Door Knocker

The script will move dynamic lighting lines used as doors to the map layer and make them transparent, opening the door. It determines what is a door and a wall based on the stroke color of the polygon and will only open doors within 1 square (default 70px) of the door knocker token.

Basic Command Syntax

The script uses a standardized API command syntax. All Door Knocker commands will begin with !knock. This will then be followed by a space a double dash preceding a keyword and options group. This looks like this:

!knock --keyWord|option1|option2|...

Opening and Closing Doors

Open and close using the key or push keyword followed by an option to tell the script whether to open doors, close doors, or toggle doors. You can also pass an optional second option to tell the script to open/close/toggle all doors within range of the knocker token, on the page, or in the campaign. These commands look like:

Affecting obvious doors

!knock --key/push|open/close/toggle|all/page/campaign/range

Affecting hidden doors

!knock --key|reveal/hide/togglehide|all/page/campaign/range

Affecting obvious and/or hidden doors

!knock --key|anydooropen/anydoorclose/anydoortoggle|all/page/campaign/range

Affecting Windows

!knock --key|openwindow/closewindow/togglewindow|all/page/campaign/range

Affecting any doors and/or windows

!knock --key|anyopen/anyclose/anytoggle|all/page/campaign/range

  • key/push: This is the keyword that tells the script to manipulate door dynamic lighting lines. The key keyword operates on both locked and unlocked doors and is GM only. The push keyword only operates on unlocked doors.
  • open/close/toggle This option tells the script to open, close, or toggle (open closed doors and close open doors) the closest door (or all doors if also using the all option described below).
  • reveal/hide/togglehide This option tells the script to open, close, or toggle the closest hidden door (or all doors if also using the all option described below).
  • anydooropen/anydoorclose/anydoortoggle This option tells the script to open, close, or toggle the closest obvious or hidden door (or all doors if also using the all option described below).
  • openwindow/closewindow/togglewindow This option tells the script to open, close, or toggle the closest window (or all windows if also using the all option described below).
  • anyopen/anyclose/anytoggle This option tells the script to open, close, or toggle the closest obvious door, hidden door, or window (or everything in range if also using the all option described below).
  • all/page/campaign: Optional argument This option tells the script to operate on all doors within range, all doors on a page, or all doors in the campaign. The page and campaign keywords are GM only and do not work with the push keyword. Range and the all/page/campaign keywords can be entered in any order relative to each other.
  • range: Optional argument This option tells the script to operate at a custom range, entered in the units of the map (e.g. ft, meters, kilometers). Range and the all/page/campaign keywords can be entered in any order relative to each other.

Setting up the Door Knocker

Set the wall, door, and locked door stroke colors in the settings menu using hex color codes (e.g. #000000). You can also set these values by selecting an already created DL line. This functionality is only accessible to the GM. The command syntax for using a selected DL line looks like:

!knock --preset|wall/door/unlocked/hidden/window|hex color

  • preset: This is the keyword that tells the script to change it's settings
  • wall/door/unlocked/window: This option tells the script to update the color setting for walls, doors, unlocked doors, and windows
  • hex color: Optional argument Passing a hex color here will set the script to consider all polygons on the Dynamic Lighting layer with a stroke of this color to be doors/walls. If this option is not passed the script will look for a selected polygon to pull a stroke color from.

Setting up your maps

The only map setup needed is to ensure your dynamic lighting doors are the appropriate color. This functionality is only accessible to the GM. If you are adapting a module or add-on to an already existing door color scheme you can select a door line and run the following chat command:

!knock --adapt|door/wall/unlocked/hidden/window|campaign

  • adapt: This is the keyword that tells the script to update all polygons on the dynamic lighting layer with the same stroke color as the selected polygon(s) to have the script's door/wall stroke color
  • wall/door/unlocked: This option tells the script to update the stroke color to that of walls, doors, or unlocked doors
  • campaign: Optional argument adding this optional argument tells the script to update polygons on all pages, not just the current page.

Searching for Doors

When you search for doors using Door Knocker, it will copy door lines to a visible layer. If a gm initiates the search hidden doors are copied and all door lines are shown on the gm layer. If a player initates the search, hidden doors are not displayed and the door lines are shown on the objects layer. How long door lines are visible for (in seconds) can be set from the settings page.

!knock --search|range

  • search: This is the keyword that tells the script to display any nearby doors
  • range: Optional argument Enter the search range, in the units of the map (e.g. feet, meters, kilometers). If you do not provide a range, it will default to the distance of a square on the map.

Note that searching does not currently reveal windows due to how the window paths are encoded. This functionality is being worked on.

Customizing the Script

Door knocker token

The script uses a generic key token as the door knocker token. You can customize this by changing the default token of this character. You also can run the script's commands from any selected token.

Script created abilities

The script also creates six abilities on this character as token actions. These can be disabled as token actions, but should not be deleted as the script will simply remake them. You can also add whatever other macros you want to this character.

Attributions

The default token image is from https://game-icons.net/ under the creative commons license. Thanks to Keith Curtis for finding this awesome token.

Great update, Scott! I assume the window functionality is UDL only, right?

March 21 (3 years ago)

Edited March 21 (3 years ago)
Andreas J.
Forum Champion
Sheet Author
Translator

Jay R. said:

I assume the window functionality is UDL only, right?

Yes, it's UDL only.


Wooh, finally windows! I updated the links on the wiki to this thread.

  • Will there eventually be an options for locked/unlocked "windows"? Could be useful for things like doors made of prison bars, or windows that have actual locks.
  • Ability to open/closes curtains for a window could be the next step. Guess either make "curtain window" a separate thing is better than having a command that convert a window to a door, as it would lose the info of it actually being a window.
    • A command Converting a window to a door or back could also have some niche use.


March 21 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Something I'm looking into is commands to convert items between all the states (e.g. hidden door to locked door unlocked door).

March 26 (3 years ago)

Edited March 26 (3 years ago)
Styx
Pro


Hi Scott,

I've been using this script for a few months and love it - thank you - but logged in today to see the above error.

Not sure if I'm the only one who has experienced this since the update though

EDIT: image didn't post correctly

March 26 (3 years ago)
Styx
Pro

I should probably also point out that I'm also using One-Way Dynamic Lighting in case that is no longer compatible

March 27 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Hmm, interesting. Thanks Styx. It looks like the function to update DoorKnocker to a previous version has some issues. It'll take a bit for the code update to hit live, but if you want you can update the code your self by deleting DoorKnocker, then readding it via the "import script" option. Then delete line 159 of the script:

getObj('graphic',id).remove();

and copy this in to that line instead:

let obj = getObj('graphic',id);
            if(obj){
                obj..remove();
            }
March 27 (3 years ago)

I have the same problem with slightly different message.  You can see the macro call in the chat box beneath. 

message is "Cannot read property 'get' of undefined

TypeError: Cannot read property 'get' of undefined
at getSegmentedPaths (apiscript.js:406:40)


 

I have never gotten the script to work, so there may be additional problems.  I am using a test game for pre-testing scripts and macros, very basic. I have set up all the colors, but no lines are moved, no doors opened, closed, or toggled. No auras appear on the token regardless of vicinity of doors.  Others give great reviews of how useful it is, so I would love to get it going in my games. Any help appreciated.

March 27 (3 years ago)

I’m pretty sure you need to install the dependency scripts. That looks like the same error messages I got the first time I loaded the script. 

March 27 (3 years ago)

I am having the same issue as Styx

March 27 (3 years ago)


Dean S. said:

I am having the same issue as Styx

Have you loaded the dependency scripts? From the main thread:

The script has two dependencies: Path Math and Vector Math by Stephen L. Both of them are available from the one-click drop library.

March 28 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Thanks for the attempts to help Jarren, however the errors being reported do not have to do with the dependencies, these are installed automatically when installed via the one-click. The errors are due to some areas where I did not put proper protections against unfound objects in the script.

March 28 (3 years ago)


Scott C. said:

Thanks for the attempts to help Jarren, however the errors being reported do not have to do with the dependencies, these are installed automatically when installed via the one-click. The errors are due to some areas where I did not put proper protections against unfound objects in the script.

Ah good to know that the dependencies are automatically loaded.  I pretty much always import scripts from the one-click instead of simply using the 'Add Script' button, as there's typically minor things I like to tweak (e.g. the startup log reports, and making sure that GM only whispers from the script have a 'name' and are set to 'no archive', and occasionally other small things).  So the first time I imported Door Knocker, I got an error message, because importing does not automatically load the dependencies.  Once I use the one-click and added the dependencies, it worked just fine. 

So it's still potentially an issue... if someone is as stubborn as me to get things looking just they way they like by tweaking other scripts. :)

April 04 (3 years ago)

Apologies for missing this thread (Door Knocker links you to a dead one).

I'm getting this error. Any ideas what might be going on?

Cannot read property 'r' of null
TypeError: Cannot read property 'r' of null
at setContrast (apiscript.js:266:31)
April 04 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Hmm, interesting Craig. What colors do you have set for your various walls?

April 04 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Also, an unfortunate update:
The windows functionality is currently non functional because of the latest UDL update. I'll update as I have new information.

April 04 (3 years ago)

Well, I selected the standard orange lines as the door colors, and the blue lines as the walls (as they come with the Mad Mage module). And I adapted them for the campaign.

However, that error message came up even before I was able to do that. I installed the API, started up my game... and that error message came popping out in chat.

I tried deleting and reinstalling, but the same error occurs.

April 04 (3 years ago)

Also of note... the Bio/Info tab on the Door Knocker sheet doesn't show me options. It's just blank (not in a pop-out)


April 06 (3 years ago)

Scott C. said:

Also, an unfortunate update:
The windows functionality is currently non functional because of the latest UDL update. I'll update as I have new information.

The windows function of Door Knocker is half-working. I draw a line in the DL layer in the color I chose for windows, and it admits light like a window even though it would ordinarily block light without the script, but it no longer blocks movement.


Craig M. said:

I'm getting this error. Any ideas what might be going on?

Cannot read property 'r' of null
TypeError: Cannot read property 'r' of null
at setContrast (apiscript.js:266:31)

I set up macros to be used from the macro bar when a token is selected. I get similar errors, "cannot read property of ..." every time I try to use the macro as an action of the token that was generated by the script. If I select that token, and activate the macro, I get an error.  When any other token is selected, it works, BUT I have to click the button three times. If I enter the command directly in chat, I have to enter it three times.  I have seen no other macro/script pair with that peculiarity.

macros are just:

!knock --search
!knock --key|open
etc.

April 06 (3 years ago)

Valerie... that is exactly what's happening on my end as well, including the triple-clicking.

This script's windows functionality is working perfectly in my game, as of yesterday. Ellipses block light now with the update, but whatever magic your script does seems to get around that :)

I use the following color codes currently. 

Red=Walls

Green=Unlocked Doors

Yellow=Locked Doors

Is there a way to have the colors change so a thief who uses pick locks on a yellow locked door can open it without GM involvement?

Is there a way for search doors to not be automatically successful?

April 07 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Handling skill checks is currently beyond the scope of the script. It's something I'm looking at, but I don't have any immediate plans for it.

For the searching, make doors you don't want to be automatically visible as hidden doors. The search won't show hidden doors.

April 08 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

First of all, some good news: The UDL implementation appears to have been updated to allow windows to work!

And, then secondly; Thanks for the error reports Valerie and Craig. Can you see if changing to this DoorKnocker code fixes your error issue?

April 08 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Also, Valerie, you appear to be having bigger issues. Could you DM me an invite to your game so I can look into what exactly is going on there.

April 09 (3 years ago)

Did the one-click script get updated?  I didn't load the new one, but the windows are now working and the triple-click problem has disappeared.  All that's left is some mysterious errors that only happen when using the door knocker token.

April 09 (3 years ago)

Edited April 09 (3 years ago)

Scott, thanks! I've installed... so far so good... no errors back, and the UI character sheet is correctly populated... kicking the tires now....


ETA: Works like a charm! I'm basically just using the toggling function as a token macro, so I can't speak for every aspect of functionality (or the error Valerie mentioned), but the functionality I wanted is there, and there are no more errors getting kicked back. Bravo!

April 09 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Craig,

Great to hear!


Valerie,

The one-click code has not update as I wanted to see if the code fixed your's and Craig's errors. The windows functionality was fixed by Roll20 changing how the UDL processed DL lines. The triple click issue was probably caused by some lag on the API server end.

Can you install the beta code linked just above and see if it fixes the errors that are being thrown for you?

April 10 (3 years ago)

Question,

Setting up the Door Knocker

Set the wall, door, and locked door stroke colors in the settings menu using hex color codes (e.g. #000000). You can also set these values by selecting an already created DL line. This functionality is only accessible to the GM. The command syntax for using a selected DL line looks like:

The previous statement seems to suggest that one can setup the Door Knocker in the settings menu, but where can one find the settings menu, I would love to set everything one time for the entire campaign, rather than going through and adapting every page. Can anyone help a newbie in understanding what I'm doing wrong with this script?


April 10 (3 years ago)

Door Knocker will create a character called 'DoorKnocker UI' (it has a token that looks like a key with a red & black background). Find that character and open up the character sheet. On the Bio & Info page, you'll see two tabs in the middle named 'Instructions' and 'Settings'.  Click on 'Settings' to see the current colors of walls and doors.



April 10 (3 years ago)

Edited April 10 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Welcome to DoorKnocker ez2rpg,

Jarren got the right of it. In addition, you can quickly change the colors of DL lines across your entire campaign with the adapt keyword described in "setting up your maps".

April 11 (3 years ago)

Thanks Jarren K. and Scott C. sometimes the obvious is so obvious I miss it.


April 11 (3 years ago)

Since the last update my players and even the Doorknocker must be nearly inside the door to work peoperly. Is there a way to change the distance for activation?

April 11 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Hi Rholan. Yes. The range defaults to 1 square (or 70 pixels if there is no grid). But you can specify a range for searching and door manipulation. See the range keyword in the help doc.


Scott C. said:

Hmm, interesting. Thanks Styx. It looks like the function to update DoorKnocker to a previous version has some issues. It'll take a bit for the code update to hit live, but if you want you can update the code your self by deleting DoorKnocker, then readding it via the "import script" option. Then delete line 159 of the script:

getObj('graphic',id).remove();

and copy this in to that line instead:

let obj = getObj('graphic',id);
            if(obj){
                obj..remove();
            }


I'm having the same issue, but don't know where to get the actual script to "import script" to make the changes. Any help would be wonderful! c:

Also, THANK YOU for this awesome script. It's a game changer. ♥

April 11 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Hi Sassy,

I'll be sending the updated code to the repo today and it should go live on Tuesday/Wednesday.

If you need the fix quicker than that you'll need to disable your current version of Door Knocker. And then, since that post you quoted, there is now a gist of the updated code that you can just copy in as a new custom script on your API scripts page (see this post for details)

I like the new search function, but in UDL the visible doors can be hard to see without making the lines super thin. Is there a way to make the visible lines thicker, or perhaps a transparent token could be created with a visible aura to show the location of the door?

April 12 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

It's something I'll look into Persephone. The lines revealed by search should be extremely thick as is.

April 12 (3 years ago)

Edited April 12 (3 years ago)

Door Knocker v1.211 error when clicking the Settings option on the Door Knocker character sheet.



April 12 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Hmm. Interesting. Thanks Keith. I'll take a look and see if I can replicate.

April 12 (3 years ago)

Edited April 12 (3 years ago)

Also receive the following error when trying to set the window option.


April 12 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Thanks for the report Mike.

For your first error, are you using the one-click or did you copy the code in from the repository?

I ask because I can't replicate the issue.

For your second, what command are you sending when you trigger that?

Hey Scott, That was copied from the repository, the second error is when i open the door knocker character sheet and click on the settings option to see the color hexcode.

Getting this error when I try using !knock --search with the DoorKnocker token selected:


April 13 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

Hmm. Interesting.

Can you post a screen cap of what the DL lines look like around the token?

Here's one area, but it happens no matter where on the map the Knocker token is. The command works fine with any other token in any area, so it's not an issue for me, just thought the info may be useful for you in case you wanna sort the bug out.


I did notice one unrelated small issue with the above door specifically, it can only be opened/closed from the left side, not the right. I tried changing it to a straight line in case the branching shape was causing issues, but that made no difference. I have several other doors like the one above and the one below, but only the one above has this issue. All others can be opened from either side.

April 14 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

mike k. said:

Hey Scott, That was copied from the repository, the second error is when i open the door knocker character sheet and click on the settings option to see the color hexcode.

Thanks Mike,

Could you try adding the script from the one-click and see if the problem persists? I think that you may be missing some lines of code.

April 16 (3 years ago)

Hi guys, I have asked this question before and got the answer to look in the description but I'm obviously too dumb to do it right. I've asked how to change the range for open/close/toogle doors. >Since I updated the API my players have to stand nearly inside the door to use the open command. Can someone please put an example command line here how to set the range?

TIA

April 16 (3 years ago)

Edited April 16 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

No worries Rholan,


There's a lot in the help doc. The relevant section for you is this:

Searching for Doors

When you search for doors using Door Knocker, it will copy door lines to a visible layer. If a gm initiates the search hidden doors are copied and all door lines are shown on the gm layer. If a player initates the search, hidden doors are not displayed and the door lines are shown on the objects layer. How long door lines are visible for (in seconds) can be set from the settings page.

!knock --search|range

  • search: This is the keyword that tells the script to display any nearby doors
  • range: Optional argument Enter the search range, in the units of the map (e.g. feet, meters, kilometers). If you do not provide a range, it will default to the distance of a square on the map.

Note that searching does not currently reveal windows due to how the window paths are encoded. This functionality is being worked on.

So, to search within 10 ft (or whatever units your map uses) of a token the command would be:

!knock --search|10
April 16 (3 years ago)

Edited April 16 (3 years ago)

@Scott, not sure if you saw my last post, but last night I noticed a lot more doors that can only be opened from one side. These are doors that I'd set up and interacted with before the last big update you made, and was not having this issue with them before. Any ideas why this might be happening? I've even tried deleting the door paths and redrawing them.

Here's a couple more screenshots for some visual context:

This door can only be opened/closed from the northeast side.

This door can only be opened/closed from the south side.
April 16 (3 years ago)
Scott C.
Forum Champion
Sheet Author
API Scripter
Compendium Curator

It's something I'm trying to figure out.

And actually, would you be willing to let me hop in and dig around a little?