Thanks for that. Seems to work fine, here is what I did in case anyone else is looking.
Add 3 images to my gui sheet:
1. a background for the loading bar
2. a little slice of loading bar that can be stretched horizontally
3. a front for the loading that has a slot alpha cut into it
I need them drawn in that order so the bar can fill the slot nicely.
The existing progress bar has a background and a bar so that covers items 1 + 2. To add the front I need a child widget to sit on top. So I open my scheme file and add:
Code: Select all
<FalagardMapping WindowType="TaharezLook/ProgressBarFront" TargetType="DefaultWindow" Renderer="Falagard/StaticImage" LookNFeel="TaharezLook/ProgressBarFront" />
So I'm just copying a static image definition.
Then in the looknfeel I add the new front widget.
Code: Select all
<WidgetLook name="TaharezLook/ProgressBarFront">
<ImagerySection name="image">
<ImageryComponent>
<Area>
<Dim type="LeftEdge" >
<AbsoluteDim value="0" />
</Dim>
<Dim type="TopEdge" >
<AbsoluteDim value="0" />
</Dim>
<Dim type="Width" >
<UnifiedDim scale="1" type="Width" />
</Dim>
<Dim type="Height" >
<UnifiedDim scale="1" type="Height" />
</Dim>
</Area>
<Image imageset="TaharezLook" image="LoadingBarFace" />
<VertFormat type="Stretched" />
<HorzFormat type="Stretched" />
</ImageryComponent>
</ImagerySection>
<StateImagery name="Enabled" >
<Layer>
<Section section="image" />
</Layer>
</StateImagery>
</WidgetLook>
And modify the existing progress bar to attach the new child and mvoe the progress bar into the middle.
Code: Select all
<!--
***************************************************
TaharezLook/ProgressBar
***************************************************
-->
<WidgetLook name="TaharezLook/ProgressBar">
<NamedArea name="ProgressArea">
<Area>
<Dim type="LeftEdge" >
<AbsoluteDim value="15" />
</Dim>
<Dim type="TopEdge" >
<AbsoluteDim value="10" />
</Dim>
<Dim type="RightEdge" >
<UnifiedDim scale="1" type="RightEdge">
<DimOperator op="Subtract">
<AbsoluteDim value="15" />
</DimOperator>
</UnifiedDim>
</Dim>
<Dim type="Height" >
<UnifiedDim scale="1" type="Height" >
<DimOperator op="Subtract">
<AbsoluteDim value="20" />
</DimOperator>
</UnifiedDim>
</Dim>
</Area>
</NamedArea>
<Child type="TaharezLook/ProgressBarFront" nameSuffix="front" >
<Area>
<Dim type="LeftEdge" >
<AbsoluteDim value="0" />
</Dim>
<Dim type="TopEdge" >
<AbsoluteDim value="0" />
</Dim>
<Dim type="Width" >
<UnifiedDim scale="1" type="Width" />
</Dim>
<Dim type="Height" >
<UnifiedDim scale="1" type="Height" />
</Dim>
</Area>
</Child>
<ImagerySection name="progress_lights" >
<ImageryComponent>
<Area>
<Dim type="LeftEdge" ><AbsoluteDim value="0" /></Dim>
<Dim type="TopEdge" ><AbsoluteDim value="0" /></Dim>
<Dim type="Width" ><UnifiedDim scale="1" type="Width" /></Dim>
<Dim type="Height" ><UnifiedDim scale="1" type="Height" /></Dim>
</Area>
<Image imageset="TaharezLook" image="LoadingBarSegment" />
<VertFormat type="Stretched" />
<HorzFormat type="Stretched" />
</ImageryComponent>
</ImagerySection>
<ImagerySection name="background">
<FrameComponent>
<Area>
<Dim type="LeftEdge" >
<AbsoluteDim value="0" />
</Dim>
<Dim type="TopEdge" >
<AbsoluteDim value="0" />
</Dim>
<Dim type="Width" >
<UnifiedDim scale="1" type="Width" />
</Dim>
<Dim type="Height" >
<UnifiedDim scale="1" type="Height" />
</Dim>
</Area>
<Image type="Background" imageset="TaharezLook" image="LoadingBarBackground" />
</FrameComponent>
</ImagerySection>
<StateImagery name="EnabledProgress">
<Layer>
<Section section="progress_lights" />
</Layer>
</StateImagery>
<StateImagery name="DisabledProgress">
<Layer>
<Section section="progress_lights">
<Colours topLeft="FF7F7F7F" topRight="FF7F7F7F" bottomLeft="FF7F7F7F" bottomRight="FF7F7F7F" />
</Section>
</Layer>
</StateImagery>
<StateImagery name="Enabled">
<Layer>
<Section section="background" />
</Layer>
</StateImagery>
<StateImagery name="Disabled">
<Layer>
<Section section="background">
<Colours topLeft="FF7F7F7F" topRight="FF7F7F7F" bottomLeft="FF7F7F7F" bottomRight="FF7F7F7F" />
</Section>
</Layer>
</StateImagery>
</WidgetLook>
Hopefully that is a sensible approach
data:image/s3,"s3://crabby-images/7abc1/7abc1b5e32cf3dd6691049bd049374790c6eaa9e" alt="Smile :)"