简体   繁体   English

我想在图像面板上显示蒙版,并在其上设置特定的蒙版按摩,或在图像的左上角设置图标

[英]I want to show mask on an image panel and set particular mask massage on it or set icon on the top-left corner of the image

I want to show mask on an image panel and set particular mask massage on it or set icon on the top-left corner of the image. 我想在图像面板上显示蒙版,并在其上设置特定的蒙版按摩,或在图像的左上角设置图标。 extjs. 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();
                                         });
                      }
                  }
}

As per your requirement, you want to show mask on image with custom message . 根据您的要求,您想在带有自定义message图像上显示mask

You need to use image component inside panel or any other component. 您需要使用panel内部的image组件或任何其他组件。

In this FIDDLE , I have created a demo using ExtJS 5.x version. 在这个FIDDLE中 ,我使用ExtJS 5.x版本创建了一个演示。 it will work for all version(4.x or above). 它将适用于所有版本(4.x或更高版本)。 I hope this will help you or guide you to achieve your requirement. 希望这对您有所帮助或指导您达到要求。

code snippet 程式码片段

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 Part 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>

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM