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

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

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

Регистрация: Oct 2006
Адрес: Кисловодск
Сообщений: 192
Отправить сообщение для Diestro с помощью ICQ
По умолчанию Вызов переопределенного метода у родителя родителя

Есть класс A, который определяет метод someMethod. И в нем определен жизненно важный функционал:
Код:
public class A {
//--------------------------
     public function someMethod():void{
          //жизненно важный функционал
     }
}
Есть класс B, который наследуется от A и переопределяет метод someMethod, вызывающий someMethod родителя и добавляя в него свой, ненужный нам функционал:
Код:
public class B extends A {
//--------------------------
     override public function someMethod():void{
          super.someMethod();
          //ненужный нам функционал
     }
}
Предположим Классы A и B это классы flex sdk и изменять их нельзя.

Задача:
Отнаследоваться от класса B, переопределить someMethod, но вызвать someMethod класса A, так как в someMethod класса B реализован ненужный нам функционал и добавить свой.
Код:
public class C extends B {
//--------------------------
     override public function someMethod():void{
          ??? superOfClassA.someMethod();
          //мой функционал
          
     }
}
Upd:
Я могу привести конкретный пример. Доводя до ума компонент AutoComplete, найденый на Adobe Flex Exchange оказалось что в нем существует ряд багов, которые захотелось исправить. Все что хотел исправил, но вылез баг, зарытый в классе ComboBox, от которого наследуется компонент AutoComplete. ComboBox в свою очередь наследуется от ComboBase.
Баг спрятан в функции updateDisplayList компонента ComboBox которая переопределяется из самых недр наследования. Здесь есть строка:
Код:
textInput.getTextField().setSelection(0, textInput.text.length);
которая собственно выделяет в определенный момент весь текст, находящийся внутри текстового поля этого компонента, потом сбрасывая выделение. Если это делать в "чистом проекте" то все в порядке, но если флэшка подзагружена или не очень быстрый компьютер, то при очень быстром вводе текста - выделеный текст стирается и бывает так что в текстовом поле остается только часть "наскоро" введенного текста.
updateDisplayList - жизненно необходимая функция и тем более в компоненте AutoComplete добавляется дополнительная функциональность. А вот функционал в ComboBox хотелось бы переделать и переопределить updateDisplayList именно его родителя.

Вопрос: насколько это возможно и какие есть выходы из данной ситуации?
__________________
blog.diestro.ru


Последний раз редактировалось Diestro; 14.10.2008 в 11:53.
Старый 10.10.2008, 15:00
terbooter вне форума Посмотреть профиль Отправить личное сообщение для terbooter Найти все сообщения от terbooter
  № 2  
Ответить с цитированием
terbooter

Регистрация: Oct 2006
Адрес: Novosibirsk-Kaliningrad
Сообщений: 1,278
Отправить сообщение для terbooter с помощью ICQ Отправить сообщение для terbooter с помощью Skype™
Насколько я помню, никак такое не сделать.
И это правильно.
Представляю какая каша началась бы была возможность переопределять
метод 0супер-1супер-...nсупер класса

Старый 10.10.2008, 16:50
smilenka вне форума Посмотреть профиль Отправить личное сообщение для smilenka Найти все сообщения от smilenka
  № 3  
Ответить с цитированием
smilenka
[+1.3 31.10.08]

Регистрация: Sep 2008
Сообщений: 8
А нельзя использовать агрегацию ? и вызывать метод объекта-экземпляра нужного вам класса A или B, притом что объект является членом вашего класса C.

Старый 10.10.2008, 18:04
Diestro вне форума Посмотреть профиль Отправить личное сообщение для Diestro Посетить домашнюю страницу Diestro Найти все сообщения от Diestro
  № 4  
Ответить с цитированием
Diestro
 
Аватар для Diestro

Регистрация: Oct 2006
Адрес: Кисловодск
Сообщений: 192
Отправить сообщение для Diestro с помощью ICQ
Агрегация не подойдет. Например someMethod это реализация метода invalidateDisplayList() и хотелось бы чтобы все вызовы этого метода реализовывал класс C, без разницы из недр какого из родителей он был вызван.
__________________
blog.diestro.ru

Старый 12.10.2008, 13:50
Diestro вне форума Посмотреть профиль Отправить личное сообщение для Diestro Посетить домашнюю страницу Diestro Найти все сообщения от Diestro
  № 5  
Ответить с цитированием
Diestro
 
Аватар для Diestro

Регистрация: Oct 2006
Адрес: Кисловодск
Сообщений: 192
Отправить сообщение для Diestro с помощью ICQ
Неужели ни у кого больше нету идей. Неужели все выходят из положения переносом класса из flex sdk в папку проекта, чтобы убрать ненужный код?
__________________
blog.diestro.ru

Старый 12.10.2008, 16:45
enepx вне форума Посмотреть профиль Отправить личное сообщение для enepx Посетить домашнюю страницу enepx Найти все сообщения от enepx
  № 6  
Ответить с цитированием
enepx
 
Аватар для enepx

Регистрация: Aug 2006
Адрес: Мюнхен
Сообщений: 509
Отправить сообщение для enepx с помощью ICQ Отправить сообщение для enepx с помощью Yahoo Отправить сообщение для enepx с помощью Skype™
мне кажется Вам подойдет перепроектирование проекта (извиняюсь за игру слов). что-то тут не так )

