为了账号安全,请及时绑定邮箱和手机立即绑定

如何使用Selenium Webdriver捕获特定元素而不是整个页面的屏幕截图?

如何使用Selenium Webdriver捕获特定元素而不是整个页面的屏幕截图?

元芳怎么了 2019-09-20 14:50:25
目前我正在尝试使用Selenium WebDriver捕获屏幕截图。但我只能获得整页屏幕截图。但是,我想要的只是捕获页面的一部分,或者只是基于ID或任何特定元素定位器捕获特定元素。(例如,我希望用图像id =“Butterfly”捕获图片)有没有办法按选定的项目或元素捕获屏幕截图?
查看完整描述

3 回答

?
收到一只叮咚

TA贡献1821条经验 获得超4个赞

在Node.js,我编写了以下代码,但它不是基于selenium的官方WebDriverJS,而是基于SauceLabs's WebDriver:WD.js和一个非常紧凑的图像库,名为EasyImage。


我只想强调你不能真正拍摄元素的截图,但你应该做的是首先,截取整个页面的截图,然后选择你喜欢的页面部分并裁剪特定部分:


browser.get(URL_TO_VISIT)

       .waitForElementById(dependentElementId, webdriver.asserters.isDisplayed, 3000)

       .elementById(elementID)

        .getSize().then(function(size) {

            browser.elementById(elementID)

                   .getLocation().then(function(location) {

                        browser.takeScreenshot().then(function(data) {

                            var base64Data = data.replace(/^data:image\/png;base64,/, "");

                            fs.writeFile(filePath, base64Data, 'base64', function(err) {

                                if (err) {

                                    console.log(err);

                                } 

                                else {

                                    cropInFile(size, location, filePath);

                                }

                                doneCallback();

                        });

                    });

                });

            }); 

而cropInFileFunction就是这样的:


var cropInFile = function(size, location, srcFile) {

    easyimg.crop({

            src: srcFile,

            dst: srcFile,

            cropwidth: size.width,

            cropheight: size.height,

            x: location.x,

            y: location.y,

            gravity: 'North-West'

        },

        function(err, stdout, stderr) {

            if (err) throw err;

        });

};


查看完整回答
反对 回复 2019-09-20
  • 3 回答
  • 0 关注
  • 1038 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信