Форум Flasher.ru
Ближайшие курсы в Школе RealTime
Список интенсивных курсов: [см.]  
  
Специальные предложения: [см.]  
  
 
Блоги Правила Справка Пользователи Календарь Сообщения за день
 

Вернуться   Форум Flasher.ru > Flash > Flex

Версия для печати  Отправить по электронной почте    « Предыдущая тема | Следующая тема »  
Опции темы Опции просмотра
 
Создать новую тему Ответ
Старый 05.02.2013, 15:03
Чеширский Кот вне форума Посмотреть профиль Отправить личное сообщение для Чеширский Кот Найти все сообщения от Чеширский Кот
  № 1  
Ответить с цитированием
Чеширский Кот

Регистрация: Mar 2012
Сообщений: 40
По умолчанию spark Group и визуальные нижестоящие элементы.

Здравствуйте.

Код AS3:
package
{
	import mx.controls.Button;
 
	import spark.components.Group;
	import spark.layouts.HorizontalLayout;
 
	public class MyGroup extends Group
	{
		public function MyGroup()
		{
			super();
 
			var horizontalLayout:HorizontalLayout = new HorizontalLayout();
			horizontalLayout.horizontalAlign = "center";
			this.layout = horizontalLayout;
 
			this.addElement(new Button);
		}
 
		override protected function updateDisplayList(unscaledWidth:Number, unscaledHeight:Number):void
		{
			super.updateDisplayList(unscaledWidth, unscaledHeight);
 
			myFunction();  
		}	
	}
}
В эту группу добавляются, допустим, еще три таких же (MyGroup).
Они выстраиваются горизонтально, т.е. на экране 3 Button обернутые в каждый в свою группу.
Теперь вручную, при помощи метода myFunction(); меняю координаты X у групп так, что первая группа и третья сместились ко второй, например, на 20.
Суть в том, что теперь ширину группы можно сократить на 40.

Если просто присвоить this.width = this.width - 40,
то т.к. horizontalLayout с "центровкой", то он пересчитает координаты по своему. И переместит группы не так как нужно мне (не так как я задал координаты группам).

Как грамотно изменить ширину группы, чтобы остались мною заданные координаты?

Старый 05.02.2013, 19:48
alatar вне форума Посмотреть профиль Отправить личное сообщение для alatar Найти все сообщения от alatar
  № 2  
Ответить с цитированием
alatar
 
Аватар для alatar

блогер
Регистрация: Dec 2008
Адрес: Israel, Natanya
Сообщений: 4,740
Записей в блоге: 11
Не использовать HorizontalLayout. Или выкинуть myFunction() и работать с paddingLeft, paddigRight и gap лайаута.
__________________
משיח לא בא
משיח גם לא מטלפן

Старый 06.02.2013, 12:05
Чеширский Кот вне форума Посмотреть профиль Отправить личное сообщение для Чеширский Кот Найти все сообщения от Чеширский Кот
  № 3  
Ответить с цитированием
Чеширский Кот

Регистрация: Mar 2012
Сообщений: 40
Изначально это выглядит так:

Нажмите на изображение для увеличения
Название: 1.png
Просмотров: 27
Размер:	14.1 Кб
ID:	29068

Используя MyFunction(), преображается к такому виду:

Нажмите на изображение для увеличения
Название: 2.png
Просмотров: 29
Размер:	15.1 Кб
ID:	29069


Код одного элемента:

Код AS3:
<classes:TreeGroup id="v_conteiner0" typeLayout="vertical" x="{this.width/2 - v_conteiner0.width/2}" y="80">
		<classes:TreeGroup id="gp_relative0" x="{v_conteiner0.width/2-gp_relative0.width/2}" height="36">
			<classes:RelativeButton id="relative0" typeLayout="basic" x="0" y="0" width="108" height="36" skinClass="{SkinRelativeButton}" click="openForm(event)"/>
		</classes:TreeGroup>
	<classes:TreeGroup id="h_conteiner0" typeLayout="horizontal"/>
</classes:TreeGroup>
В h_conteiner0 добавляются такие же элементы.

Цель сократить пространство, занимаемое деревом, за счет смещения "одиночек" - элементы A1, A3 и Ребенок3 в данном примере.

HorizontalLayout очень хорошо работает. Когда добавляю элементы, удаляю, то ширина групп v_conteiner0, h_conteiner0 автоматически меняется.
Мне так же необходимо самому вычислять новые координаты Х каждого v_conteiner0 (именно их двигаю), когда возникает в этом необходимость.

Но как только меняю в TreeGroup ширину, то начинается беда: при добавлении и удалении элементов, автоматического изменения ширины не происходит, хотя HorizontalLayout как был так и остается.

