Texas Instruments matrix-gui-2.0 hacking -- index.php

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: Matrix Application Launcher var has_graphics = true; var link_history = ["submenu.
<?php
/*
 * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/ 
 * 
 * 
 *  Redistribution and use in source and binary forms, with or without 
 *  modification, are permitted provided that the following conditions 
 *  are met:
 *
 *    Redistributions of source code must retain the above copyright 
 *    notice, this list of conditions and the following disclaimer.
 *
 *    Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the 
 *    documentation and/or other materials provided with the   
 *    distribution.
 *
 *    Neither the name of Texas Instruments Incorporated nor the names of
 *    its contributors may be used to endorse or promote products derived
 *    from this software without specific prior written permission.
 *
 *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
 *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
 *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 *  A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 
 *  OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 
 *  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 
 *  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 *  DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 *  THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 
 *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 
 *  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
*/
?>

<?php
    # Check if json.txt file needs to be generated
    # 判断json.txt是否存在
    # 这个文件定义了一些数据,如app的名字、图标存放的路径、
    # shell脚本执行的位置及参数等等内容
    if(!file_exists("json.txt"))
    {
        //Generate the json.txt file
        # 为什么这里可以用php?,主要是没看到哪里配置了环境变量
        # 答案好像是因为lighttpd配置文件里配置了php的位置
        # 另外generate.php能够生成json.txt文件
        system("php generate.php");
        //Remove the cache since it is based on the previous json.txt file
        # 删除缓冲文件
        system("rm -rf cache/*");
    }

    if(!file_exists("cache"))
    {
        mkdir("cache",6666);        # 缓冲文件不存在,那么就创建它,并给出相应的权限
    }

    $supportedResolutions = null;
    

    # 这个是保存了屏幕分辨率,以及一屏中有多少行、多少列图标
    if(file_exists("supported_resolutions.txt")==true)
    {
        # 将文件读入一个数组中
        $supportedResolutions = file ("supported_resolutions.txt",FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES);
    }

    # count: 计算数组中的单元数目或对象中的属性个数,对于数组,返回其元素个数
    if($supportedResolutions == null || count($supportedResolutions) == 0)
    {
        echo "supported_resolutions.txt doesn't exist or is empty";
        exit; 
    }

    # SERVER_NAME: 当前运行脚本所在服务器主机的名称
    # REMOTE_ADDR: 正在浏览当前页面用户的IP地址
    $client_is_host = $_SERVER['SERVER_NAME']==$_SERVER['REMOTE_ADDR']||$_SERVER['SERVER_NAME'] == "localhost";
?>

<html>
<head>
<title>Matrix Application Launcher</title>
<meta http-equiv="X-UA-Compatible" content="IE=EDGE" />                         <!-- 添加元信息   -->

<link rel="stylesheet" type="text/css" href="css/fonts-min.css">                <!-- 加载样式     -->
<script type="text/javascript" src="/javascript/jquery-latest.js"></script>     <!-- 加载jquery库 -->
<link rel='stylesheet' type='text/css' href='css/global.css'>                   <!-- 加载样式     -->

</head>


<body class="unselectable" style = "-webkit-user-select: none;-moz-user-select: none;">
<div id = "complete_container"></div>

<script>
var has_graphics = true;
var link_history = ["submenu.php?submenu=main_menu&page=0"];    // 创建历史记录数组
var uri = "submenu.php?submenu=main_menu&page=0";               // 当前需要加载的URI地址
var previous_clicked = uri;                                     // 第一次之前URI的就是现在的

<?php
if($client_is_host == true)
    echo "var client_is_host = true;";          # 自动生成js变量
else
    echo "var client_is_host = false;";
?>

$(document).ready(function()                    // 文档加载完毕时运行该函数 
{
    var supportedResolutions=new Array();       // 创建数组

    <?php
        # 从这里可以知道,$supportedResolutions是前面的PHP里的变量,不是这里js中的
        # supportedResolutions变量,这个一定要分清楚,要不然很难理解
        for($x = 0;$x<count($supportedResolutions);$x++)
        {
            # PHP字符串连接的方式很简单,只需要一个(.)就能实现
            echo "supportedResolutions[".$x."]=\"".$supportedResolutions[$x]."\";";    
        }
    ?>

    var screenWidth = 0;                    // 屏幕宽 
    var screenHeight = 0;                   // 屏幕高
    var iconGridCol = 0;                    // 图标格点列数
    var iconGridRow = 0;                    // 图标格点行数

    // 这里大致意思是取一个合适的尺寸来分配桌面
    for(var i=0; i<supportedResolutions.length; i++) 
    {
        // 是用字符串x字符将字符串切分,x在字符串里的含义是乘,如800x600x4x3
        var value = supportedResolutions[i].split('x');    

        screenWidth = value[0];
        screenHeight = value[1];
        iconGridCol = value[2];
        iconGridRow = value[3];

        if(screen.width >= screenWidth && screen.height >= screenHeight)
            break;
    }

    document.cookie="iconGridCol="+iconGridCol;         // 通过js创建cookie
    document.cookie="iconGridRow="+iconGridRow;
    
    // 加载对应尺寸的css样式,这样使得显示更合理
    $('head').append('<link rel="stylesheet" type="text/css" href="css/'+screenWidth+'x'+screenHeight+'.css" />'); 
    //alert("screenHeight:"+screenWidth+"\n"+"screenWidth:"+screenHeight);

    // 本地的Qt程序是无法进行远程传输的,所以会有这个判断
    if(client_is_host==false)
    {
        var r=confirm("Does your target system have an attached display device?\nClick Ok and Remote Matrix will assume that a proper display device is attached to your target system.\nClick Cancel and Remote Matrix will assume that you do not have a display device attached to your target system.");
        if (r==true)
            has_graphics = true;
        else
            has_graphics = false;
    }

    // var uri = "submenu.php?submenu=main_menu&page=0";
    // var link_history = ["submenu.php?submenu=main_menu&page=0"];
    // 加载显示的html文件,放在complete_container div中
    $.get(uri, function(data) 
    {
        $('#complete_container').html(data);
        //其实这里的-2没搞清楚,不知道为什么要用这么写
        $("#back_link").attr("href",link_history[link_history.length-2]);
    });


});

// delegate()方法为指定的元素添加一个或多个事件处理程序, // 并规定当这些事件发生时运行的函数
$("#complete_container").delegate("img", "mousedown", function(e)
{
    // preventDefault()方法阻止元素发生默认的行为
    // 例如: 当点击提交按钮时阻止表单的提交
    e.preventDefault();
});

// 制定complete_container中的a标签的click事件的运行方式
$("#complete_container").delegate("a", "click", function(e)
{
    e.preventDefault();
    // 防止事件冒泡到DOM树上,也就是不触发任何前辈元素上的事件处理函数
    e.stopPropagation();
    var className = $(this).attr('class');      // 获取对应的属性
    var idName = $(this).attr('id');
    var link =  $(this).attr('href');

    //Sometimes if a request is taking a long time you might try clicking a link more then once thinking that
    //your click request was not accepted. This causes multiple request for the same page to be sent which in turn
    //sometimes results in every link you click causing 2+ request to go through. This code checks to make sure
    //your requesting a new pageand not the same page twice
    if(link==previous_clicked)                  // 防止连续点击两次,也就是避免同一个应用连续运行2次
        return false;

    previous_clicked = link;                    // 将当前连接看作是上一次的链接

    if(idName=="back_link")                     // 返回上一次链接
    {
        link_history.pop();                     // 从堆栈中弹出最后的一次链接
    }
    else if(idName=="main_menu_link")           // 转到主页
    {
        link_history = ["submenu.php?submenu=main_menu&page=0"];
    }
    else
        link_history.push(link);                // 将当前的链接加入堆栈

    //Adds a random string to the end of the $_GET Query String for page accessed.
    //This prevents IE from caching the Ajax request.
    link = link + "&rand="+Math.round((Math.random()*2356))+Math.round((Math.random()*4321))+Math.round((Math.random()*3961));
    $.get(link, function(data) 
    {
        $('#complete_container').html(data);            // 往div里添加另一个网页内容
        $("#back_link").attr("href",link_history[link_history.length-2]);
    });        
});

</script>

    </body>
</html>

 

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
2月前
|
前端开发 关系型数据库 MySQL
PHP与MySQL动态网站开发实战指南####
【10月更文挑战第21天】 本文将深入浅出地探讨如何使用PHP与MySQL构建一个动态网站,从环境搭建到项目部署,全程实战演示。无论你是编程新手还是希望巩固Web开发技能的老手,都能在这篇文章中找到实用的技巧和启发。我们将一起探索如何通过PHP处理用户请求,利用MySQL存储数据,并最终呈现动态内容给用户,打造属于自己的在线平台。 ####
64 0
|
1月前
|
存储 关系型数据库 MySQL
PHP与MySQL动态网站开发:从基础到实践####
本文将深入探讨PHP与MySQL的结合使用,展示如何构建一个动态网站。通过一系列实例和代码片段,我们将逐步了解数据库连接、数据操作、用户输入处理及安全防护等关键技术点。无论您是初学者还是有经验的开发者,都能从中获益匪浅。 ####
|
2月前
|
安全 关系型数据库 MySQL
PHP与MySQL动态网站开发实战指南####
——深入探索LAMP栈下的高效数据交互与处理技巧 ####
|
1月前
|
关系型数据库 MySQL PHP
php实现一个简单的MySQL分页
通过本文的详细步骤和代码示例,我们实现了一个简单的PHP MySQL分页功能。主要步骤包括计算总记录数、设置分页参数、查询当前页的数据以及生成分页链接。这种分页方式适用于大多数Web应用,能够有效提升用户体验和页面响应速度。
30 4
|
2月前
|
关系型数据库 MySQL PHP
PHP与MySQL动态网站开发实战指南####
深入探索PHP与MySQL的协同工作机制,本文旨在通过一系列实战案例,揭示构建高效、稳定且用户友好的动态网站的秘诀。从环境搭建到数据交互,再到最佳实践分享,本文为开发者提供了一条清晰的学习路径,助力其在LAMP(Linux, Apache, MySQL, PHP/Perl/Python)栈上实现技术飞跃。 ####