我想在图像面板上显示蒙版并在其上设置特定的蒙版按摩或在图像的左上角设置图标。 ExtJS的。
{
xtype: 'form',
layout: 'hbox',
width:'100%',
bodyPadding : '30 20 30 20',
scrollable:true,
items : [{
xtype:'image',
src: imageUrl,
// data:'shubham',
cls: 'partner-image-wrapper',
labelCls:'https:--------------.png'
listeners:{
render:function(form){debugger
form.getEl().dom.addEventListener('mouseenter',function(){debugger
form.el.mask('shubhan');
});
form.getEl().dom.addEventListener('mouseleave',function(){debugger
form.el.unmask();
});
}
}
}
答案 0 :(得分:0)
根据您的要求,您希望使用自定义message
在图片上显示mask
。
在 FIDDLE 中,我使用ExtJS 5.x版本创建了一个演示版。它适用于所有版本(4.x或更高版本)。我希望这可以帮助您或指导您实现您的要求。
代码段
Ext.create('Ext.form.Panel', {
title: 'Mask example with image and panel',
bodyPadding: 5,
layout: {
type: 'hbox',
align: 'center'
},
items: [{
layout: 'hbox',
bodyPadding: 7,
itemId: 'myImagePnl',
maxWidth: 320,
items: [{
height: 280,
width: 280,
xtype: 'image',
src: ''
}],
listeners: {
afterrender: function (panel) {
panel.mon(panel.body, 'mouseenter', function () {
this.up('form').doMaskUnMaskMouseEnterOrLeave(true);
}, panel);
}
}
}],
// Mask and Unmask buttons
bbar: ['->', {
xtype: 'button',
text: 'Mask on Image',
itemId: 'mask',
handler: function () {
this.up('form').doMaskUnMask(this);
}
}, {
xtype: 'button',
itemId: 'unmask',
text: 'Unmask on Image',
disabled: true,
handler: function () {
this.up('form').doMaskUnMask(this);
}
}],
renderTo: Ext.getBody(),
//function will do mask or unmask on image panel mouse enter or leave.
doMaskUnMaskMouseEnterOrLeave: function (isMask) {
var form = this;
if (isMask) {
form.down('#myImagePnl').mask('Mouse enter, for unmask leave mouse from <b>image<b>');
var dom = Ext.DomQuery.select('div.x-mask-msg-text')[0].offsetParent;
if (Ext.get(dom)) {
Ext.get(dom).on('mouseleave', function () {
this.doMaskUnMaskMouseEnterOrLeave(false);
}, form);
}
} else {
form.down('#myImagePnl').unmask();
}
},
//function will do mask or unmask on image panel.
doMaskUnMask: function (btn) {
var form = this;
btn.setDisabled(true);
if (btn.getItemId() == 'mask') {
form.down('#myImagePnl').mask('Mask button clicked, For unmask click to <b>unmask</b> button');
form.down('#unmask').setDisabled(false);
} else {
form.down('#myImagePnl').unmask();
form.down('#mask').setDisabled(false);
}
}
});
CSS部分
<style>
.x-mask-msg {
height: 100%;
width: 100%;
background-color: #00000024;
}
.x-mask-msg-inner {
height: 100%;
width: 100%;
display: table;
}
.x-mask-msg-text {
padding: 21px 0 20px 20px;
vertical-align: middle;
display: table-cell;
color: blue;
background-size: 0px;
}
</style>