本文整理匯總了Python中PyQt5.Qt.QDrag.setMimeData方法的典型用法代碼示例。如果您正苦於以下問題:Python QDrag.setMimeData方法的具體用法?Python QDrag.setMimeData怎麽用?Python QDrag.setMimeData使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類PyQt5.Qt.QDrag
的用法示例。
在下文中一共展示了QDrag.setMimeData方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: mouseMoveEvent
# 需要導入模塊: from PyQt5.Qt import QDrag [as 別名]
# 或者: from PyQt5.Qt.QDrag import setMimeData [as 別名]
def mouseMoveEvent(self, event):
dex = self.indexAt(event.pos())
if dex.isValid():
self.setCursor(Qt.PointingHandCursor)
else:
self.unsetCursor()
if not event.buttons() & Qt.LeftButton:
return
if self.in_drag_drop or not dex.isValid():
QTreeView.mouseMoveEvent(self, event)
return
# Must deal with odd case where the node being dragged is 'virtual',
# created to form a hierarchy. We can't really drag this node, but in
# addition we can't allow drag recognition to notice going over some
# other node and grabbing that one. So we set in_drag_drop to prevent
# this from happening, turning it off when the user lifts the button.
self.in_drag_drop = True
if not self._model.flags(dex) & Qt.ItemIsDragEnabled:
QTreeView.mouseMoveEvent(self, event)
return
md = self._model.mimeData([dex])
pixmap = dex.data(DRAG_IMAGE_ROLE).pixmap(self.iconSize())
drag = QDrag(self)
drag.setPixmap(pixmap)
drag.setMimeData(md)
if self._model.is_in_user_category(dex):
drag.exec_(Qt.CopyAction|Qt.MoveAction, Qt.CopyAction)
else:
drag.exec_(Qt.CopyAction)
示例2: drag_data
# 需要導入模塊: from PyQt5.Qt import QDrag [as 別名]
# 或者: from PyQt5.Qt.QDrag import setMimeData [as 別名]
def drag_data(self):
m = self.model()
rows = self.selectionModel().selectedRows()
paths = [force_unicode(p, enc=filesystem_encoding) for p in m.paths(rows) if p]
md = QMimeData()
md.setData("application/calibre+from_device", b"dummy")
md.setUrls([QUrl.fromLocalFile(p) for p in paths])
drag = QDrag(self)
drag.setMimeData(md)
cover = self.drag_icon(m.cover(self.currentIndex().row()), len(paths) > 1)
drag.setHotSpot(QPoint(-15, -15))
drag.setPixmap(cover)
return drag
示例3: drag_data
# 需要導入模塊: from PyQt5.Qt import QDrag [as 別名]
# 或者: from PyQt5.Qt.QDrag import setMimeData [as 別名]
def drag_data(self):
m = self.model()
db = m.db
selected = self.get_selected_ids()
ids = ' '.join(map(str, selected))
md = QMimeData()
md.setData('application/calibre+from_library', ids.encode('utf-8'))
fmt = prefs['output_format']
def url_for_id(i):
try:
ans = db.format_path(i, fmt, index_is_id=True)
except:
ans = None
if ans is None:
fmts = db.formats(i, index_is_id=True)
if fmts:
fmts = fmts.split(',')
else:
fmts = []
for f in fmts:
try:
ans = db.format_path(i, f, index_is_id=True)
except:
ans = None
if ans is None:
ans = db.abspath(i, index_is_id=True)
return QUrl.fromLocalFile(ans)
md.setUrls([url_for_id(i) for i in selected])
drag = QDrag(self)
col = self.selectionModel().currentIndex().column()
try:
md.column_name = self.column_map[col]
except AttributeError:
md.column_name = 'title'
drag.setMimeData(md)
cover = self.drag_icon(m.cover(self.currentIndex().row()),
len(selected) > 1)
drag.setHotSpot(QPoint(-15, -15))
drag.setPixmap(cover)
return drag
示例4: WebView
# 需要導入模塊: from PyQt5.Qt import QDrag [as 別名]
# 或者: from PyQt5.Qt.QDrag import setMimeData [as 別名]
#.........這裏部分代碼省略.........
initClass('Menu');
initClass('MenuItem');
initClass('TrayIcon');
initClass('Downloader');
initClass('Process');
initClass('SocketServer');
initClass('SocketClient');
function initClass(name){
HAE[name] = function(){
return initEventBinder(HAE['create' + name].apply(window, arguments));
};
}
function initModule(name){
var key = 'HAE_' + name;
HAE[name] = initEventBinder(window[key]);
delete window[key];
}
function initEventBinder(object){
object.addEvent = function(event, handler){
if(typeof event == 'string'){
var eventName = event;
event = ('on' + event).toLowerCase();
if(event in this && this[event].connect){
this[event].connect(handler);
}else{
console.warn('Warning: This object dose not have "' + eventName + '" event');
}
}else if(typeof event == 'object'){
for(var key in event){
this.addEvent(key, event[key]);
}
}
};
object.removeEvent = function(event, handler){
event = 'on' + event;
console.log(this[event]);
if(event in this && this[event].connect){
this[event].disconnect(handler);
}
};
return object;
}
})();
''')
def mousePressEvent(self, event):
self.parentWidget().mousePressEvent(event)
if not self.parentWidget().isDraging():
super(WebView, self).mousePressEvent(event)
if event.buttons() == Qt.LeftButton:
mimeData = QMimeData()
hitTestResult = self.mainFrame.hitTestContent(event.pos())
# print(hitTestResult.linkUrl())
# dragging the scrollbar
if hitTestResult.isNull():
self.draging = True
if hitTestResult.isContentSelected():
mimeData.setText(self.selectedText())
mimeData.setHtml(self.selectedHtml())
elif not hitTestResult.linkUrl().isEmpty():
mimeData.setUrls([hitTestResult.linkUrl()])
mimeData.setHtml(hitTestResult.element().toOuterXml())
elif not hitTestResult.pixmap().isNull():
mimeData.setImageData(hitTestResult.pixmap())
mimeData.setUrls([hitTestResult.imageUrl()])
mimeData.setHtml(hitTestResult.element().toOuterXml())
# mimeData.setData('application/x-qt-windows-mime;value="FileContents"', QVariant(hitTestResult.pixmap()).toByteArray())
# elif not hitTestResult.mediaUrl().isEmpty():
# mimeData.setUrls([hitTestResult.mediaUrl()])
# mimeData.setHtml(hitTestResult.element().toOuterXml())
else:
return
# pixmap = hitTestResult.pixmap()
# pixmap.setMask(QBitmap.fromImage(pixmap.toImage()))
self.drag.setMimeData(mimeData)
# self.drag.setPixmap(pixmap)
# self.drag.setHotSpot(QPoint(self.drag.pixmap().width() / 2, self.drag.pixmap().height() / 2))
def mouseMoveEvent(self, event):
if not self.parentWidget().isDraging():
super(WebView, self).mouseMoveEvent(event)
if self.drag.mimeData():
self.drag.exec()
self.drag.setMimeData(None)
if not self.draging:
event.ignore()
def mouseReleaseEvent(self, event):
self.draging = False
super(WebView, self).mouseReleaseEvent(event)
self.drag.setMimeData(None)
event.ignore()
def close(self):
self.stop()
self.load()
self.page().close()
self.eval('HAE = null')
self.drag.setMimeData(None)
super(WebView, self).close()