тепловата камера за Android? Това е много мощен инструмент, който ни позволява да наблюдаваме това, което нашите очи сами по себе си не могат да забележат. Топлинната камера използва инфрачервена...">
,需要通过父级DOM结构来判断
*/
var trackActionPhone = function (node) {
var nodeInnerText = node.innerText || '';
if (!limitRegLength(nodeInnerText)) return;
var nodeText = trimText(nodeInnerText);
if (nodeText.length < 5 || nodeText.length > 20) return false;
var type =
arguments.length > 1 && arguments[1] !== undefined
? arguments[1]
: 'click';
var str = trimText(node.href || node.innerHTML || '');
if (phoneReg.test(str) && numUseReg.test(str)) {
_paq.push(['trackEvent', type, 'phone', nodeText]);
return true;
}
/** 排查父级嵌套非标签场景,并且对dom的正则校验做一个性能兜底,通过控制innerText的长度,来确保正则的性能 */
var fatherText = trimText(node.parentNode.innerText || '');
if (fatherText.length < 5 || fatherText.length > 20) return false;
var fatherDom = trimText(node.parentNode.innerHTML || '');
if (phoneReg.test(fatherDom) && numUseReg.test(fatherDom)) {
_paq.push(['trackEvent', type, 'phone', nodeText]);
return true;
}
return false;
};
window.addEventListener('click', function (e) {
var node = e.target;
/** 社媒点击 */
var appName = '';
var getAppAriaLabel =
node.ariaLabel || node.parentNode.ariaLabel || '';
if (mediaList.includes(getAppAriaLabel.toLowerCase())) {
appName = getAppAriaLabel;
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'a'
) {
appName = getMediaName(node.href) || getMediaName(node.alt);
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'img'
) {
appName = getMediaName(node.alt) || getMediaName(node.src);
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'i'
) {
appName = getMediaName(node.className);
}
if (appName) {
_paq.push(['trackEvent', 'click', 'contactApp', appName]);
return;
}
/** 联系方式点击 */
if (trackActionPhone(node, 'click')) return;
if (node.nodeName && node.nodeName.toLowerCase() === 'a') {
var val = node.href;
if (!limitRegLength(val)) return;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'click', 'email', val]);
return;
}
}
if (node.nodeName && node.nodeName.toLowerCase() === 'i') {
var val = node.className;
var content = node.parentNode.href || '';
if (val.includes('email')) {
_paq.push(['trackEvent', 'click', 'email', content]);
return;
}
}
var nodeChildList = node.childNodes;
for (var i = 0; i < nodeChildList.length; i++) {
if (nodeChildList[i].nodeType !== 3) continue;
var val = nodeChildList[i].textContent.replace(/\s?:?/g, '');
if (!limitRegLength(val)) continue;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'click', 'email', val]);
return;
}
}
trackNumberData(node);
});
window.addEventListener('copy', function (e) {
if (trackActionPhone(e.target, 'copy')) return;
var text = e.target.textContent;
if (!text) return;
var val = text.replace(/\s:?/g, '');
if (!limitRegLength(val)) return;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'copy', 'email', val]);
return;
}
trackNumberData(e.target);
});
}
trackContactInit();
/**
* 基于custom_inquiry_form.js 以及 form.js 对于询盘表单提交的实现,来反推询盘表单的input标签触发,用来收集意向客户
* 1. 缓存的KEY:TRACK_INPUT_ID_MTM_00;
* 2. 缓存策略 - lockTrackInput:单个页面内,10分钟内,不重复上报
*/
function trackActionInput() {
const CACHE_KEY = 'TRACK_INPUT_ID_MTM_00';
const pathName = window.location.hostname + window.location.pathname;
var lockTrackInput = function () {
try {
const lastCacheData = localStorage.getItem(CACHE_KEY);
if (!lastCacheData) return false;
const cacheData = JSON.parse(lastCacheData);
const cacheTime = cacheData[pathName];
if (!cacheTime) return false;
return Date.now() - cacheTime < 1000 * 60 * 10; // 10分钟内,不重复上报
} catch (error) {
console.error('lockTrackInput Error', error);
return false;
}
};
var setInputTrackId = function () {
try {
const curCacheData = localStorage.getItem(CACHE_KEY);
if (curCacheData) {
const cacheData = JSON.parse(curCacheData);
cacheData[pathName] = Date.now();
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
return;
}
const cacheData = {
[pathName]: Date.now(),
};
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
} catch (error) {
console.error('setInputTrackId Error', error);
}
};
var getInputDom = function (initDom) {
var ele = initDom;
while (ele) {
/**
* isWebSiteForm 是站点的表单
* isChatWindowForm 是聊天窗口的表单
*/
/** 旧模板表单 */
var isWebSiteForm = !!(
/crm-form/i.test(ele.className) && ele.querySelector('form')
);
/** 1:新模板自定义表单、2:Get a Quote 弹框表单 */
var isWebSiteFormNew = !!(
/inquiry/i.test(ele.className) && ele.querySelector('form')
);
if (isWebSiteForm || isWebSiteFormNew) {
_paq.push(['trackEvent', 'formInquiry', 'formInput', 'page']);
setInputTrackId();
return;
}
/** Mkt会话触达-聊天弹框的表单输入: MKT由于是iframe嵌入,所以MKT的上报,会单独写到MKT-form代码上 */
var isInquiryChatForm = !!(
/comp-form/i.test(ele.className) && ele.querySelector('form')
);
if (isInquiryChatForm) {
_paq.push(['trackEvent', 'formInquiry', 'formInput', 'chat']);
setInputTrackId();
return;
}
/** 向上查找父节点 */
ele = ele.parentNode;
}
};
function initInputListener() {
var inputUseDebounce = function (fn, delay) {
var timer = null;
var that = this;
return function () {
var args = Array.prototype.slice.call(arguments);
if (timer) clearTimeout(timer);
timer = setTimeout(function () {
fn.apply(that, args);
}, delay);
};
};
var optimizeGetInputDom = inputUseDebounce(getInputDom, 300);
window.addEventListener('input', function (e) {
/** 如果已经上报过,则不再上报 */
if (lockTrackInput()) return;
optimizeGetInputDom(e.target);
});
}
try {
initInputListener();
} catch (error) {
console.log('initInputListener Error', error);
}
}
trackActionInput();
}
/** 第三方消息上报:目前主要是针对全点托管会话;在msgCollect/index.js中调试,访问test.html */
function thirdMsgCollect() {
/** 先检测是否是stayReal托管:如果stayReal脚本都没有,那么说明当前站点未开启stayReal会话托管 */
const scriptList = Array.prototype.slice.call(
document.querySelectorAll('script'),
);
const checkStayReal = () =>
!!scriptList.find((s) => s.src.includes('stayreal.xiaoman.cn'));
if (!checkStayReal()) return;
/** 缓存当前消息队列的最后一条消息id */
const CACHE_KEY = 'CACHE_KEY_MONITOR';
const setCache = (msgIndex) => {
/** 对缓存KEY进行base64转码处理 */
const cacheMsgIndex = btoa(msgIndex);
localStorage.setItem(CACHE_KEY, cacheMsgIndex);
};
const getCache = () => {
const cacheMsgIndex = localStorage.getItem(CACHE_KEY);
if (cacheMsgIndex) return Number(atob(cacheMsgIndex));
return -1;
};
/** 拉取最新msg列表 */
const pullMsgList = () => {
const msgEleList = Array.prototype.slice.call(
document.querySelectorAll('#chat-list li'),
);
const msgIds = [];
const msgMap = msgEleList.reduce((acc, item) => {
const sendTime = item
.querySelector('.message-data-time')
.textContent.trim();
const sendContent = item.querySelector('.message').textContent.trim();
/** msg带有class:other-message的是访客消息,my-message的是客服消息 */
const isOtherMessage = item
.querySelector('.message')
.classList.contains('other-message');
const msgId = item.querySelector('.message').getAttribute('id');
const msgItemData = {
msgId,
user: isOtherMessage ? 'visitor' : 'official',
time: sendTime,
content: sendContent,
};
msgIds.push(msgId);
acc[msgId] = msgItemData;
return acc;
}, {});
return {
ids: msgIds,
dataMap: msgMap,
};
};
/** 加密并上传消息数据 */
let ENCRYPT_KEY = 'de29f1aab63ab033';
let ENCRYPT_IV = 'b8d2badf875e76ac';
const baseUrl = 'https://cms.xiaoman.cn';
// var getEncryptConfig = function () {
// const url = baseUrl + '/shop-api/innerApi/getKeyIv'
// $.get(
// url,
// function (result) {
// console.log('result', result)
// if (Number(result.code) === 0 && result.data.key && result.data.iv) {
// ENCRYPT_KEY = result.data.key
// ENCRYPT_IV = result.data.iv
// uploadMsgData()
// } else {
// /** 如果获取失败,则重试 */
// setTimeout(() => {
// getEncryptConfig()
// }, 1000)
// }
// },
// 'json'
// )
// }
// getEncryptConfig()
const encryptMsg = function (msgData) {
const enc = new TextEncoder();
// 转字节
const keyBytes = enc.encode(ENCRYPT_KEY);
const ivBytes = enc.encode(ENCRYPT_IV);
const plainBytes = enc.encode(msgData);
// 导入密钥并加密
return crypto.subtle
.importKey('raw', keyBytes, { name: 'AES-CBC' }, false, ['encrypt'])
.then(function (cryptoKey) {
return crypto.subtle.encrypt(
{ name: 'AES-CBC', iv: ivBytes },
cryptoKey,
plainBytes,
);
})
.then(function (encryptedBuffer) {
// 转 base64 返回
return btoa(
String.fromCharCode(...new Uint8Array(encryptedBuffer)),
);
})
.catch((err) => {
return Promise.reject(err);
});
};
let uploadFlag = false;
const uploadMsgData = function () {
if (uploadFlag) return;
uploadFlag = true;
const { ids, dataMap } = pullMsgList();
let cacheMsgIndex = getCache();
const msgLen = ids.length;
if (!msgLen) {
// 消息DOM未挂载 || 消息DOM已挂载,但是消息列表为空
uploadFlag = false;
return;
}
if (msgLen - 1 < cacheMsgIndex) {
/** 针对站点挂后台一段时间,消息列表会自动塞入重复消息,导致消息有重复,刷新后又重置回正常消息列表,所以这里需要更新锚点下标 */
cacheMsgIndex = msgLen - 1;
setCache(cacheMsgIndex);
uploadFlag = false;
return;
}
if (msgLen - 1 === cacheMsgIndex) {
// 缓存的最后一次发送的消息ID是最后一条(说明当前消息均已经上报),则不跳过本地上报
uploadFlag = false;
return;
}
const currentMsgIds = ids.slice(cacheMsgIndex + 1, msgLen);
const currentMsgData = currentMsgIds.map((id) => dataMap[id]);
const mtmId = window.matomo_site_id_cookie_key || ''; // 获取mtm会话id
const msgBody = {
mtmId,
curl: window.location.href,
msgList: currentMsgData,
};
const msgBodyStr = JSON.stringify(msgBody);
encryptMsg(msgBodyStr)
.then(function (encryptedMsg) {
console.log('encryptedMsg:', encryptedMsg, msgBodyStr);
const url = baseUrl + '/shop-api/External/ListenSiteActiveStatus';
$.ajax({
type: 'POST',
url,
data: JSON.stringify({ d_v: encryptedMsg }),
contentType: 'application/json',
success: function (result) {
if (Number(result.code) === 0) {
// 更新消息队列
setCache(msgLen - 1);
}
uploadFlag = false;
},
error: function (err) {
console.error(err, '请求异常');
uploadFlag = false;
},
});
})
.catch((err) => {
console.error(err, '数据加密失败');
uploadFlag = false;
});
};
/** 监控chat-list的DOM变更 */
const initChatListObserver = () => {
// 需要监听的 DOM 节点
const target = document.getElementById('chat-list');
if (!target) return;
// 回调函数
const callback = function (mutationsList, observer) {
for (const mutation of mutationsList) {
console.log('mutation', mutation);
if (mutation.type === 'childList') {
uploadMsgData();
}
}
};
// 配置
const config = {
childList: true, // 监听子节点的增删
subtree: true, // 是否也监听后代节点
};
// 创建 observer
const observer = new MutationObserver(callback);
// 开始监听
observer.observe(target, config);
};
let testCount = 30;
let itv = null;
const checkChatDom = () => !!document.querySelector('#vc-model');
const initTalkCheck = () => {
itv = setTimeout(() => {
console.log('checkChatDom', checkChatDom(), testCount);
if (!checkChatDom() && testCount > 0) {
testCount--;
initTalkCheck();
return;
}
clearTimeout(itv);
uploadMsgData();
initChatListObserver();
}, 1500);
};
initTalkCheck();
}
try {
gtmTrack();
thirdMsgCollect();
console.log('inserted gtm code');
} catch (error) {
console.error('gtmTrack Error', error);
}
});
})();
Знаеш ли какво е термална Камера за Android ? Това е много мощен инструмент, който ни позволява да наблюдаваме неща, които очите ни не могат да видят сами. Термалната камера използва инфрачервен светлинен спектър, за да формира изображение. Това е наистина впечатляващо, защото ни позволява да виждаме топлина. С тази топлинна визия можем да откриваме скрити проблеми, които в друг случай остават незабелязани! Разгледай своя дом или училище с дупка в покрива. Да се определи откъде идва водата може да бъде много трудно. Малко вероятно е да забележите протичане, особено ако водата се е разпростряла. С термалната термална Камера за Android можем да видим къде водата охлажда нещата повече, отколкото трябва. Термална камера показва различни температури, така че знаем, че това е точното място, което трябва да се поправи отгоре! По този начин можем да спрем протечката преди да причини още повече вреди. Много от проблемите, срещнати от нас, могат да бъдат решени или предотвратени, ако са забележени рано с евтин термален камера Android . Това е толкова важно, защото ако остане нерешено, ще се засилено и коригирането му, когато всичко вече е излязло от ред, ще бъде много по-трудно. Това ще ни спести време и пари в бъдеще. Това е подобно на ходенето на регуларни проверки у лекаря. Да предположим, че е за нашето здраве и лекарят открива проблем на ранна стадия, тогава имаме лесно (или по-лесно) решение, отколкото когато нещата станат много лоши. Така че, това ще спести много време и пари за поправки, които се правят от евтин термален камера Android . Чим колкото повече пари и време сме събрали, толкова повече от тях ще можем да похарчим за забавления, които могат да донесат истинско щастие в нашите жизни. Сега, когато мисля за това, можем да прекарваме повече време, играейки с приятели и да тръгваме на забавни приключения или да си купим следващата играчка. Просто ще има време, когато хората имат работа в области, които съществено дойдат с твърде много рискове. Думата за тези опасни места се нарича опасни среди. Вокруг вас може да има неща, които биха могли да са опасни за тях - като много гореща вода, чистящи химикали или нещо друго. Когато правим термичен скен на петрохимично производство или рафинерия с Horizon Excel, местата за работа са по-безопасни за всеки, който трябва да отиде в тези райони. Това е така, например, ако трябва да работите в много гореща зона, ние извършваме термен камера скен, за да проверим дали човекът не се грее прекалено много. Контролираме тези неща и ако камерата ни казва, че те стават горещи, можем да направим промени, за да охлажданме тази област, така че все още да е безопасна за тях, но по-безопасна. Това ни позволява да останем по-безопасни и по-здравословни, докато работим! За това, разбира се, можем да проверим изолацията зад стените. Изолацията е от съществено значение за предотвратяване на загуба или стягане на топлина. Чрез термалната камера лесно можем да видим области на изолация, които може да са повредени или по някакъв начин по-тънки, отколкото трябва. Това ще гарантира, че сградата е в добър състояние преди да има жители и ще помогне за подобряване на бъдещите квартиранти, като ги прави комфортни, когато са сигурни вътре в своите съответни апартаменти. В LSJ ние разбираме важността на термичното сканиране с топлинна камера и осигуряваме висококачествени продукти и изключително обслужване на нашите клиенти. Затова предлагаме гаранции от една или пет години. Това демонстрира нашата увереност в качеството и производителността на нашите продукти. Инвестираме значителни средства в научни изследвания и разработки, за да гарантираме, че нашите продукти отговарят на най-високите стандарти. Като производител прилагаме строги стандарти за контрол на качеството – от началото до крайния продукт. Предлагаме широка гама продукти, за да задоволим нуждите на всички потребители. Нашите запаси от компоненти, суровини и други материали са достатъчно големи, за да осигурят своевременно доставки. В случай, че не успеем да доставим стоката навреме, ще ви възстановим до 5% от сумата. За да ви помогнем да използвате нашите продукти по продуктивен начин и ефективно, предоставяме подробни обучащи видеоклипове. Освен това предлагаме техническо обучение на място, персонализирано според вашите конкретни нужди, така че да придобиете необходимата компетентност за ефективно и лесно използване на нашите продукти. Изберете LSJ за висококачествени, надеждни продукти и отлично клиентско обслужване. От 2013 г. компанията Thermal Camera Scan разработва, произвежда и доставя високопроизводителни устройства за търсене и спасяване, както и екипировка за пожарникари. LSJ е получила сертификати за ISO9001, CE и RoHS. Компанията притежава също повече от 30 патента. Инвестираме значителни средства в нашия отдел по изследвания и дизайн, тъй като сме водещ бизнес. През 2024 г. LSJ участва в четири големи международни изложби: INTERSEC в Дубай, Securika 2024, 18-ата изложба за отбранителни услуги „Asia (DSA)“ и 3-тата изложба „National Security Asia (NATSEC)“ в Малайзия, както и в изложбата на NFPA в САЩ. Освен това сме регистрирани за участие в INTERSEC в Дубай от 14 до 16 януари 2025 г. Там ще представим нашия радарен детектор за живи обекти, 3D радар, способен да открива стени, газови детектори, аудио- и видеооборудване за подслушване, както и оборудване за мониторинг на стабилността и термични камери за борба с пожари. Каним Ви да посетите нашия щанд. LSJ има 11-годишен опит в производството. Те са експерти в разработването и създаването на нови продукти, базирани на конкретните сценарии на използване от страна на клиентите. Освен това непрекъснато подобряват възможностите и намаляват разходите за своите продукти. LSJ притежава също богат опит в градското търсене и спасяване. Например при земетресението в Турция през 2023 г. радарният детектор за жизнени признаци на LSJ изигра ключова роля в спасителните операции на китайския отряд „Blue Sky Rescue“. Изберете LSJ за напреднали, надеждни решения, персонализирани според Вашите изисквания. Ние осигуряваме поддръжка на пожарните и спасителните служби, както и на службите за обществена безопасност и градските екипи за търсене и спасяване. LSJ предоставя иновативно оборудване за термични камери, извършване на търсене и спасяване, както и работа в опасни зони в различни отрасли.
Термични камери за пожарникари: Проучили сме и разработили два типа термични камери. Те се предлагат с три опции за резолюция: 256x192, 384x288 и 640x512. Тези камери могат да измерват температури до 2000 °C.
Оборудване за търсене и спасяване: Предлагаме широка гама продукти, включващи монитори за стабилизиране, детектори на газове и системи за наблюдение на движение.
Промишлени термични камери: Освен термичните камери за пожарникари, LSJ предлага ръчни термични камери за откриване на течове в водопроводните мрежи и инспекции на сгради, както и за електронен ремонт, установяване на загуби при подовото отопление и инспекции на климатични системи (HVAC).
Термични прицели и нощни прицели: Идеални са за наблюдение през нощта и са популярни сред ловците. Могат да се монтират върху огнестрелни оръжия.
LSJ е ангажирана да доставя висококачествено термично изобразяващо и спасително оборудване, за да отговаря на изискванията на различни отрасли и да повишава безопасността и ефективността. LSJ предлага най-сигурните и напреднали решения.
Можете да имате пълно доверие на LSJ като основен Ви партньор в областта на градското търсене и спасяване. LSJ е пионер в разработването на термални камери за сканиране и оборудване за градско търсене и спасяване, което отговаря на международните стандарти.
Предварително продажбено обслужване:
Екипът ни от специалисти е готов да ви помогне още от самото начало. Предлагаме изчерпателни консултации, за да разберем напълно вашите изисквания и да създадем персонализирани решения. Предоставяме подробни технически спецификации на продукта и демонстрация, за да ви помогнем да вземете обосновано решение.
Продажбено обслужване:
Грижим се целият процес на продажба да протече безпроблемно и ефективно. Гарантираме, че вашите продукти ще пристигнат навреме и в отлично състояние благодарение на оптимизираната ни система за поръчки и строгия контрол на качеството. Поддържаме и доставка „от врата до врата“.
Служба след продажбата:
Партньорството ни с вас не свършва с доставката на нашите продукти. Обширните ни услуги след продажбата включват помощ при инсталиране, обучение на потребители и поддръжка. Екипът ни по обслужване на клиенти е готов да ви помогне при всички възникнали проблеми или въпроси и да гарантира пълното ви задоволство. При закупуване на оборудване от LSJ вие получавате гаранция сроком три години и можете да ползвате конкретни услуги след продажбата от нас.
Когато избирате LSJ, избирате качество, надеждност и непревзойдена услуга. Очакваме с нетърпение да станем ваши партньори в областта на градското търсене и спасяване, както и при борба с пожари. Авторско право © Beijing LSJ Technology Development Co., Ltd. Запазени са всички права
-
Политика за поверителност
термален камерен скан
Термален камерен скан спестява време и пари при поддържането на обслугване

Термален камерен скан подобрява безопасността в опасни среди

Термален камерен скан повишава енергийната ефективност

Термален камерен скан предоставя ценен инсайт за градски инспекции
Why choose LSJ Technology термален камерен скан?
Гарантиране на качество и вreme за доставка: ангажиментът на LSJ към удовлетвореността на клиентите
Иновиращ Производител на Високопроизводително Оборудване за Търсене и Спасяване
Пълен набор от екипировка за градски търсене и спасavanе. Ланцети на осигуряване на екипировка
Защо LSJ може да бъде вашият производител и доставчик на праймери?
Свързани категории продукти
Не намирате това, което търсите?
Поискайте оферта сега
Свържете се с нашите консултанти за повече налични продукти.Свържете се с нас