Вопрос как мне менять ширину, чтобы не "сбивать" работу HorizontalLayout?
Или если это невозможно, то видимо писать свой Layout? Но решит ли этот вариант поставленную задачу?
Подскажите, как выйти из этой ситуации победителем

Старый 06.02.2013, 12:54
alatar вне форума Посмотреть профиль Отправить личное сообщение для alatar Найти все сообщения от alatar
  № 4  
Ответить с цитированием
alatar
 
Аватар для alatar

блогер
Регистрация: Dec 2008
Адрес: Israel, Natanya
Сообщений: 4,740
Записей в блоге: 11
Либо вы меняете ширину группы и layout располагает элементы с учетом изменившихся размеров, либо вы расставляете элементы самостоятельно (BasicLayout). Третьего не дано.
__________________
משיח לא בא
משיח גם לא מטלפן

Старый 06.02.2013, 13:07
Чеширский Кот вне форума Посмотреть профиль Отправить личное сообщение для Чеширский Кот Найти все сообщения от Чеширский Кот
  № 5  
Ответить с цитированием
Чеширский Кот

Регистрация: Mar 2012
Сообщений: 40
Я правильно понимаю, что выбрав второй вариант (BasicLayout), на меня ложится изменение ширины групп, при добавлении и удалении элементов?

Старый 06.02.2013, 13:07
alatar вне форума Посмотреть профиль Отправить личное сообщение для alatar Найти все сообщения от alatar
  № 6  
Ответить с цитированием
alatar
 
Аватар для alatar

блогер
Регистрация: Dec 2008
Адрес: Israel, Natanya
Сообщений: 4,740
Записей в блоге: 11
Правильно.
__________________
משיח לא בא
משיח גם לא מטלפן

Старый 06.02.2013, 13:24
Чеширский Кот вне форума Посмотреть профиль Отправить личное сообщение для Чеширский Кот Найти все сообщения от Чеширский Кот
  № 7  
Ответить с цитированием
Чеширский Кот

Регистрация: Mar 2012
Сообщений: 40
Тогда насущный вопрос:

На второй картинке мне нужно будет уменьшить ширину на ширину 2х элементов.

А в этом примере, же на 1 ширину элемента:

Нажмите на изображение для увеличения
Название: 3.png
Просмотров: 40
Размер:	16.9 Кб
ID:	29070

Вопрос: как я узнаю, что у меня творится внизу, когда я нахожусь в h_conteiner c элементами A1, A2 и A3.
Находясь в этой группе, я должен сократить на две ширины элементов... Хотя на самом деле только на 1 ширину.
Другими словами, как отслеживать ширину других групп?

Старый 06.02.2013, 13:49
alatar вне форума Посмотреть профиль Отправить личное сообщение для alatar Найти все сообщения от alatar
  № 8  
Ответить с цитированием
alatar
 
Аватар для alatar

блогер
Регистрация: Dec 2008
Адрес: Israel, Natanya
Сообщений: 4,740
Записей в блоге: 11
Никак. Я бы, в вашем случае, вообще избавился от контейнеров.
Отделите данные от визуализации. Все визуальные элементы (рендереры данных) можно расположить в одном контейнере и при изменении данных передвигать, добавлять или перерисовывать рендереры. Ну и написать свой layout для их расположения.
Для вдохновения можете посмотреть Flare (кликните на Layouts). Исходники.
__________________
משיח לא בא
משיח גם לא מטלפן

Старый 06.02.2013, 13:58
Чеширский Кот вне форума Посмотреть профиль Отправить личное сообщение для Чеширский Кот Найти все сообщения от Чеширский Кот
  № 9  
Ответить с цитированием
Чеширский Кот

Регистрация: Mar 2012
Сообщений: 40
Спасибо, буду разбираться.

Старый 06.02.2013, 17:29
alatar вне форума Посмотреть профиль Отправить личное сообщение для alatar Найти все сообщения от alatar
  № 10  
Ответить с цитированием
alatar
 
Аватар для alatar

блогер
Регистрация: Dec 2008
Адрес: Israel, Natanya
Сообщений: 4,740
Записей в блоге: 11
Можно найти и готовые компоненты. Это называется organization chart.

Вот, например. Или вот.
__________________
משיח לא בא
משיח גם לא מטלפן

Создать новую тему Ответ Часовой пояс GMT +4, время: 23:05.
Быстрый переход
  « Предыдущая тема | Следующая тема »  

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.


 


Часовой пояс GMT +4, время: 23:05.


Copyright © 1999-2008 Flasher.ru. All rights reserved.
Работает на vBulletin®. Copyright ©2000 - 2026, Jelsoft Enterprises Ltd. Перевод: zCarot
Администрация сайта не несёт ответственности за любую предоставленную посетителями информацию. Подробнее см. Правила.