Попробуйте перевернуть эти строки с:
width -= 341;
minWidth = 450;
до:
minWidth = 450;
width -= 341;
Я думаю, что проблема в том, как настроено условие в общем .... Я собираюсь скопировать ваш код и изменить его, как я бы сделал это, и сделать репост в виде редактирования, но вы можете попробовать Приведенное выше предложение (я полагаю, что вы можете установить ширину ниже минимальной ширины, а затем уменьшить minWidth, чтобы настройка ширины в первую очередь была бы установлена на ширину, которая недопустима в соответствии с текущей minWidth, может увидеть это только в первый раз из-за времени с проверкой.
РЕДАКТИРОВАТЬ (дважды редактировать, добавить блокировку размера окна, установив минимальную и максимальную высоты, равные заданной высоте):
<?xml version="1.0" encoding="utf-8"?>
<s:WindowedApplication xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx"
minHeight="355"
maxHeight="355"
minWidth="450"
width.two="791"
width.one="450"
minWidth.one="450"
minWidth.two="791"
maxWidth.one="450"
maxWidth.two="791">
<fx:Script>
<![CDATA[
protected function stateBox_changeHandler(event:Event):void
{
// TODO Auto-generated method stub
currentState=stateBox.selected ? 'two' : 'one';
}
]]>
</fx:Script>
<s:states>
<s:State name="one"/>
<s:State name="two"/>
</s:states>
<s:HGroup width="100%"
height="100%"
gap="0">
<s:Rect width="450"
height="100%">
<s:fill>
<s:SolidColor color="0xff0000"/>
</s:fill>
</s:Rect>
<s:Rect width="341"
height="100%"
includeIn="two">
<s:fill>
<s:SolidColor color="0x000000"/>
</s:fill>
</s:Rect>
</s:HGroup>
<s:CheckBox id="stateBox"
label="change state"
change="stateBox_changeHandler(event)"/>
</s:WindowedApplication>
Достигает ли это желаемого поведения ^ (извините, я знаю, что я изменил много кода, но я просто подхожу к этому, может быть, это не сработает из-за других явных размеров, которые вам нужно установить, но, кажется, для достижения цель для меня)