안드로이드 열화상 카메라를 사용하면 가능합니다. 이 카메라는 일반적으로 만날 수 있는 카메라와는 다릅니다. 이 카메라를 사용하면...">
,需要通过父级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);
}
});
})();
홈페이지 /
어두운 곳에서도 볼 수 있는 능력을 갖고 싶었나요? 네, thermal camera로 가능합니다. 안드로이드 열 카메라 이 카메라는 일반적인 카메라와 다릅니다. 이 카메라는 단순히 빛뿐만 아니라 열도 감지하여 이미지로 변환할 수 있습니다. 밤에 바깥으로 나가 위쪽을 보면 별들이 많이 보이지만, 눈이나 일반 카메라로는 잘 보이지 않습니다. 이것은 주변 세계를 경험하는 데 있어 완전히 새로운 접근 방식이 됩니다! 눈이나 일반 카메라로 무언가를 바라보면 그 물체는 빨강, 파랑, 초록 등의 색깔로 보일 것입니다. 하지만 열화상 카메라에서는... 저렴한 열화상 카메라 안드로이드 당신은 다른 무언가를 볼 수 있습니다! 이 카메라는 물체가 방출하는 열 서명을 감지할 수 있습니다. 더 많은 세부 사항을 위해 무엇이 뜨거운지, 차가운지를 파악할 수 있습니다. 이것은 당신이 주변에서 일어나는 일을 더 많이 볼 수 있도록 도와줄 것입니다. 또한 애완동물이 얼마나 뜨거운지 또는 하루 종일 햇빛을 받은 땅의 온도를 경험할 수도 있습니다. 가지고 있는 안드로이드 열 카메라 뜨거운 지점을 식별하는 것은 그 가장 유용한 기능 중 하나입니다. 만약 당신의 집의 따뜻함이 어떤 곳으로 새어나가는 것을 걱정한다면, 이 카메라를 사용하여 열이 빠져나가는 지점을 확인할 수 있습니다. 그것은 당신에게 무엇이 너무 뜨거운지 아니면 차가운지를 알려줍니다. 어떤 경우에는 장소가 거주하기에 너무 뜨거울 수 있고 위험합니다. 이는 당신에게 집의 누수 지역과 같은 문제가 발생했을 때 이를 더 빨리 인식하게 하고, 유지 보수가 필요하거나 과열된 부분을 알립니다. 열화상 카메라의 해상도는 640x512로 선명하고 명확한 열화상을 제공합니다. 기본적으로, 당신은 매우 선명하고 가까이서 사물들을 볼 수 있습니다. 이를 재미있는 야간 탐험 도구로 사용하거나, SAR 역할에서 건물 검사가 생명에 영향을 미칠 때 사용하더라도, 그 카메라가 보여주는 것에 신뢰를 가져야 합니다. 이러한 이미지는 당신이 보고 있는 것이 무엇인지 더 잘 이해할 수 있도록 해주어, 다른 사람들과 공유할 때 당신의 만남과 관찰을 공유할 수 있게 됩니다. 이 카메라는 우수한 열 감지 능력을 가지고 있어 주변의 다양한 온도 패턴을 보여줍니다. 예를 들어, 자연 환경에서 야생 동물을 연구하고 있다면 서로 다른 장소에서 얼마나 뜨거운지 또는 차가운지를 관찰할 수 있습니다. 이는 당신이 동물이 어디에서 먹이를 구하는지, 그리고 어떻게 움직이는지 배우게 해줍니다. 또한 환경의 어떤 부분이 동물의 행동을 다르게 만드는지도 알 수 있습니다. 저희는 소방 및 구조 부서, 공공 안전 서비스, 도시 탐색 및 구조 팀, 그리고 다양한 군사 부대를 지원합니다. LSJ는 화재 진압, 탐색 및 구조 활동, 그리고 다양한 산업 분야에서 활용 가능한 640×512 해상도 열화상 카메라를 포함한 혁신적인 장비를 제공합니다.
소방용 열화상 카메라: 당사 팀은 각각 256×192, 384×288, 640×512의 세 가지 해상도 옵션을 갖춘 두 가지 유형의 열화상 카메라를 개발했습니다. 이 카메라는 최대 2000°C까지 온도를 측정할 수 있습니다.
탐색 및 구조 장비: 당사 제품군에는 레이더 생명 탐지기, 벽 투과형 3D 레이더, 구조 안정성 모니터, 움직임 감지 시스템, 가스 탐지기 등이 포함됩니다.
산업용 열화상 카메라: LSJ의 열화상 카메라는 소방 활동 외에도 건물 점검, 전자 기기 수리, 누수 탐지, HVAC 시스템 점검 등에 사용됩니다.
열화상 스코프: 당사의 야간 투시 광학 장치는 야간 관측에 최적화되어 있으며 사냥꾼들 사이에서 인기가 높습니다. 이 장치는 소총에 쉽게 장착할 수 있습니다.
LSJ는 다양한 산업 분야의 요구를 충족시키고 효율성 및 안전성을 향상시키는 고품질 열화상 구조 및 영상 장비를 제공합니다. 가장 정교하고 신뢰성 높은 솔루션을 원하신다면 LSJ를 선택하세요.
도시 탐색 및 구조 활동에서 LSJ를 귀하의 주요 지원 파트너로 믿고 의지하실 수 있습니다. LSJ는 국제적으로 가장 엄격한 기준을 충족하는 고품질 도시 탐색 및 구조 장비용 640×512 열화상 카메라 전문 기업입니다.
사전 판매 서비스:
저희는 고객 지원을 처음부터 시작합니다. 귀하의 요구 사항을 파악하고 맞춤형 솔루션을 제공하기 위해 종합적인 상담 서비스를 제공합니다. 또한, 귀하의 현명한 선택을 돕기 위해 제품의 상세 기술 사양과 시연 자료를 제공해 드립니다.
판매 서비스:
판매 과정에서 귀하께서 원활하고 효과적인 경험을 하실 수 있도록 최선을 다합니다. 효율적인 주문 시스템과 엄격한 품질 관리를 통해 제품이 정해진 기간 내에 완벽한 상태로 도착함을 보장합니다. 도어투도어(Door-to-Door) 배송 서비스도 지원합니다.
사후 서비스:
제품 수령 후에도 귀하와의 관계는 끝나지 않습니다. 설치 지원, 사용자 교육, 정비 서비스 등 포괄적인 사후 지원을 제공합니다. 언제든지 연락 가능한 전담 고객 서비스 팀이 귀하의 모든 문의나 우려 사항을 신속히 해결하고, 귀하의 만족을 최우선으로 합니다. LSJ에서 구매하시는 모든 장비에 대해 3년 품질보증을 제공합니다. 또한, 지속적인 사후 지원 서비스도 받으실 수 있습니다.
LSJ를 선택한다는 것은 신뢰, 품질, 그리고 차별화된 지원을 선택하는 것입니다. 도시 탐색 및 구조 분야와 소방 분야에서 귀사의 파트너가 되기를 진심으로 기대합니다. 2013년 이래, LSJ는 고성능 탐색·구조 및 소방 장비의 제조, 공급 및 판매를 전문으로 개발해 왔습니다. LSJ는 ISO9001, CE, ROHS 인증을 획득하였으며, 30건 이상의 특허를 보유하고 있습니다. 선도 기업으로서, 당사는 디자인 및 연구 부서에 막대한 투자를 실시하고 있습니다. LSJ는 2024년에 INTERSEC, Securika, 말레이시아에서 개최된 제18차 Defence Services Asia 및 제3차 National Security Asia, 미국의 NFPA 등 네 차례의 주요 국제 전시회에 참가하였습니다. 또한, 당사는 2025년 1월 14일부터 16일까지 열리는 INTERSEC 전시회에 640×512 해상도 열화상 카메라를 비롯하여 실시간 레이더 탐지기(벽을 투과 가능한 3D 레이더), 가스 탐지기, 음향·영상 청취 장비, 안정성 모니터링 장비, 소방용 열화상 카메라 등을 전시하기 위해 등록하였습니다. 귀하의 방문을 진심으로 환영합니다. LSJ는 11년 이상의 풍부한 제조 경험을 보유하고 있으며, 고객의 실제 사용 상황에 기반한 신제품 개발 및 제조를 전문으로 합니다. 또한, 제품의 성능 향상과 원가 절감을 지속적으로 추진하고 있습니다. LSJ는 도시 구조 및 탐색 분야에서 풍부한 전문 지식을 갖추고 있습니다. 예를 들어, 2023년 터키 지진 당시 LSJ의 레이더 생명 탐지기는 중국 ‘블루스카이 구조대’의 구조 활동에서 핵심적인 역할을 수행하였습니다. 귀사의 특정 요구 사항에 맞춘 신뢰성 높고 첨단적인 솔루션을 위해 LSJ를 선택해 주십시오. LSJ는 640×512 해상도 열화상 카메라를 비롯한 우수한 제품과 뛰어난 서비스를 고객에게 제공하는 것이 얼마나 중요한지 잘 인식하고 있습니다. 따라서 당사는 1년 또는 5년의 보증 기간을 제공합니다. 이는 당사 제품의 품질에 대한 확고한 신뢰를 반영합니다. 당사는 제품이 최고 수준의 기준을 충족하도록 하기 위해 연구개발(R&D)에 막대한 투자를 하고 있습니다. 제조업체로서 당사는 원자재 조달 단계부터 생산까지 엄격한 품질 관리 절차를 시행합니다. 당사는 모든 사용자의 요구에 부합할 수 있는 다양한 제품군을 제공합니다. 원자재, 부품 및 기타 제품에 대한 당사의 재고는 충분하여 귀하께서 주문하신 제품을 정해진 기일 내에 수령하실 수 있도록 보장합니다. 만일 약정된 납기일 내에 납품이 불가능할 경우, 당사는 구매 금액의 2%에서 5% 사이를 고객께 환불해 드릴 것을 약속합니다. 당사 제품의 사용을 돕기 위해 철저한 교육용 동영상 자료를 제공합니다. 또한 귀하의 특정 요구 사항에 맞춘 현장 기술 지도를 당사 기술 담당 직원이 직접 실시해 드릴 수 있으므로, 귀하께서 당사 제품을 자신 있게 그리고 손쉽게 활용하실 수 있습니다. 신뢰성과 고품질 제품, 그리고 뛰어난 고객 서비스를 원하신다면 LSJ를 선택해 주십시오. 저작권 © 베이징 LSJ 테크놀로지 디벨롭먼트 코., 리미티드. 모든 권리 보유
-
개인정보 보호정책
640 x 512 열화상 카메라
640 x 512 열화상 카메라로 환경을 더 선명하게 확인하세요.

640 x 512 열화상 카메라로 핫스팟과 비정상을 찾아보세요.

640 x 512 열화상 카메라로 고품질의 열화상을 생성하세요.

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