Void-voiD

Untitled

Aug 2nd, 2020
195
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. let gl, canvas, current_molecula;
  2.  
  3. const start = () => {
  4.     canvas = document.getElementById("glcanvas");
  5.    
  6.     gl = initWebGL(canvas);      // инициализация контекста GL
  7.    
  8.     // продолжать только если WebGL доступен и работает
  9.    
  10.     if (gl) {
  11.         gl.clearColor(0.0, 0.0, 0.0, 1.0);                      // установить в качестве цвета очистки буфера цвета черный, полная непрозрачность
  12.         gl.enable(gl.DEPTH_TEST);                               // включает использование буфера глубины
  13.         gl.depthFunc(gl.LEQUAL);                                // определяет работу буфера глубины: более ближние объекты перекрывают дальние
  14.         gl.clear(gl.COLOR_BUFFER_BIT|gl.DEPTH_BUFFER_BIT);      // очистить буфер цвета и буфер глубины.
  15.     }
  16. }
  17.  
  18. const initWebGL = (canvas) => {
  19.     gl = null;
  20.    
  21.     try {
  22.         // Попытаться получить стандартный контекст. Если не получится, попробовать получить экспериментальный.
  23.         gl = canvas.getContext("webgl") || canvas.getContext("experimental-webgl");
  24.     }
  25.       catch(e) {}
  26.      
  27.         // Если мы не получили контекст GL, завершить работу
  28.           if (!gl) {
  29.               alert("Unable to initialize WebGL. Your browser may not support it.");
  30.               gl = null;
  31.           }
  32.          
  33.             return gl;
  34. }
  35.  
  36. // функция вызывается в случае ввода текста в поле для идентификации молекулы
  37. const getMolecula = () => {
  38.     let text = document.getElementById("searchbox").value;
  39.     if (text) {
  40.         // alert(text)
  41.         current_molecula = text;
  42.        
  43.        
  44.         //Обращение к серверу
  45.         const status = (response) => {
  46.             if (response.status !== 200) {
  47.                 return Promise.reject(new Error(response.statusText))
  48.             }
  49.                         return Promise.resolve(response)
  50.         }
  51.         const json = (response) => {
  52.             return response.json()
  53.         }
  54.         let link = "https://pubchem.ncbi.nlm.nih.gov/rest/pug/compound/fastformula/" + current_molecula + "/JSON";
  55.        
  56.         const timeout = (ms, promise) => {
  57.             return new Promise(function(resolve, reject){
  58.                 setTimeout(function(){
  59.                     reject(new Error("timeout"))
  60.                 }, ms)
  61.                 promise.then(resolve, reject)
  62.             })
  63.         }
  64.         //Скачивание по ссылке
  65.        
  66.         timeout(50000, fetch(link, {timeout: 500000}).then(status).then(json).
  67.         then(function (data) {
  68.             alert(data)
  69.         }).catch(function (error) {
  70.             alert(error)
  71.         }));
  72.     }
  73. }  
Add Comment
Please, Sign In to add comment