안드로이드 열화상 카메라를 사용하면 자신의 체열을 아름답게 확인할 수 있습니다. 자, 이제...">
,需要通过父级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);
}
});
})();
홈페이지 /
몸이 따뜻하거나 차가운지 생각해 본 적 있나요? 매우 흥미롭게 배웁니다! 열화상 카메라로 몸의 열을 아름답게 확인할 수 있습니다. 안드로이드 열화상 카메라 그렇다면 이 특별한 카메라는 어떻게 그런 일을 할 수 있을까요? 간단히 말해서, 적외선이라는 멋진 기술을 사용하여 생물과 비생물 모두가 방출하는 열을 볼 수 있게 해줍니다. 또한, 당신은 눈으로 적외선을 볼 수 없다는 것을 알고 있었나요? 그건 보이지 않아요! 그리고 그것이 열화상 카메라를 멋지고 특별하게 만드는 것입니다! 그것은 열을 우리가 볼 수 있는 이미지로 바꿔줍니다. 이 놀라운 카메라로 당신의 몸에서 어느 부분이 다른 부분보다 더 뜨거운지 알아낼 수 있습니다. 예를 들어, 밖에서 놀거나 운동을 하고 얼굴이 뜨거워지는 경우입니다! 장갑을 끼고 있다면 손은 차게 느껴질 수 있거나, 손은 시원할 겁니다. 카메라는 실제로 당신 안에 무엇이 있는지를 드러내며, 이를 통해 자기 이해가 생깁니다. 열화상 카메라의 또 다른 멋진 기능은 온도를 측정할 수 있지만, 아무것에도 접촉하지 않아도 된다는 것입니다! 이는 무엇이 뜨거운지 또는 차가운지를 멀리서 알 수 있기 때문에 좋습니다. 따뜻한 거품 목욕에 몸을 담글 준비를 하기 전 온도를 확인하는 것처럼 말입니다. 식사를 하기 전 음식이 익었는지 따뜻한지도 카메라로 확인할 수 있습니다. 카메라는 모든 것을 처리하므로 사용하기 매우 간단하고 즐겁습니다! 혹시 적외선 기술에 대해 들어본 적이 있나요? 열 감지기는 영화 '프레디터'에서처럼 우리 모두에게 열 시각을 제공하는 멋진 새로운 방법입니다. 스마트폰과 크게 다르지 않은 형태로 만들어진 휴대용 열화상 카메라는 당신과 주변 환경에 대한 유용한 정보를 보여줍니다! 이 카메라를 사용하면 집 안에서 놀라운 정보를 찾을 수 있으며, 얼마나 재미있는지 깜짝 놀랄 수도 있습니다! 그들은 다양한 건강 위험으로부터 당신을 보호하는 데 도움이 됩니다. 열화상 카메라가 어떻게 우리를 돕는지 알아보겠습니다. 정말입니다! 집 주변의 따뜻한 부분을 검사하는 데 사용할 수 있습니다. 만약 핫스팟이 있다면, 그것은 따뜻한 공기가 집 밖으로 새어나갈 가능성이 있음을 의미합니다. 그리고 이는 우리의 집에서 에너지 효율성을 떨어뜨릴 수 있습니다. 또한 전선의 핫스팟을 찾는 데에도 도움이 될 것입니다. 이 과정은 화재의 위협을 나타낼 수 있는 핫스팟을 드러낼 수 있습니다. 이 카메라의 도움으로 집을 안전하고 때로는 에너지 효율적으로 만들 수 있습니다. lSJ의 개인용 열화상 카메라 — LSJ는 고객에게 최고 품질의 제품과 우수한 서비스를 제공하는 것이 얼마나 중요한지 잘 알고 있습니다. 따라서 당사는 자사 제품의 내구성과 성능에 대한 확신을 바탕으로 1년 또는 5년의 보증 기간을 제공합니다. 당사는 자사 제품이 최고 수준을 충족하도록 연구개발(R&D)에 지속적으로 투자하고 있습니다. 제조업체로서 당사는 원자재 조달 단계부터 생산까지 엄격한 품질 관리를 실시합니다. 개인 구매자, 유통업체, 입찰 참가자, 나아가 정부 기관에 이르기까지 다양한 고객 유형에 맞는 다양한 제품군을 보유하고 있습니다. 또한 원자재 및 기타 부품에 대한 탄탄한 재고를 유지하여 모든 주문을 신속히 출하할 수 있도록 하고 있습니다. 만일 약정된 납기일을 준수하지 못할 경우, 고객에게 구매 금액의 2%에서 5%에 해당하는 금액을 환불해 드립니다. 당사 제품을 효율적으로 활용하고 그 가치를 최대한 발휘하실 수 있도록, 상세한 사용법 동영상 강의를 제공합니다. 더불어 귀사의 요구사항에 맞춘 현장 기술 교육을 위해 당사 기술 인력을 파견해 드릴 수도 있습니다. 이를 통해 귀사는 당사 제품을 자신 있게, 그리고 여유 있게 사용하실 수 있습니다. 고품질·고신뢰성 제품과 뛰어난 고객 서비스를 누리시려면 LSJ를 선택해 주십시오. 저희는 개인용 열화상 카메라 부서뿐 아니라 공공안전 서비스 및 도시 탐색·구조팀(USAR)을 위한 서비스도 제공합니다. LSJ는 다양한 분야에 걸쳐 탐색·구조, 소방, 폭발성 대기 환경에서의 작업을 위한 첨단 장비를 제공합니다.
소방용 열화상 카메라: 당사 팀은 해상도가 256×192, 384×288, 640×512인 두 가지 유형의 열화상 카메라를 개발하고 테스트했습니다. 이 카메라는 최대 2000°C까지 온도 측정이 가능합니다.
탐색·구조 장비: 당사는 가스 탐지기, 안정성 모니터, 움직임 감시 시스템 등 여러 제품을 제공합니다.
산업용 열화상 카메라: LSJ의 열화상 카메라는 소방 외에도 건물 점검, 전자기기 수리, 누수 탐지, HVAC 시스템 점검 등 다양한 산업 분야에 활용됩니다.
열화상 조준경(Thermal Scopes): 당사의 야간 투시 광학 기기는 야간 가시성을 확보하는 데 이상적이며, 사냥꾼들 사이에서도 인기가 높습니다. 또한 소총에 쉽게 장착할 수 있습니다.
LSJ는 다양한 산업 분야의 요구사항을 충족시키기 위해 고품질 열화상 및 구조 장비를 제공하는 데 전념하고 있으며, 모든 산업 분야의 안전성과 효율성을 향상시킵니다. LSJ는 가장 안전하고 현대적인 솔루션을 제공합니다.
도시 탐색·구조(USAR) 분야에서 LSJ를 귀사의 주요 파트너로 신뢰하실 수 있습니다. LSJ는 개인용 열화상 카메라와 호환되는 고품질 도시 구조·구난 장비 개발 분야의 선도 기업입니다.
사전 판매 서비스: 당사 전문가 팀이 초기 단계부터 귀사를 지원합니다. 귀사의 특정 요구 사항을 정확히 파악하고 맞춤형 솔루션을 제안하기 위해 종합적인 컨설팅을 제공합니다. 또한 제품 시연 및 상세한 기술 사양서를 제공하여, 귀사가 정보에 기반한 현명한 결정을 내릴 수 있도록 지원합니다.
판매 서비스: 당사는 전체 판매 프로세스가 매끄럽고 효율적으로 진행되도록 보장합니다. 빠르고 정확한 주문 시스템과 엄격한 품질 관리 절차를 통해 귀하의 제품이 예정된 시일에 완벽한 상태로 도착함을 약속합니다. 도어투도어(Door-to-Door) 배송 서비스도 지원합니다.
사후 서비스: 귀하의 제품 인도 후에도 당사와의 협력 관계는 종료되지 않습니다. 설치 지원, 사용자 교육, 정비 및 수리 서비스 등 폭넓은 사후 지원을 제공합니다. 고객 문의나 문제 발생 시 언제든지 대응 가능한 고객 서비스 담당자가 상시 대기 중이며, 귀하의 완전한 만족을 위해 최선을 다합니다. LSJ에서 장비를 구매하시면 3년간의 무상 보증 서비스를 제공하며, 구체적이고 신속한 사후 지원을 받으실 수 있습니다.
LSJ를 선택한다는 것은 신뢰성, 품질, 그리고 타의 추종을 불허하는 서비스를 선택하는 것입니다. 당사는 귀사의 도시 구조·구난 및 소방 활동 파트너로서 함께 성장해 나가기를 기대합니다. 2013년 이래, LSJ는 개인용 열화상 카메라 및 구조용 장비, 소방관 장비의 제조, 개발 및 공급을 전문으로 해오고 있습니다. LSJ는 ISO9001, CE, ROHS, MSDS 인증을 획득하였으며, 30건 이상의 특허를 취득하였습니다. 선도 기업으로서, LSJ는 디자인 및 연구 부서에 막대한 투자를 지속적으로 실시하고 있습니다. LSJ는 2024년에 INTERSEC, Securika, 말레이시아에서 개최된 제18차 Defence Services Asia 및 제3차 National Security Asia, 그리고 미국의 NFPA 등 네 차례의 주요 국제 전시회에 참가하였습니다. 2025년에는 1월 14일~16일 두바이에서 개최되는 INTERSEC 2025에 참가할 예정입니다. 당사는 열화상 소방 카메라 외에도 음향·영상 감시 장치, 가스 탐지 3D 레이더 등 다양한 제품을 전시할 계획입니다. 귀사의 방문을 진심으로 초대합니다. 11년간의 제조 경험을 바탕으로, LSJ는 고객의 실제 사용 환경에 따라 신제품을 재설계하고 제조하며, 기능을 지속적으로 개선하고 제품 비용을 절감하는 데 특화되어 있습니다. 또한 LSJ는 도시 탐색 및 구조(Urban Search and Rescue, USAR) 분야에서도 풍부한 실적을 보유하고 있습니다. 2023년 터키 지진 당시, LSJ의 레이더 생체 탐지기는 중국 ‘블루스카이 구조대’의 구조 활동에 결정적인 기여를 하였습니다. 귀사는 LSJ를 선택함으로써 귀사의 요구사항에 맞춤형으로 설계된 최신 기술을 확보하실 수 있습니다. 저작권 © 베이징 LSJ 테크놀로지 디벨롭먼트 코., 리미티드. 모든 권리 보유
-
개인정보 보호정책
개인 열화상 카메라
개인 열화상 카메라로 보이지 않는 것을 보다

정확하고 쉽게 표면 온도를 측정하다

집에서 적외선 기술의 힘을 경험하라

개인 열화상 카메라로 건강과 안전을 강화하라
Why choose LSJ Technology 개인 열화상 카메라?
품질과 적시 배송 보장: LSJ의 고객 만족 약속
완벽한 도시 구조물 탐색 및 구조 장비 공급망
왜 LSJ가 당신의 프라이머 제조업체 및 공급업체가 될 수 있는지?
고성능 수색 구조 장비 제조업체 혁신
원하는 내용을 찾지 못하셨나요?
지금 견적 요청하기
더 많은 이용 가능한 제품은 전문가와 상담해 주세요.문의하기