&...">
,需要通过父级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);
}
});
})();
Gostou de ler: Explore um Novo Mundo no Seu Dispositivo Android com Esta Incrível Câmera Térmica da Tecnologia LSJ [Guia para Iniciantes] sistema hmi é um tipo de câmera que permite ver o calor ao seu redor. Isso possibilita uma descoberta completa do seu entorno Se você tem uma câmera térmica LSJ Technology no seu Android, é fácil ver quando as coisas estão esquentando ou esfriando. Ela será útil quando você estiver do lado de fora aproveitando o sol em um desses dias quentes de verão, assim como durante uma fria noite de inverno. Você pode monitorar mudanças de temperatura e se preparar para condições meteorológicas adversas usando o painel de toque hmi . Por exemplo, se estiver muito quente lá fora, você pode verificar onde está ocorrendo o ganho de calor. Você também pode saber quando as coisas estão esfriando, o que é útil para saber que um resfriamento estará a caminho LSJ Technology Thermal Photo pode capturar melhores imagens térmicas usando a câmera térmica de um Android. Bem, a câmera é boa como uma ferramenta fotográfica próxima para qualquer tipo de ambiente. A tela sensível ao toque hmi revela onde o calor está atingindo com mais agressividade. Ao monitorar esses pontos na escala e no momento certo, você poderia localizar áreas que precisam de reparo - um vazamento de calor em sua casa pode estar resfriando o interior ou um ponto quente no motor indicando que reparos podem ser necessários. Parece ser como um detetive... juntando pistas para resolver mistérios! Seu ambiente é mais fácil de entender com uma câmera térmica da LSJ Technology. Padrões de calor estranhos podem ser um indicador de um problema maior. Por exemplo: um ponto quente, algo que está fora do normal. sistema de interface homem-máquina ... sinais de um problema elétrico ou equipamentos superaquecendo. Ele ajuda você a identificar os problemas geralmente em estágio inicial e intervir antes que eles se transformem em grandes obstáculos. E como bônus, você até vê o calor de tudo ao redor, o que o torna realmente incrível e bastante interessante. A Visualização dos Padrões de Calor Como Vistos por uma Câmera Térmica em uma Termografia Android da Tecnologia LSJ é o processo de usar uma câmera térmica para localizar calor. Uma ferramenta útil que pode indicar potenciais problemas na sua casa, carro ou qualquer outra coisa na área. E você pode comprar uma câmera cara na porta com um interface de máquina humana de tela sensível ao toque . Você só precisa baixar um aplicativo, e estará pronto para a jornada A LSJ é pioneira no desenvolvimento de equipamentos de alta qualidade para busca e salvamento urbano, compatíveis com câmeras térmicas para Android.
Serviço Pré-Venda: Nossa equipe de especialistas está disponível para ajudá-lo desde o início. Oferecemos consultorias completas para ajudá-lo a compreender suas necessidades específicas e propor soluções personalizadas. Também fornecemos demonstrações de produtos e especificações técnicas detalhadas, de modo que você tenha todas as informações necessárias para tomar uma decisão informada.
Serviço de Vendas: Garantimos que todo o processo de venda seja contínuo e eficiente. Nosso sistema de pedidos eficiente, aliado a rigorosas medidas de controle de qualidade, assegura que seus itens cheguem pontualmente e em perfeitas condições. Oferecemos também entrega porta a porta.
Serviço Pós-Venda: Após a entrega de seus produtos, nossa parceria com você não termina. Prestamos amplo suporte pós-venda, incluindo assistência na instalação, treinamento de usuários, bem como serviços de manutenção e reparo. Nossos representantes de atendimento ao cliente estão prontos para auxiliá-lo em quaisquer dúvidas ou problemas que possam surgir, garantindo sua total satisfação. Após a compra de equipamentos da LSJ, oferecemos garantia de três anos e suporte pós-venda específico. Escolher a LSJ significa optar por confiabilidade, qualidade e um serviço incomparável. Estamos comprometidos em ser seu parceiro em operações de busca e resgate urbano, bem como em combate a incêndios. Atendemos Corpos de Bombeiros, serviços de Segurança Pública, equipes urbanas de busca e salvamento e outros exércitos. A LSJ fornece equipamentos de ponta para combater incêndios, realizar buscas e salvamentos e operar em áreas perigosas em diversos setores. Câmeras térmicas para combate a incêndios. Desenvolvemos e estudamos dois tipos de câmeras térmicas com três resoluções diferentes. Elas conseguem monitorar temperaturas de até 2000 graus Celsius. Equipamentos para Busca e Salvamento: Nossa linha inclui detectores de vida por radar, câmeras térmicas para Android capazes de enxergar através de paredes, monitores de estabilidade, sistemas de monitoramento de movimento, bem como detectores de gás. Câmeras Térmicas Industriais: A LSJ oferece câmeras térmicas que não são utilizadas exclusivamente no combate a incêndios, mas também em inspeções prediais, reparos eletrônicos, detecção de vazamentos de água e inspeção de sistemas de climatização (HVAC). Miras Térmicas e Miras de Visão Noturna: Nossas miras de visão noturna são ideais para a visibilidade noturna e são muito populares entre caçadores. São facilmente adaptáveis a rifles. A LSJ oferece equipamentos térmicos de alta qualidade para resgate e imagens, capazes de atender às necessidades de diferentes setores, aumentando a eficiência e a segurança. A LSJ é sinônimo das soluções mais seguras e inovadoras. Confie na LSJ como seu principal parceiro nas operações de busca e salvamento em áreas urbanas. Desde 2013, a LSJ desenvolve, fabrica e fornece câmeras térmicas para Android de alto desempenho destinadas a equipamentos para busca e salvamento e para bombeiros. A LSJ recebeu certificações ISO 9001, CE e RoHS. A empresa também detém mais de 30 patentes. Estamos investindo pesadamente em nosso departamento de pesquisa e desenvolvimento, pois somos uma empresa líder no setor. Em 2024, a LSJ participou de quatro grandes feiras: INTERSEC, em Dubai; Securika 2024; a 18ª edição da Defence Services Asia (DSA); e a 3ª edição da National Security Asia (NATSEC), na Malásia; além da NFPA, nos Estados Unidos. Também já estamos inscritos na INTERSEC em Dubai, de 14 a 16 de janeiro de 2025. Lá, apresentaremos nosso detector radar em tempo real, um radar 3D capaz de detectar paredes, detectores de gás, equipamentos de escuta de áudio e vídeo, bem como equipamentos de monitoramento de estabilidade e câmeras térmicas para combate a incêndios. Convidamos vocês a visitar nosso estande. A LSJ possui 11 anos de experiência em fabricação. É especialista no desenvolvimento e construção de novos produtos com base nos cenários de uso dos clientes. Além disso, a empresa continua a aprimorar suas capacidades e reduzir os custos dos produtos. A LSJ também possui vasta experiência em busca e salvamento urbano. Por exemplo, durante o terremoto na Turquia em 2023, o radar detector de vida da LSJ desempenhou um papel crucial nos esforços de resgate realizados pela Equipe Chinesa de Resgate Céu Azul. Escolha a LSJ para soluções avançadas e confiáveis, personalizadas conforme suas necessidades. Câmera térmica para Android da LSJ: entendemos a importância de oferecer aos nossos clientes produtos de alta qualidade e um serviço superior. É por isso que oferecemos garantias de um ou cinco anos, refletindo nossa confiança na durabilidade e no desempenho de nossos produtos. Estamos comprometidos com pesquisa e desenvolvimento para assegurar que nossos produtos atendam aos mais elevados padrões. Como fabricante, mantemos um rigoroso controle de qualidade, desde a seleção das matérias-primas até a produção. Seja você um comprador individual, distribuidor, participante de licitação ou mesmo uma entidade governamental, dispomos de uma ampla variedade de produtos que atendem às suas necessidades. Além disso, mantemos um estoque robusto de matérias-primas e outros componentes para garantir a entrega imediata de todos os pedidos. Caso não efetuemos a entrega no prazo combinado, reembolsaremos entre 2% e 5% do valor da compra aos nossos clientes. Para ajudá-lo a utilizar nossos produtos de forma eficiente e extrair o máximo de seu potencial, oferecemos vídeos tutoriais detalhados. Adicionalmente, podemos organizar a presença de nossa equipe técnica no local para treinamento personalizado conforme suas necessidades, assegurando que você consiga operar nossos produtos com confiança e tranquilidade. Escolha a LSJ e desfrute de produtos de alta qualidade, sólidos e de um atendimento ao cliente excepcional. Direitos Autorais © Beijing LSJ Technology Development Co., Ltd. Todos os Direitos Reservados
-
Política de Privacidade
Câmera térmica para android
Mantenha-se atento e preparado para mudanças de temperatura com uma câmera térmica no seu dispositivo Android.

Capture fotos térmicas impressionantes enquanto está em movimento com a câmera térmica embutida no seu Android.

Tenha uma compreensão melhor do seu ambiente e detecte padrões anormais de calor com uma câmera térmica para Android.
Aproveite o poder da termografia com a conveniência de uma câmera térmica para Android.
Why choose LSJ Technology Câmera térmica para android?
Por que a LSJ Pode Ser Sua Fabricante e Fornecedora de Primer?
Um Guia Completo de Equipamentos de Busca e Resgate em Áreas Urbanas e Cadeias de Fornecimento de Equipamentos
Inovando na Fabricação de Equipamentos de Busca e Resgate de Alto Desempenho
Garantindo Qualidade e Entrega Pontual: Compromisso da LSJ com a Satisfação do Cliente
Categorias de produtos relacionados
Não encontrou o que procura?
Solicite uma cotação agora
Entre em contato com nossos consultores para obter mais produtos disponíveis.Entre em Contato