Форум сайта python.su
poltergeistvoid QMimeData::setData ( const QString & mimeType, const QByteArray & data )
ZZZ я бы всё же посоветовал не хакать по-питонски (mime.Element = self) и усложнять жизнь разработчику… можно ведь обойтись “правильным” способом переноса данных (mime.setData(mtype, data)) драг&дропом, который уже будет в себе иметь понятный интерфейс (mtype). Такой подход будет универсальным, т.е. можно будет передавать данные не только в пределах одного приложения… Этот человек пишет пример, в том числе и для того чтобы других учить, а твой пример я считаю не хорошим в этом плане:(
The gray CardinalЕсть такой принцип: KISS.
Картинку таким способом передать вроде можно, а вот как передать сам перетаскиваемый элемент, я не понял.
class ElementMimeData(QMimeData):
def setElement(self, Element):
self.__Element = Element
def element(self):
return self.__Element
The gray CardinalА ты попробуй на нём что-нить нарисовать. :-)
Не понял. Вопрос в том, что я не пойму, что именно там за виджет сидит, в моём случае. Это не мой элемент-наследник QGraphicsPixmapItem, это не сцена, это не её QGraphicsView, и это не главное окно. Что это тогда? У меня больше никаких объектов-то нет .
The gray CardinalМнэээ… Не очень хорошо.
Кажется, осилил.
...
mime.Pos = event.pos() # Если уж так делать.
...
...
item.setPos(event.scenePos() - mime.Pos)
...
Отредактировано (Дек. 10, 2008 05:20:51)
Офлайн
ZZZНе понял, в каком смысле и как “нарисовать”? Да и “нарисование” только для выяснения, что это за виджет, смешно как-то :).
А ты попробуй на нём что-нить нарисовать. :-)
ZZZАга, я тебя понял, спасибо, учту на будущее. То, что для QPoint поддерживаются арифметические операции, тоже интересно. Но, вобщем, именно в данном контексте, мне всё это кажется не очень существенным. А делать своего наследника от QMimeData только для того, чтобы определить поле, которое Python вставляет полностью автоматически, как-то, мне кажется, не рационально, что ли. Имхо, только загромождать код будет. Ты же сам писал, что “люди, изучающие PyQt, забывают, что пишут на питоне” ;).
Всё-таки я согласен с Полтергейстом, что злоупотреблять этим совсем не стоит. Передать то, что нельзя нормально передавать через data, ещё ладно, а вот разтого рода x, y…
ZZZЗдесь ты меня понял с точностью до наоборот :). Я не рассказываю, что setData “непонятный”. Кавычки я там употребил только потому, что “понятность” - свойство слишком уж субъективное. Я ведь указал, что в случае “передавать данные не только в пределах одного приложения” setData может оказаться как раз желательнее.
И уж тем более, рассказывать новичкам про то, что setData такой непонятный – лучше разберись с ним.
Отредактировано (Дек. 10, 2008 11:48:24)
Офлайн
ZZZ
В QByteArray можно запихнуть что душе угодно, даже запиклить класс и передать таким образом - не вопрос. Просто это будет уже каким-то протоколом взаимодействия компонентов приложения/приложений. Тут я бы просто передавал в QMimeData строку с линком на ресурс (изображение в QPixmapCache, в ресурсах приложения ну или на диске) - это считаю самый кошерный вариант. Monkey patching тут излишество. А пример будет учить именно этому… :( поэтому я не понимаю нужность “этого” кукбука, если его наполнением занимаются лишь бы для наполнения, а не от огромного опыта и интересных наработок в этой области, которыми хотелось поделиться и обсудить…
З.Ы.
ZZZПро инициализацию класса забыли:) сори, просто придираюсь уже по ходу…
По-хорошему, нужно оформить это так:
Офлайн
poltergeistДа не будет учить пример “именно этому”! Пример лишь показывает, как можно сделать drag-and-drop в контексте Graphics View, ни больше, ни меньше. И вообще, интерпретация опубликованного - это личное дело каждого читателя. Так можно дойти до того, что лишнюю запятую бояться в комментариях поставить, а то вдруг кто-то чему-то плохому научится. Вместе с PyQt4 идёт единственный несчастный пример с роботом, который совершенно не полон (там элементы перетаскиваются только друг на друга, причём сами при этом не перемещаются), именно поэтому я так и мучился в этой теме. А теперь, с моим примером, уже мучиться не надо. Вот тебе и обоснование нужности этого кукбука, если уж это обоснование тебе так необходимо :).
А пример будет учить именно этому… поэтому я не понимаю нужность “этого” кукбука, если его наполнением занимаются лишь бы для наполнения, а не от огромного опыта и интересных наработок в этой области, которыми хотелось поделиться и обсудить…
poltergeistНе факт. Зачем писать длиннее, если можно написать короче?
Monkey patching тут излишество.
Офлайн
The gray CardinalНе, спасибо, я уж лучше как минимум буду тут на форуме отвечать, а если будет тяга к написанию чего-то возвышенного, то напишу пост в своём блоге…
Кстати. Никто не запрещает подлючиться к процессу, и вставить свой комментарий и свой вариант решения в тот же кукбук.
Отредактировано (Дек. 10, 2008 12:27:41)
Офлайн
poltergeist
В общем, пойми меня правильно: кукбук - это собрание коротких примеров, основное требование к которым состоит в том, что они работают так, как заявлено, и показывают, как можно решить ту или иную проблему. Вылизывать код и делать “правильнее”, “красивее” и т.д. можно почти до бесконечности. Кроме того, мнения о “правильности” и “красоте” решений могут сильно разойтись у всех читателей и писателей. Делать из короткого примера на 50 строк супер-пупер туториал с охватом всех проблем и обучением тонким правилам хорошего тона в программировании, имхо, совсем не обязательно, да и просто нереально, скорее всего. Для меня лично это стопудей нереально, по многим причинам. Поэтому я бы и был не против, если к этому делу подключился бы кто-то ещё.
Отредактировано (Дек. 10, 2008 13:21:55)
Офлайн
Офлайн
Подумал и поправил немного, в соответствии с замечаниями ZZZ о QPoint :).
Кстати, мой изначальный метод со специальным полем в классе сцены для временного хранения перетаскиваемого элемента, получается, был не так уж и плох ;).
Офлайн
poltergeistТы представляешь объем кода, для решения этого вопроса? :-)))
В QByteArray можно запихнуть что душе угодно, даже запиклить класс и передать таким образом - не вопрос.
poltergeistЯ бы, кстати, тоже. Просто не знал, как это коротко написать. Но здесь есть одна проблема – придётся переделать много кода, как мне кажется.
Тут я бы просто передавал в QMimeData строку с линком на ресурс
poltergeistНе забыли. Мне нечего дополнить к QMimeData.__init__. Но когда писал сначала руки сами набили `def __init__`… :-)
Про инициализацию класса забыли сори, просто придираюсь уже по ходу…
The gray CardinalВ этом-то и минус Qt. А если точнее PyQt. Для того, чтобы код был понятен и не был сильно разнородным, нужно оформлять классы по-qt'шному, что не очень-то согласуется с питоньим стилем и совершенно не влазиет в PEP-8. Некоторое время назад, я показал (на pydev.ru), как это можно совместить стили, но в тоже время сейчас я понимаю, что это не очень хорошо. Эволюция однако.
А делать своего наследника от QMimeData только для того, чтобы определить поле, которое Python вставляет полностью автоматически, как-то, мне кажется, не рационально, что ли.
Офлайн
>>> mime.z == mime.Element.zValue()
True
>>> import this
The Zen of Python, by Tim Peters
# вырезано девятнадцать строк
Namespaces are one honking great idea -- let's do more of those!
Офлайн