Community widgets
Re: Community widgets
[#55] Community LCB widget "hhControls" v1.0.2
(Tested to work on newer MacOS/ Win 7+10/ Ubuntu 1604)
This is for LC 8 (version > 8.1.4). LC 9 is currently (as of 9.0.0-dp11) not supported, sorry.
hhControls is a widget that lets you create a widget that contains controls:
One or several of
++ push buttons,
++ check boxes,
++ (groupable) radio buttons,
++ info text,
++ number steppers,
++ text steppers,
++ popup menus,
++ (horizontal) sliders,
++ color swatches (needs widget hhColorpicker)
The controls are automatically placed, you only select whether they start a new row or reside in the same row as the previous control.
Hint. Start to play with the ControlKit (see below).
The controls have a lot of properties that you can set in the property editor or by script. Find these properties documented in the dictionary.
You can set the font for the names/labels and set the fontSize.
The fontSize controls the size of the widget. All controls scale with the selected fontSize. LCB does a real good job with that, you will be surprised.
The demo stack has 5 scripted widget. The scripts show how to use the MESSAGE that is sent by the widget on mouseUp (or by hitting a push button if popped up) to its script object/the card.
For downloading the widget and a demo stack use the hh-widgets-un-installer from (Download: Sorry, currently not available). See also this post.
 
For an easy build of the controls I made moreover a CONTROLKIT* that is also available (Download: Sorry, currently not available). This stack lets you build a control widget by clicks and generates moreover a script that builds your widget (especially for use with "popup widget"). All widgets from the demo stack were made with the ControlKit in a few minutes. You can use this stack also for an easy edit of your built widgets (just copy the widget back to the controlKit for that).
____________
*Feb 02, 2018: New version 102b (removed a bug in the script generation)
 
			
							(Tested to work on newer MacOS/ Win 7+10/ Ubuntu 1604)
This is for LC 8 (version > 8.1.4). LC 9 is currently (as of 9.0.0-dp11) not supported, sorry.
hhControls is a widget that lets you create a widget that contains controls:
One or several of
++ push buttons,
++ check boxes,
++ (groupable) radio buttons,
++ info text,
++ number steppers,
++ text steppers,
++ popup menus,
++ (horizontal) sliders,
++ color swatches (needs widget hhColorpicker)
The controls are automatically placed, you only select whether they start a new row or reside in the same row as the previous control.
Hint. Start to play with the ControlKit (see below).
The controls have a lot of properties that you can set in the property editor or by script. Find these properties documented in the dictionary.
You can set the font for the names/labels and set the fontSize.
The fontSize controls the size of the widget. All controls scale with the selected fontSize. LCB does a real good job with that, you will be surprised.
The demo stack has 5 scripted widget. The scripts show how to use the MESSAGE that is sent by the widget on mouseUp (or by hitting a push button if popped up) to its script object/the card.
For downloading the widget and a demo stack use the hh-widgets-un-installer from (Download: Sorry, currently not available). See also this post.
For an easy build of the controls I made moreover a CONTROLKIT* that is also available (Download: Sorry, currently not available). This stack lets you build a control widget by clicks and generates moreover a script that builds your widget (especially for use with "popup widget"). All widgets from the demo stack were made with the ControlKit in a few minutes. You can use this stack also for an easy edit of your built widgets (just copy the widget back to the controlKit for that).
____________
*Feb 02, 2018: New version 102b (removed a bug in the script generation)
- Attachments
- 
			
		
				- One example of a hhControls widget.
- hhControls101.png (14.07 KiB) Viewed 42517 times
 
- 
			
		
				- Another example of a hhControls widget.
- hhControls100.png (26.13 KiB) Viewed 42561 times
 
					Last edited by [-hh] on Sat Feb 22, 2020 4:02 pm, edited 3 times in total.
									
			
									shiftLock happens
						Re: Community widgets
[#53a] Community LCB widget "hhColorPicker" v1.0.1
[Updated to 1.0.2, is now a "fat" widget (for LC 8 and 9), see viewtopic.php?p=171902#p171902 ]
Just upgraded the color picker to run with LC 9.0.1 (and added an opaque background).
The stack contains buttons to install / remove the widget.
Examples in the stack (incl. scripts to evaluate the results):
1. Use as non-popup widget, can be hidden and dragged around
2. Use as popup widget (as a modal dialog).
See the more detailed description of the widget here:
viewtopic.php?p=159190#p159190
			
			
													[Updated to 1.0.2, is now a "fat" widget (for LC 8 and 9), see viewtopic.php?p=171902#p171902 ]
Just upgraded the color picker to run with LC 9.0.1 (and added an opaque background).
The stack contains buttons to install / remove the widget.
Examples in the stack (incl. scripts to evaluate the results):
1. Use as non-popup widget, can be hidden and dragged around
2. Use as popup widget (as a modal dialog).
See the more detailed description of the widget here:
viewtopic.php?p=159190#p159190
					Last edited by [-hh] on Sat Feb 22, 2020 3:59 pm, edited 7 times in total.
									
			
									shiftLock happens
						Re: Community widgets
[#56] Community LCB widget "datePicker89" v1.0.7
[Updated to 1.0.8, see viewtopic.php?p=171902#p171902 ]
This is a *sample-stack* that has also buttons to install or remove the widget.
The widget is "fat" (contains LC 8 and 9 modules), loaded will by LC only the needed module. Both modules are of size 45 KByte, no matter how many copies of the picker you have on your cards. The widget incl. all resources has 200 KByte.
For creating new standard widgets ...
... Dragging from Tools does NOT work (is an IDE bug)
... Choose from menu Object/New Widget or
... DoubleClick the Date icon in Tools.
OR
use it, without creating, as popup.
Examples in the stack:
1. Use as standard (non-popup) widget, can be dragged around,
2. Use as popup widget (a modal dialog).
For the popup dialog you have to give at least one argument: The date to display as year, month, day. Optionally you can give 33 more properties (of which 10 are colors and 8 are styles for different parts).
Especially can you
For the standard widget you have 36 options available (additionally grabbing and a default pickerScale for use in the property inspector).
Thanks to Bernd Niggemann (bn, berndN) for valuable hints and comments.
### v1.0.7 Sep 30, 2018 ... first version on "Sample Stacks"
			
							
			
													[Updated to 1.0.8, see viewtopic.php?p=171902#p171902 ]
This is a *sample-stack* that has also buttons to install or remove the widget.
The widget is "fat" (contains LC 8 and 9 modules), loaded will by LC only the needed module. Both modules are of size 45 KByte, no matter how many copies of the picker you have on your cards. The widget incl. all resources has 200 KByte.
For creating new standard widgets ...
... Dragging from Tools does NOT work (is an IDE bug)
... Choose from menu Object/New Widget or
... DoubleClick the Date icon in Tools.
OR
use it, without creating, as popup.
Examples in the stack:
1. Use as standard (non-popup) widget, can be dragged around,
2. Use as popup widget (a modal dialog).
For the popup dialog you have to give at least one argument: The date to display as year, month, day. Optionally you can give 33 more properties (of which 10 are colors and 8 are styles for different parts).
Especially can you
- set english, system or custom naming,
- start the week on saturday, sunday or monday,
- see the lunar phase of the picked date and
- scale the widget to 80-280% (done by affine transforms).
Code: Select all
on mouseUp
    put "today" into tP["selectedDate"]
    popup widget "community.livecode.hermann.datepicker" \
           at the botright of me with properties tP
    if it is not empty then answer it
end mouseUp
 -- it is 7 items: year, month, day, dayOfWeek number,
 -- dayOfWeek name, month name, day's lunar phase
Thanks to Bernd Niggemann (bn, berndN) for valuable hints and comments.
### v1.0.7 Sep 30, 2018 ... first version on "Sample Stacks"
					Last edited by [-hh] on Sat Feb 22, 2020 3:59 pm, edited 6 times in total.
									
			
									shiftLock happens
						Re: Community widgets
Nice versatility on the plugin, but you know, no matter how many times I look at this ~ 
it still cracks me up 
			
			
									
									

Re: Community widgets
- [#56a] Community LCB widget DatePicker v1.0.8
 v1.0.8: Added source code (and a new name for the widget in the Tools palette).
 
- [#53b] Community LCB widget ColorPicker v1.0.2
 v1.0.2: Made also to a fat widget (for LC 8 and 9) and added a new naming system**
 
 IMPORTANT.
 The kind of the widget has changed to "community.livecode.hermann.colorpicker".
 You may have to adjust some of your scripts accordingly (sorry).
 
- [#52a] Community LCB widget IconGrid v2.1.1 
 v2.1.1: Made also to a fat widget (for LC 8 and 9) and gave a new name in the Tools palette.
 
 For the description of the widget please see here (the widget's functionality is of v2.1.0):
 viewtopic.php?p=158112#p158112
 
(EU) http://hyperhh.de/widgets or
(US) http://hh.on-rev.com/widgets
_________________
(**) I needed a unique naming system for the kind of the widget and the widget's name in the Tools palette. To get less confused when developing...
					Last edited by [-hh] on Sat Feb 22, 2020 3:57 pm, edited 4 times in total.
									
			
									shiftLock happens
						Re: Community widgets
- [#42a] Community LCB widget SVGText v1.5.2
 v1.5.1: Made to a fat widget (for LC 8 and 9) and added a new name naming system**.
 v1.5.2: Removed flicker of opening.
 
 IMPORTANT.
 The kind of the widget has changed to "community.livecode.hermann.svgtext".
 You may have to adjust some of your scripts accordingly (sorry), or use on LC 8 the old widget parallel to the new one.
- [#46a] Community LCB widget DigitClock v1.2.1
 v1.2.1: Made to a fat widget (for LC 8 and 9) and gave a new name for the tools palette.
- [#47a] Community LCB widget Polygon v1.2.1
 v1.2.1: Made to a fat widget (for LC 8 and 9) and added a new name naming system**.
 
 IMPORTANT.
 The kind of the widget has changed to "community.livecode.hermann.polygon".
 You may have to adjust some of your scripts accordingly (sorry), or use on LC 8 the old widget parallel to the new one.
- [#49a] Community LCB widget Progress v1.3.0
 v1.2.1: Made to a fat widget (for LC 8 and 9) and added a new name naming system**.
 v1.2.5: Added parameter to size inner/outer ring in ellipse mode.
 v1.3.0: Added text display (percentage) for both bar and ellipse mode.
 
 IMPORTANT.
 The kind of the widget has changed to "community.livecode.hermann.progress".
 You may have to adjust some of your scripts accordingly (sorry), or use on LC 8 the old widget parallel to the new one.
 
 [#50a] Community LCB widget OrientedText v1.5.2
 v1.5.2: Made to a fat widget (for LC 8 and 9) and gave a new name for the tools palette.
(EU) http://hyperhh.de/widgets or
(US) http://hh.on-rev.com/widgets
_________________
(**) I needed a unique naming system for the kind of the widget and the widget's name in the Tools palette.
					Last edited by [-hh] on Sat Feb 22, 2020 3:55 pm, edited 2 times in total.
									
			
									shiftLock happens
						Re: Community widgets
- [#43a] Community LCB widget ClockAround v1.2.5
 v1.2.1: Made to a fat widget (for LC 8 and 9) and gave a new name for the tools palette.
 v1.2.2: Added option to colorise the center (inner face).
 v1.2.5: Added options for the dots display, text display, context menu and grab.
(EU) http://hyperhh.de/widgets or
(US) http://hh.on-rev.com/widgets
					Last edited by [-hh] on Sat Feb 22, 2020 3:51 pm, edited 3 times in total.
									
			
									shiftLock happens
						Re: Community widgets
[#57] Community LCB widget "baseClock" v1.0.5
BaseClock is a widget that displays by special "digits" the time encoded to a number base in range 2-60.
Encoded is each of the time items (hours, minutes, seconds). For base 2 this is known as "Binary encoded decimals".
The display is unique (I invented that) as it doesn't use characters for digits > 9 but decimal "columns".
This is easy to read and (manually) to write, for the electronic "writing" we use pathes.
If the math seems difficult to you start with base 11. This means the first digit has to be multiplied by 11, the second digit adds to that, for example 42 is 4 x 11 +2 = 46.
Then go to base 12, where 42 is 4 x 12 + 2 = 50.
In base 9 is 42 read as 4 x 9 + 2 = 38.
And so on (up to base 60and down to base 5, bases 2-4 have no digit 4).
  
  
The sample stack contains an installer and displays 17 clocks to different number bases. One display cycle for a seconds display is done by each widget in < 3 millisecs (compute and paint)!
This stack shows especially an essential improvement of LCB 9 over LCB 8: The clocks are much more "in sync" than in LC 8. Compare yourself.
And it has a substack that is prepared for displaying a baseClock "window shaped".
There are 16 options for the display, see the dictionary or open the property inspector.
Note.
Some properties of the widget are triggered by the timer, which is (as all timers) stopped in the property inspector. So you may see the changes not before going back to browse mode.
Download the widget from "Sample Stacks" or from
http://livecodeshare.runrev.com/stack/911
The widget is free for non-commercial use and has the source code included. For commercial use please give a (small) fee to the LC developer help fund.
			
			
									
									BaseClock is a widget that displays by special "digits" the time encoded to a number base in range 2-60.
Encoded is each of the time items (hours, minutes, seconds). For base 2 this is known as "Binary encoded decimals".
The display is unique (I invented that) as it doesn't use characters for digits > 9 but decimal "columns".
This is easy to read and (manually) to write, for the electronic "writing" we use pathes.
If the math seems difficult to you start with base 11. This means the first digit has to be multiplied by 11, the second digit adds to that, for example 42 is 4 x 11 +2 = 46.
Then go to base 12, where 42 is 4 x 12 + 2 = 50.
In base 9 is 42 read as 4 x 9 + 2 = 38.
And so on (up to base 60and down to base 5, bases 2-4 have no digit 4).
The sample stack contains an installer and displays 17 clocks to different number bases. One display cycle for a seconds display is done by each widget in < 3 millisecs (compute and paint)!
This stack shows especially an essential improvement of LCB 9 over LCB 8: The clocks are much more "in sync" than in LC 8. Compare yourself.
And it has a substack that is prepared for displaying a baseClock "window shaped".
There are 16 options for the display, see the dictionary or open the property inspector.
Note.
Some properties of the widget are triggered by the timer, which is (as all timers) stopped in the property inspector. So you may see the changes not before going back to browse mode.
Download the widget from "Sample Stacks" or from
http://livecodeshare.runrev.com/stack/911
The widget is free for non-commercial use and has the source code included. For commercial use please give a (small) fee to the LC developer help fund.
shiftLock happens
						Re: Community widgets
[#58] Community LCB widget "ImageWidget" v1.1.0
ImageWidget is dedicated to the LC team, the makers of LCB.
The widgets lets you
The widget transforms images of up to screen size in "real time".
The base position of the 9 handles are:
  
  
Affine Transformations by Click and/or Drag actions:
[M=Midth, T=Top, L=Left, R=Right, B=Bottom]
ImageWidget is a "fat" widget that works with LC 8 and LC 9 identically and also in all LC editions, from community up to business. [Except that you need LC 9 when using drawingSVGcompile for loading an SVG file to the image.]
The code has 3500 lines (incl. 800 lines for the dictionary), there is a lot of math to do when getting the affine transforms: the widget computes the current transform from the current position of the handles. The source (lcb-file) is not included.
Download the widget and a sample stack from
(EU) http://hyperhh.de/widgets or
(US) http://hh.on-rev.com/widgets
 
			
							
			
													ImageWidget demonstrates the enormous possibilities that LiveCode Builder already provides. I tried to do everything in pure LCB. There is only script access where I was forced to do because LCB is not yet ready: Networking and adjusting the widget's size. So:Someday, everything is gonna be diff'rent when I paint my masterpiece. (Bob Dylan)
ImageWidget is dedicated to the LC team, the makers of LCB.
The widgets lets you
- load raw imagedata from your stack,
- load an image from a local file,
- load an image or (with saving) raw data from an URL.
The widget transforms images of up to screen size in "real time".
The base position of the 9 handles are:
Affine Transformations by Click and/or Drag actions:
[M=Midth, T=Top, L=Left, R=Right, B=Bottom]
- Near 0=MM but not 0=MM: Rotate,
- RightClick 0=MM: ResetImage,
- 0=MM: ResetShape (width 360),
- 2=TM: SkewX (= shearX),
- 4=MR: SkewY (= shearY),
- 6=BM: TrueHeight,
- 8=ML: TrueWidth,
- 1=TL,3=TR,5=BR,7=BL: TrueResize.
ImageWidget is a "fat" widget that works with LC 8 and LC 9 identically and also in all LC editions, from community up to business. [Except that you need LC 9 when using drawingSVGcompile for loading an SVG file to the image.]
The code has 3500 lines (incl. 800 lines for the dictionary), there is a lot of math to do when getting the affine transforms: the widget computes the current transform from the current position of the handles. The source (lcb-file) is not included.
Download the widget and a sample stack from
(EU) http://hyperhh.de/widgets or
(US) http://hh.on-rev.com/widgets
					Last edited by [-hh] on Sat Feb 22, 2020 3:50 pm, edited 2 times in total.
									
			
									shiftLock happens
						Re: Community widgets
[#59] Community LCB widget "TurnImage" v1.3.5
[v1.3.5 Adds new features: The two images are saved with the stack, you can scale/resize the widget and you can set rotation axes also at the images left, top, right and bottom.]
TurnImage is a pure LiveCode Builder widget (there is no essential script access and no use of JavaScript).
The widgets lets you
For example two groups of same size that make up the front and back of a turning "card". Just try the demo in the sample stack.
The widget is fast enough to "turn" a video by grabbing frames from it. For this we need to use a browser widget to play the video (just play, nothing else) because the LC player object is essentially blocking.
TurnImage is a "fat" widget that works with LC 8 and LC 9 identically and also in all LC editions, from community up to business.
This sample stack containes several examples for scripting the widget's properties.
Download the widget, this stack and another (large) example stack "FlipCards2" (that requires the TurnImage widget v135) from
(EU) http://hyperhh.de/widgets or
(US) http://hh.on-rev.com/widgets
 
			
							[v1.3.5 Adds new features: The two images are saved with the stack, you can scale/resize the widget and you can set rotation axes also at the images left, top, right and bottom.]
TurnImage is a pure LiveCode Builder widget (there is no essential script access and no use of JavaScript).
The widgets lets you
- turn an image horizontally or vertically with a 2D-perspective view,
- rotate and then turn around diagonal axes (axes are resettable to the ordinary ones).
- switch from an image to a second image while turning or rotating.
For example two groups of same size that make up the front and back of a turning "card". Just try the demo in the sample stack.
The widget is fast enough to "turn" a video by grabbing frames from it. For this we need to use a browser widget to play the video (just play, nothing else) because the LC player object is essentially blocking.
TurnImage is a "fat" widget that works with LC 8 and LC 9 identically and also in all LC editions, from community up to business.
This sample stack containes several examples for scripting the widget's properties.
Download the widget, this stack and another (large) example stack "FlipCards2" (that requires the TurnImage widget v135) from
(EU) http://hyperhh.de/widgets or
(US) http://hh.on-rev.com/widgets
- Attachments
- 
			
		
				- turnImage.png (11.53 KiB) Viewed 40601 times
 
					Last edited by [-hh] on Sat Feb 22, 2020 3:47 pm, edited 4 times in total.
									
			
									shiftLock happens
						- 
				Lagi Pittas
- VIP Livecode Opensource Backer 
- Posts: 367
- Joined: Mon Jun 10, 2013 1:32 pm
Re: Community widgets
Hi Hermann,
Just loaded the turnimage stack
pressed START then stop at varying times - 5 seconds 10 seconds etc - the whole ive livecode exits without any spinning or dialogs or anything.
I tried it on LC 9.04 rc3 and livecode 9.5 dp1 - exactly the same
O/S is Windows 10
Lagi
			
			
									
									
						Just loaded the turnimage stack
pressed START then stop at varying times - 5 seconds 10 seconds etc - the whole ive livecode exits without any spinning or dialogs or anything.
I tried it on LC 9.04 rc3 and livecode 9.5 dp1 - exactly the same
O/S is Windows 10
Lagi
Re: Community widgets
Lagi,
the widget and demo works here in Windows10-64bit using LC 8.1.10 and 9.0.2. and 9.5.0-dp1.
Did you install / do you use the widget that comes with the turnImage stack (and uninstall old versions)? The widget version is shown in the property inspector and should read "turnImage_v135".
The widget is pure LCB, has no OS dependencies. Do the other demos work?
Please try also in a new stack whether the turnImage widget works (rightClick for a menu).
If so, alone the video demo of the sample stack, which works here, is OS dependent because it uses a browser widget. The browser widget had memory leaks until 9.0.4 that could cause a crash after long usage but later versions should work without any problems.
Before you hit "Start", does the video run in the browser widget?
Hermann
			
			
									
									the widget and demo works here in Windows10-64bit using LC 8.1.10 and 9.0.2. and 9.5.0-dp1.
Did you install / do you use the widget that comes with the turnImage stack (and uninstall old versions)? The widget version is shown in the property inspector and should read "turnImage_v135".
The widget is pure LCB, has no OS dependencies. Do the other demos work?
Please try also in a new stack whether the turnImage widget works (rightClick for a menu).
If so, alone the video demo of the sample stack, which works here, is OS dependent because it uses a browser widget. The browser widget had memory leaks until 9.0.4 that could cause a crash after long usage but later versions should work without any problems.
Before you hit "Start", does the video run in the browser widget?
Hermann
shiftLock happens
						- 
				Lagi Pittas
- VIP Livecode Opensource Backer 
- Posts: 367
- Joined: Mon Jun 10, 2013 1:32 pm
Re: Community widgets
Thanks Herman,
Will try again tomorrow
Bogged down at the. Moment
lagi
			
			
									
									
						Will try again tomorrow
Bogged down at the. Moment
lagi
Re: Community widgets
Hope you are meanwhile recovered from using LC 9.5.1 on Win10 ...
			
			
									
									shiftLock happens
						Re: Community widgets
[#60] Community LCB widget "ChangeImage" v1.0.6
This is a (partial) extension of the TurnImage widget v135.
It adds masking of the images and several transition animations (from one image to a second one). These animations are made with pathes filled with image patterns what works in LC 8/9.
[With LC 9.5, LCB introduced CanvasOperationClipPath. Parts of the masking and some animations could also be generated with that new operation. But this doesn't work in any earlier version of LC, not even in 9.0.5, so we don't use it.]
We now have the following transition animations:
zoom, barn door horiz/vert, move horiz/vert, squeeze horiz/vert, swipe diag/horiz/vert, (perspective) turn horiz/vert and rotate.
(Note: Animations don't work in pointer mode!)
You can easily generate a "dia show" of images *of same size* with the widget.
The widget sample stack has a script for that (btn "ALL").
The widget works using LC 8/9 on MacOS, Win 7/10 and linux-ubuntu 1604 (all tested). Should also work on mobile (untested).
You can use ChangeImage Widget v106 for free.
Note. The source code (lcb-file) is NOT included.
Read more, download the widget and a sample stack from https://hyperhh.de/widgets/changeimage.html
 
p.s. https://hyperhh.de/widgets/ or https://hh.on-rev.com/widgets/ is now the overview from where you can find all updated widgets (and their sample stacks), especially most of those that were "unlinked" above (earlier) in this thread.
			
			
									
									This is a (partial) extension of the TurnImage widget v135.
It adds masking of the images and several transition animations (from one image to a second one). These animations are made with pathes filled with image patterns what works in LC 8/9.
[With LC 9.5, LCB introduced CanvasOperationClipPath. Parts of the masking and some animations could also be generated with that new operation. But this doesn't work in any earlier version of LC, not even in 9.0.5, so we don't use it.]
We now have the following transition animations:
zoom, barn door horiz/vert, move horiz/vert, squeeze horiz/vert, swipe diag/horiz/vert, (perspective) turn horiz/vert and rotate.
(Note: Animations don't work in pointer mode!)
You can easily generate a "dia show" of images *of same size* with the widget.
The widget sample stack has a script for that (btn "ALL").
The widget works using LC 8/9 on MacOS, Win 7/10 and linux-ubuntu 1604 (all tested). Should also work on mobile (untested).
You can use ChangeImage Widget v106 for free.
Note. The source code (lcb-file) is NOT included.
Read more, download the widget and a sample stack from https://hyperhh.de/widgets/changeimage.html
p.s. https://hyperhh.de/widgets/ or https://hh.on-rev.com/widgets/ is now the overview from where you can find all updated widgets (and their sample stacks), especially most of those that were "unlinked" above (earlier) in this thread.
shiftLock happens