Старый 12.10.2008, 17:17
7thsky™ вне форума Посмотреть профиль Отправить личное сообщение для 7thsky™ Найти все сообщения от 7thsky™
  № 7  
Ответить с цитированием
7thsky™
Flash Aксакал
 
Аватар для 7thsky™

Регистрация: Jun 2005
Сообщений: 636
Скорее всего не обойти. Как правило (в таких случаях) в классе C переопределяется метод и туда просто копируется содержимое того же метода из класса A (без копирования всего сдк).

нда... вообще интересно есть ли более правильное решение

Старый 12.10.2008, 18:41
Diestro вне форума Посмотреть профиль Отправить личное сообщение для Diestro Посетить домашнюю страницу Diestro Найти все сообщения от Diestro
  № 8  
Ответить с цитированием
Diestro
 
Аватар для Diestro

Регистрация: Oct 2006
Адрес: Кисловодск
Сообщений: 192
Отправить сообщение для Diestro с помощью ICQ
Я могу привести конкретный пример. Т.е. описать где именно я с этим столкнулся. Доводя до ума компонент AutoComplete, найденый на Adobe Flex Exchange оказалось что в нем существует ряд багов, которые захотелось исправить. Все что хотел исправил но вылез баг, зарытый в классе ComboBox, от которого наследуется компонент AutoComplete. ComboBox в свою очередь наследуется от ComboBase.
Баг спрятан в функции updateDisplayList компонента ComboBox которая переопределяется из самых недр наследования. Здесь есть строка:
Код:
textInput.getTextField().setSelection(0, textInput.text.length);
которая собственно выделяет в определенный момент весь текст, находящийся внутри текстового поля этого компонента, потом сбрасывая выделение. Если это делать в "чистом проекте" то все в порядке, но если флэшка подзагружена или не очень быстрый компьютер, то при очень быстром вводе текста - выделеный текст стирается и бывает так что в текстовом поле остается только часть "наскоро" введенного текста.
updateDisplayList - жизненно необходимая функция и тем более в компоненте AutoComplete добавляется дополнительная функциональность. А вот функционал в ComboBox хотелось бы переделать и переопределить updateDisplayList именно его родителя.
__________________
blog.diestro.ru


Последний раз редактировалось Diestro; 12.10.2008 в 18:46.
Старый 12.10.2008, 18:49
wvxvw вне форума Посмотреть профиль Отправить личное сообщение для wvxvw Найти все сообщения от wvxvw
  № 9  
Ответить с цитированием
wvxvw
Modus ponens
 
Аватар для wvxvw

модератор форума
Регистрация: Jul 2006
Адрес: #1=(list #1#)
Сообщений: 8,049
Записей в блоге: 38
Можешь попробовать поискать метод типа $invalidateDisplayList, так вобщем-то принято называть метод, если он должен експонировать родительский метод, при том, что этот же класс его оверрайдит. Ну, а если такого нету... ну не знаю, зависит от того на сколько проект должен быть совместим / поддерживаться дальше другими разработчиками и т.п. Если вы единственный его разработчик - я бы не заморачивался и просто дописал сам этот $... метод к нужному классу, а если нет - ну, тогда, как уже сказали, только самому взять и переписать...
__________________
Hell is the possibility of sanity

Старый 14.10.2008, 11:42
Diestro вне форума Посмотреть профиль Отправить личное сообщение для Diestro Посетить домашнюю страницу Diestro Найти все сообщения от Diestro
  № 10  
Ответить с цитированием
Diestro
 
Аватар для Diestro

Регистрация: Oct 2006
Адрес: Кисловодск
Сообщений: 192
Отправить сообщение для Diestro с помощью ICQ
Цитата:
Сообщение от 7thsky™ Посмотреть сообщение
Скорее всего не обойти. Как правило (в таких случаях) в классе C переопределяется метод и туда просто копируется содержимое того же метода из класса A (без копирования всего сдк).

нда... вообще интересно есть ли более правильное решение
Ну это при условии что класс A является самым верхним в родительской иерархии. А если будет большая глубина наследования то и копировать прийдется последовательно кучу кода из всех родителей метода updateDisplayList().

Цитата:
Сообщение от wvxvw Посмотреть сообщение
Можешь попробовать поискать метод типа $invalidateDisplayList, так вобщем-то принято называть метод, если он должен експонировать родительский метод, при том, что этот же класс его оверрайдит. Ну, а если такого нету... ну не знаю, зависит от того на сколько проект должен быть совместим / поддерживаться дальше другими разработчиками и т.п. Если вы единственный его разработчик - я бы не заморачивался и просто дописал сам этот $... метод к нужному классу, а если нет - ну, тогда, как уже сказали, только самому взять и переписать...
Естественно нужного метода через значок $ там не оказалось
__________________
blog.diestro.ru


Последний раз редактировалось iNils; 14.10.2008 в 11:51.
Создать новую тему Ответ Часовой пояс GMT +4, время: 10:46.
Быстрый переход
  « Предыдущая тема | Следующая тема »  

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

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


 


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


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