在Android应用开发中,集成百度地图API是一项常见的需求,它能为用户提供丰富的地图服务功能,如定位、导航、路线规划等。
本篇文章将详细介绍如何在Android项目中进行百度地图的开发,以及一些关键的技术点。
我们需要在百度地图开放平台(http://lbsyun.baidu.com/)注册账号并创建应用,获取API密钥。
这个API密钥是连接我们应用与百度地图服务的关键,确保了应用的合法性。
完成注册后,根据应用的包名和签名信息生成相应的密钥,并在项目中正确配置。
接下来,我们将在AndroidManifest.xml文件中添加必要的权限。
包括访问网络、读写外部存储、获取地理位置等,例如:```xml<uses-permission android:name="android.permission.INTERNET" /><uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /><uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />```同时,添加百度地图SDK所需的库依赖:```xml<meta-data android:name="com.baidu.lbsapi.API_KEY" android:value="你的API_KEY" />```然后,在布局文件中加入MapView组件,这是显示百度地图的核心组件:```xml<com.baidu.mapapi.map.MapView android:id="@+id/bmapView" android:layout_width="match_parent" android:layout_height="match_parent" android:clickable="true" />```在Activity或Fragment中初始化MapView,并设置地图的显示样式和级别:```javaMapView mapView = findViewById(R.id.bmapView);BaiduMap baiduMap = mapView.getMap();baiduMap.setMapType(BaiduMap.MAP_TYPE_NORMAL); // 设置为普通地图baiduMap.setZoom(15); // 设置地图缩放级别```为了让应用能够获取用户的位置信息,我们需要开启定位服务:```javaLocationClient locationClient = new LocationClient(this);locationClient.registerListener(new MyLocationListener()); // 自定义监听器locationClient.start(); // 开启定位```编写`MyLocationListener`类,重写`onReceiveLocation`方法,接收定位结果:```javapublic class MyLocationListener implements BDLocationListener { @Override public void onReceiveLocation(BDLocation location) { if (location != null) { // 使用获得的经纬度设置地图中心点 LatLng myLocation = new LatLng(location.getLatitude(), location.getLongitude()); MapStatusUpdate update = MapStatusUpdateFactory.newLatLng(myLocation); baiduMap.setMapStatus(update); } }}```为了给用户提供更丰富的地图交互体验,可以添加覆盖物(Overlay)、信息窗口(InfoWindow)等功能。
例如,自定义一个Marker来表示用户当前位置:```javaOverlayOptions markerOption = new MarkerOptions() .position(myLocation) .icon(BitmapDescriptorFactory.fromResource(R.drawable.marker));baiduMap.addOverlay(markerOption);```此外,还可以通过百度地图API实现路线规划,比如驾车、步行、公交等。
调用`DrivingRoutePlanOption`、`WalkingRou
2025/6/15 22:19:09 5.65MB
1

在IT行业中,ZTree是一款广泛应用于Web开发的前端插件,尤其在文件管理、权限控制等领域,它提供了强大的树形展示功能。
标题提到的“ztree的使用”着重于介绍如何在项目中集成和操作ZTree。
由于描述中提到了项目基于SSH(Spring、Struts2、Hibernate)框架,我们可以推测这是一个Java Web项目,ZTree在此类项目中常用于后台数据的前端展示。
ZTree的基础概念需要理解。
ZTree是一个基于jQuery的插件,它可以将静态或动态的数据结构渲染成交互式的树形视图。
它的主要特点包括节点的多级展示、可选的异步加载、丰富的事件机制以及自定义的节点样式和图标。
在SSH框架中使用ZTree,首先你需要在项目中引入ZTree的CSS和JavaScript文件。
这些文件通常可以从ZTree的官方网站下载,包含所需的样式表和脚本。
然后,在HTML页面中引入这些资源,并设置一个div元素作为ZTree的容器。
接下来,你需要准备ZTree的数据源。
在基于SSH的项目中,数据通常通过Ajax请求从后端获取。
数据格式应遵循ZTree的规范,一般为JSON格式,包含节点ID、父节点ID、节点文本等关键信息。
例如:```json[ { "id": "1", "pId": "0", "name": "父节点1" }, { "id": "1_1", "pId": "1", "name": "子节点1_1" }, { "id": "1_2", "pId": "1", "name": "子节点1_2" }]```在JavaScript中,你可以使用$.fn.zTree.init方法初始化ZTree,传入刚才创建的容器div和数据源。
同时,你还需要配置ZTree的参数,如是否启用异步加载、节点展开方式、是否允许拖拽等。
例如:```javascriptvar setting = { async: { enable: true, url: yourAjaxUrl, autoParam: [id], otherParam: {type: typeValue} }, data: { simpleData: { enable: true } }};var zNodes = []; // 前面准备的JSON数据$.fn.zTree.init($("#treeDemo"), setting, zNodes);```ZTree还提供了丰富的事件监听,如onClick、onDblClick等,你可以根据需要绑定相应的处理函数来实现节点点击后的业务逻辑。
例如:```javascriptvar treeObj = $.fn.zTree.getZTreeObj("treeDemo");treeObj.bind("onClick", function(event, treeId, treeNode) { console.log(点击了节点:, treeNode.id);});```此外,ZTree支持动态加载和异步数据获取,这对于大型数据集非常有用。
你可以通过配置async参数来开启异步加载,并指定获取数据的URL。
当用户展开节点时,ZTree会自动发送请求获取子节点数据。
“ztree的使用”涵盖了前端展示、后端数据交互、事件处理等多个方面。
理解ZTree的工作原理和配置选项,能够帮助你在SSH项目中构建出高效、交互性强的树形界面。
通过不断实践和优化,ZTree可以成为项目中不可或缺的一部分,提升用户体验并简化后台数据管理。
2025/6/15 22:18:37 17KB
1
简介:
ExtJS是一种基于JavaScript的前端开发框架,用于构建富客户端应用。
它提供了丰富的组件库,包括TreePanel和GridPanel,这两个组件在数据展示和管理中扮演着重要角色。
TreePanel是ExtJS中的一个树形控件,它允许你展示层级结构的数据。
在教程中,你可能会学到如何创建和配置TreePanel,包括加载数据、设置节点图标、处理节点的展开和折叠事件,以及添加拖放功能。
TreePanel通常用于展现文件系统、组织架构或层级关系的数据。
GridPanel则是ExtJS中的表格视图组件,它可以展示大量的数据,并提供排序、筛选、分页等功能。
在集成TreePanel和GridPanel时,可能涉及到的概念有:将TreePanel的节点与GridPanel的数据关联,实现点击树节点时动态加载或更新GridPanel的数据,以及可能的父子数据联动操作。
在实际应用中,你可能会学习到以下关键点:1. 创建TreePanel:定义树节点的数据源,配置列显示,设置树的样式和交互行为。
2. 创建GridPanel:定义Grid的数据模型,设置列配置,添加行操作和列筛选。
3. 数据绑定:通过store将TreePanel和GridPanel连接起来,使得选择树节点可以动态改变Grid的数据。
4. 事件监听:添加事件监听器来响应用户的操作,比如节点点击、数据加载等。
5. 动态加载:当用户点击TreePanel的节点时,根据节点ID或属性动态加载对应的Grid数据。
6. 用户交互:实现拖放功能,允许用户通过拖动TreePanel的节点来调整结构,或者拖放到GridPanel中进行操作。
在"我自己写的Extjs入门教程"这个压缩包中,可能包含的文件可能有HTML示例文件、JavaScript代码文件、CSS样式文件,甚至可能有图片资源。
这些文件将帮助你理解并实践教程中的每个步骤,通过阅读和修改代码,你可以深入理解ExtJS的组件用法和数据交互机制。
在学习过程中,理解ExtJS的MVC(Model-View-Controller)架构至关重要,因为TreePanel和GridPanel都是View部分,它们的数据源(Model)和控制器(Controller)是实现功能的关键。
同时,熟悉JSON格式数据的处理也是必要的,因为ExtJS通常使用JSON来传递和存储数据。
这门入门教程将带你进入ExtJS的世界,通过TreePanel和GridPanel的实践,你将掌握基本的组件使用和数据管理技巧,为构建更复杂的企业级应用打下基础。
记得在实践中不断探索和实验,理论结合实际,才能真正掌握这些知识。
2025/6/15 19:57:15 739KB
1
简介:
slickerPicker(测试版) 一个使用Vanilla Javascript制作的简单快速的颜色选择器插件设置插件包括slickerPicker.js和slickerPicker.css < script type = "text/javascript" src = "slickerPicker.js" > < / script >< link rel = "stylesheet" href = "slickerPicker.css" > 实例化slickerPicker。
slickerPicker将仅接受选项对象的1个参数您必须包括要将选择器附加到的元素的目标ID。
new slickerPicker ( { target : "target" } ) ;
2025/6/15 19:51:31 14KB
1
简介:
在本文中,我们将深入探讨如何使用Qt框架与Video for Linux 2(V4L2)接口相结合,实现在Linux系统上显示摄像头视频流。
V4L2是Linux内核提供的一种标准接口,用于与视频捕获设备(如摄像头)进行交互,而Qt则是一个跨平台的C++图形用户界面应用程序开发框架。
我们需要了解V4L2的基本概念。
V4L2是V4L(Video4Linux)的升级版,提供了更多的功能,包括对多种视频格式的支持、多设备并发访问以及高级缓冲区管理。
它通过/dev/videoX设备节点与摄像头通信,X为设备编号。
接下来,我们要引入Qt。
Qt库提供了一套完整的图形用户界面工具,包括窗口、控件、布局等,以及多媒体模块(QMultimedia),可以方便地处理音频和视频数据。
在Qt中,我们可以通过QCamera类来操作摄像头,并使用QCameraViewfinder或QVideoWidget来显示视频流。
实现"v4l2摄像头显示视频流"的关键步骤如下:1. **初始化Qt环境**:确保系统已安装Qt库,然后创建一个Qt项目,选择合适的Qt版本和构建系统。
2. **导入相关模块**:在代码中导入必要的Qt模块,如`<QtWidgets>`(用于窗口和控件)、`<QCamera>`(摄像头操作)和`<QCameraViewfinder>`(显示视频流)。
3. **创建QCamera对象**:使用QCamera类创建一个摄像头对象,传入设备ID(通常是"/dev/video0")作为参数。
例如: ```cpp QCamera camera(new QCamera("/dev/video0", this)); ``` 如果需要检测可用摄像头,可以使用`QCameraInfo`类列出所有设备。
4. **设置视频源**:V4L2摄像头作为视频源,可以通过设置`QCamera::setCaptureDevice`方法来实现: ```cpp camera.setCaptureDevice(QCamera::CaptureDevice::DeviceType, "video0"); ```5. **启动相机**:在确保设置正确后,启动相机: ```cpp camera.start(); ```6. **显示视频流**:创建一个`QCameraViewfinder`实例并将其设置为相机的视图finder,然后将视图finder添加到窗口布局中: ```cpp QCameraViewfinder *viewfinder = new QCameraViewfinder(this); camera.setViewfinder(viewfinder); layout->addWidget(viewfinder); // 假设layout是窗口的布局 ```7. **处理错误和状态改变**:为QCamera对象添加信号连接,以便在出现错误或状态改变时进行相应的处理。
8. **关闭相机**:在应用退出或不再需要视频流时,记得停止并释放相机资源: ```cpp camera.stop(); delete camera; ```以上就是使用Qt结合V4L2显示摄像头视频流的基本步骤。
实际应用中可能还需要处理分辨率设置、帧率控制、色彩格式转换等更复杂的细节。
同时,为了保证兼容性和稳定性,可能需要针对不同的硬件和驱动进行适配。
此外,还可以利用QMediaPlayer和QVideoSurfaceFormat等类来实现自定义的视频播放器功能。
通过这些知识,开发者可以构建出功能丰富的摄像头应用,不仅限于简单的视频显示,还能进行录像、图像处理等多种功能。
对于嵌入式系统或者需要在Linux环境下处理摄像头数据的应用来说,Qt结合V4L2是一个高效且灵活的选择。
2025/6/15 19:50:07 12KB
1
简介:
### CAS单点登录服务器配置详解#### 一、CAS单点登录概述CAS(Central Authentication Service)是一种开放源代码的单点登录协议和服务框架,它为Web应用提供了一种简化了的身份验证流程。
通过CAS,用户只需要在一个地方完成登录过程,即可在多个应用间共享登录状态,无需重复登录。
#### 二、CAS服务器安装与配置##### 2.1 安装CAS服务端1. **下载CAS服务端**:首先从官方网址http://www.cas.org/下载最新的CAS服务端压缩包。
2. **部署WAR包**:将下载的WAR包复制到Tomcat的webapps目录下,并将其重命名为`cas.war`。
3. **启动Tomcat**:启动Tomcat服务器,自动解压WAR包,此时会在Tomcat的webapps目录下生成一个名为`cas`的文件夹。
4. **访问CAS**:通过浏览器访问`http://localhost:8896/cas`来测试CAS服务是否正常启动。
##### 2.2 配置CAS使用数据库验证为了实现更安全、更灵活的身份验证机制,我们可以配置CAS使用数据库进行用户身份验证。
具体步骤如下:1. **修改部署配置文件**:打开`cas-server-webapp\WEB-INF\deployerConfigContext.xml`文件,找到`SimpleTestUsernamePasswordAuthenticationHandler`配置项,将其替换为`QueryDatabaseAuthenticationHandler`。
```xml <bean id="authenticationHandler" class="org.jasig.cas.authentication.handler.QueryDatabaseAuthenticationHandler"> <!-- 数据库连接数据源 --> <property name="dataSource" ref="dataSource"/> <!-- 查询语句 --> <property name="sql" value="SELECT password FROM users WHERE username = ?"/> <!-- 密码加密方式 --> <property name="passwordEncoder" ref="passwordEncoder"/> </bean> ```2. **配置数据库连接**:在同一文件中添加一个新的`dataSource` bean来定义数据库连接信息。
```xml <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/casdb"/> <property name="username" value="casuser"/> <property name="password" value="password"/> </bean> ```3. **配置密码加密方式**:继续在同一文件中添加`passwordEncoder` bean来指定密码加密方式,这里使用MD5作为示例。
```xml <bean id="passwordEncoder" class="org.springframework.security.crypto.password.StandardPasswordEncoder"> <constructor-arg value="MD5"/> </bean> ```4. **测试数据库验证**:重启Tomcat服务器,访问CAS服务器页面,使用数据库中的用户名和密码尝试登录,验证是否可以成功登录。
#### 三、CAS工作原理CAS的工作原理主要分为以下几个步骤:1. **用户访问服务**:用户首次访问受保护的资源时,CAS客户端会检测到HTTP请求中缺少ServiceTicket(简称ST),表明用户尚未经过身份验证。
2. **重定向至CAS服务器**:CAS客户端会将用户重定向到CAS服务器进行身份验证,并携带用户的请求URL作为参数(service参数)。
3. **用户认证**:CAS服务器接收到来自用户的认证请求后,引导用户进入登录页面。
用户输入用户名和密码进行登录,若身份验证成功,则CAS服务器通过HTTPS协议返回一个TGC(Ticket-Granting Cookie)给浏览器。
4. **发放ServiceTicket**:CAS服务器生成一个随机的ServiceTicket(简称ST),并将用户重定向回CAS客户端。
5. **验证ServiceTicket**:CAS客户端收到ST后,向CAS服务器验证ST的有效性。
如果验证通过,则允许用户访问受保护资源。
6. **传输用户信息**:CAS服务器验证ST通过后,将用户的相关认证信息发送给CAS客户端。
通过以上步骤,CAS实现了单点登录的功能,极大地提升了用户体验和系统的安全性。
### 四、CAS与HTTPS在配置CAS服务器时,可以选择使用HTTPS协议来增强通信的安全性。
如果选择HTTPS协议,则需要在服务器上配置CAS证书。
证书的创建和导入过程可以参考以下链接:[http://m.blog..net/zrk1000/article/details/51166603](http://m.blog..net/zrk1000/article/details/51166603)### 总结本文详细介绍了如何配置CAS单点登录服务,并重点讲解了如何利用Java代码实现CAS的配置,包括使用数据库进行登录验证的具体步骤。
同时,还阐述了CAS的基本工作原理,帮助读者更好地理解CAS的工作流程和技术细节。
2025/6/15 19:47:19 293KB
1
全国手机号码段归属地数据库(共360569条记录)测试过可以。
想不要资源分的,但是没有这个选项。
该数据库共包含360569条记录,涵盖了最新的170和171号段,可满足几乎所有的手机号码的归属地查询。
数据文件的格式有两种:txt文件和sql文件,字符编码为utf8。
mysql中创建数据表:CREATETABLE`mobile`(`id`mediumint(8)unsignedNOTNULLAUTO_INCREMENTCOMMENT'主键',`phone`char(9)NOTNULLDEFAULT''COMMENT'手机号码段',`province`char(10)NOTNULLDEFAULT''COMMENT'省份',`city`char(10)NOTNULLDEFAULT''COMMENT'市',`service_provider`char(10)NOTNULLDEFAULT''COMMENT'运营商',`city_code`char(9)NOTNULLDEFAULT''COMMENT'区号',`postcode`char(9)NOTNULLDEFAULT''COMMENT'邮编',PRIMARYKEY(`id`),UNIQUEKEY`phone`(`phone`))ENGINE=InnoDBDEFAULTCHARSET=utf8COMMENT='全国手机号码段归属地';
2025/6/15 15:22:23 2.63MB 手机号归属地
1
版本修改记录:V2.2.0.2修改:修改了HttpPost相对路径的一些问题。
V2.2.0.0增加:[id(0x00010041),helpstring("GetRevIndex")]HRESULTGetRevCount([out,retval]long*pbool);[id(0x00010042),helpstring("GetRevIndexInfo")]HRESULTGetRevInfo([in]longlIndex,[in]longlType,[out,retval]BSTR*pbool);[id(0x00010043),helpstring("SetDocProp")]HRESULTSetValue([in]BSTRstrValue,[in]BSTRstrName,[out,retval]long*pbool);[id(0x00010044),helpstring("SetDocVariable")]HRESULTSetDocVariable([in]BSTRstrVarName,[in]BSTRstrValue,[in]longlOpt,[out,retval]long*pbool);[id(0x00010045),helpstring("SavepageToDoc")]HRESULTSetPageAs([in]BSTRstrLocalFile,[in]longlPageNum,[in]longlType,[out,retval]long*pbool);----------------------------------------------------------------------------------------------------------------------------------------------------------------------LoadDso.jsvars=""s+=""s+=""document.write(s)----------------------------------------------------------------------------------------------------------------------------------------------------------------------接口文档:/*1.新建*///新建Worddocument.all.FramerControl1.CreateNew("Word.Document");//新建Exceldocument.all.FramerControl1.CreateNew("Excel.Sheet");/*2.打开文件*///打开制定的本地文件document.all.FramerControl1.Open("C:\\TestBook.xls");//制定用Word来打开c:\plain.txt文件document.all.FramerControl1.Open("C:\\Plain.txt",false,"Word.Document");//打开服务器的文件document.all.FramerControl1.Open"https://secureserver/test/mytest.asp?id=123",true,"Excel.Sheet","MyUserAccount","MyPassword");//打开服务器的文件document.all.FramerControl1.Open("http://localhost/1.doc",true);/*3.保存文件*///到本地document.all.FramerControl1.Save("c:\\1.doc",true);//服务器/*增加Http协议Post上传接口,可以Post一个动态页面(jsp,asp,php...),由动态页面负责解析数据boolHttpInit();boolHttpAddPostString(BSTRstrName,BSTRstrValue);boolHttpAddPostCurrFile(BSTRstrFileID,BSTRstrFileName);BSTRHttpPost(BSTRbstr);*///初始化Http引擎document.all.FramerControl1.HttpInit();//增加Post变量document.all.FramerControl1.HttpAddPostString("RecordID","20060102200");document.all.FramerControl1.HttpAddPostString("UserID","李局长");//上传打开的文件document.all.FramerControl1.HttpAddPostCurrFile("FileData","文档名.doc");//执行上传动作document.all.FramerControl1.HttpPost("http://xxxx.com/uploadfile.asp");/*4.修订留痕*///进入留痕状态document.all.FramerControl1.SetTrackRevisions(1);//进入非留痕状态document.all.FramerControl1.SetTrackRevisions(0);//接受当前修订document.all.FramerControl1.SetTrackRevisions(4);/*5.设置当前用户*/document.all.FramerControl1.SetCurrUserName("张三");/*6.设置当前时间(笔迹留痕会显示("Like2006:02:0711:11:11")*/document.all.FramerControl1.SetCurrTime("2006:02:0711:11:11");/*7.设置和创建书签,此功能比较强大,设置书签数据、添加书签和添加红头文件就靠他了SetFieldValue(BSTRstrFieldName,BSTRstrValue,BSTRstrCmdOrSheetName)strFieldName:书签名strValue:要设置的值strCmdOrSheetName:命令::ADDMARK::添加BookMark::DELMARK::删除这个BookMark::GETMARK::定位到这个BookMark::FILE::插入的是文件::JPG::插入的是图片一般来说:WORD中书签是做好的,可以通过此接口把外界数据设置进书签中去。
*///在当前WORD位置插入标签,标签名为"book1",数值为"test"document.all.FramerControl1.SetFieldValue("book1","test","::ADDMARK::");//设置书签"Time",数值为"2006-03-1622:22:22"document.all.FramerControl1.SetFieldValue("Time","2006-03-1622:22:22","");//在书签位置"hongtou",插入红头文件"http://222.222.222.222/hongtou1.doc"这样,红头就自动插进去了document.all.FramerControl1.SetFieldValue("hongtou","http://222.222.222.222/hongtou1.doc","::FILE::");/*8.设置菜单显示情况BOOLSetMenuDisplay(longlMenuFlag)lMenuFlag为以下数值的组合#defineMNU_NEW0x01#defineMNU_OPEN0x02#defineMNU_CLOSE0x04#defineMNU_SAVE0x08#defineMNU_SAVEAS0x16#defineMNU_PGSETUP0x64#defineMNU_PRINT0x256#defineMNU_PROPS0x32#defineMNU_PRINTPV0x126*///只有“新建”菜单可用document.all.FramerControl1..SetMenuDisplay(1);//只有“打开”菜单可用document.all.FramerControl1.SetMenuDisplay(2);//只有“打开”和“新建”菜单可用document.all.FramerControl1.SetMenuDisplay(3);/*9.保护文档和解保护文档lProOrUn:1:保护文档;
0:解除保护lProType:wdNoProtection=-1,wdAllowOnlyRevisions=0,wdAllowOnlyComments=1,wdAllowOnlyFormFields=2strProPWD:密码*///完全保护文档,密码为"pwd"document.all.FramerControl1.ProtectDoc(1,1,"pwd");//解除文档保护document.all.FramerControl1.ProtectDoc(0,1,"pwd");/*10.显示或隐藏修订内容ShowRevisions(longnNewValue)nNewValue=0则隐藏修订=1则显示修订*///显示修订留痕document.all.FramerControl1.ShowRevisions(1);//隐藏修订留痕document.all.FramerControl1.ShowRevisions(0);/*11.插入合并文件,strFieldPath文件路径,可以是http,ftp的路径pPos=0//当前鼠标位置1;文件开头2;文件末尾pPos的第4位为1的时候,代表插入的是图片InSertFile(BSTRstrFieldPath,longlPos)*///文件头部插入文件document.all.FramerControl1.InSertFile("http://XX.com/XX.doc",1);//文件尾部插入文件document.all.FramerControl1.InSertFile("http://XX.com/XX.doc",2);//当前光标位置插入文件document.all.FramerControl1.InSertFile("http://XX.com/XX.doc",0);//文件头部插入图片document.all.FramerControl1.InSertFile("http://XX.com/XX.jpg",9);//文件尾部插入图片document.all.FramerControl1.InSertFile("http://XX.com/XX.jpg",10);//当前光标位置插入图片document.all.FramerControl1.InSertFile("http://XX.com/XX.jpg",8);/*0x31.文档另存为HRESULTSaveAs([in]VARIANTstrFileName,[in]VARIANTdwFileFormat,[out,retval]long*pbool);参数:strFileName:文件本地路径,如c:\\11.docdwFileFormat:文件格式dwFileFormat的数值为:Excel:TypeenumXlFileFormat{xlAddIn=18,xlCSV=6,xlCSVMac=22,xlCSVMSDOS=24,xlCSVWindows=23,xlDBF2=7,xlDBF3=8,xlDBF4=11,xlDIF=9,xlExcel2=16,xlExcel2FarEast=27,xlExcel3=29,xlExcel4=33,xlExcel5=39,xlExcel7=39,xlExcel9795=43,xlExcel4Workbook=35,xlIntlAddIn=26,xlIntlMacro=25,xlWorkbookNormal=-4143,xlSYLK=2,xlTemplate=17,xlCurrentPlatformText=-4158,xlTextMac=19,xlTextMSDOS=21,xlTextPrinter=36,xlTextWindows=20,xlWJ2WD1=14,xlWK1=5,xlWK1ALL=31,xlWK1FMT=30,xlWK3=15,xlWK4=38,xlWK3FM3=32,xlWKS=4,xlWorks2FarEast=28,xlWQ1=34,xlWJ3=40,xlWJ3FJ3=41,xlUnicodeText=42,xlHtml=44};Word:TypeenumWdSaveFormat{wdFormatDocument=0,wdFormatTemplate=1,wdFormatText=2,wdFormatTextLineBreaks=3,wdFormatDOSText=4,wdFormatDOSTextLineBreaks=5,wdFormatRTF=6,wdFormatUnicodeText=7,wdFormatEncodedText=7,wdFormatHTML=8};PPT:enumPpSaveAsFileType{ppSaveAsPresentation=1,ppSaveAsPowerPoint7=2,ppSaveAsPowerPoint4=3,ppSaveAsPowerPoint3=4,ppSaveAsTemplate=5,ppSaveAsRTF=6,ppSaveAsShow=7,ppSaveAsAddIn=8,ppSaveAsPowerPoint4FarEast=10,ppSaveAsDefault=11,ppSaveAsHTML=12,ppSaveAsHTMLv3=13,ppSaveAsHTMLDual=14,ppSaveAsMetaFile=15,ppSaveAsGIF=16,ppSaveAsJPG=17,ppSaveAsPNG=18,ppSaveAsBMP=19};*//*0x32.删除本地文件HRESULTDeleteLocalFile([in]BSTRstrFilePath);参数:strFileName:文件本地路径,如c:\\11.doc*//*0x33.创建临时文件HRESULTGetTempFilePath([out,retval]BSTR*strValue);返回:临时文件的路径地址。
使用完后,用DeleteLocalFile删除*//*0x34.设置文档显示模式HRESULTShowView([in]longdwViewType,[out,retval]long*pbool);dwViewType的可取值为:enumWdViewType{wdNormalView=1,wdOutlineView=2,wdPrintView=3,wdPrintPreview=4,wdMasterView=5,//这个是大纲wdWebView=6};*///大纲模式document.all.FramerControl1.ShowView(5);/*0x39:下载远程文件HRESULTDownloadFile([in]BSTRstrRemoteFile,[in]BSTRstrLocalFile,[out,retval]BSTR*strValue);参数:strRemoteFile:远程路径地址,httporFtpstrLocalFile:本地保存地址,ifstrLocalFile==NULLthenCreateTempFileandreturnTempFile'sPath*//*0x40:增加Http上传时候的,附加其他文件HRESULTHttpAddPostFile([in]BSTRstrFileID,[in]BSTRstrFileName,[out,retval]long*pbool);参数:strFileID:文件的ID,供服务器端页面解析strFileName:本地文件地址*//*0x41,0x42.获取详细的修订信息。
GetRevCount([out,retval]long*pbool);GetRevInfo([in]longlIndex,[in]longlType,[out,retval]BSTR*pbool);例子如下*/varvCount;vCount=document.all.FramerControl1.GetRevCount();alert(vCount);varvOpt=0;varvDate;for(vari=1;i<=vCount;i++){vOpt=document.all.FramerControl1.GetRevInfo(i,2);if("1"==vOpt){vOpt="插入";}elseif("2"==vOpt){vOpt="删除";}else{vOpt="未知操作";}vDate=newString(document.all.FramerControl1.GetRevInfo(i,1));vDate=parseFloat(vDate);alert(vDate);dateObj=newDate(vDate);alert(dateObj.getYear()+"年"+dateObj.getMonth()+1+"月"+dateObj.getDate()+"日"+dateObj.getHours()+"时"+dateObj.getMinutes()+"分"+dateObj.getSeconds()+"秒");alert("用户:"+document.all.FramerControl1.GetRevInfo(i,0)+"\r\n操作:"+vOpt+"\r\n内容:"+document.all.FramerControl1.GetRevInfo(i,3));}/*0x43.设置基本信息:HRESULTSetValue([in]BSTRstrValue,[in]BSTRstrName,[out,retval]long*pbool);1.设置文件只读密码SetValue("password","::DOCPROP:PassWord");2.设置文件修改密码SetValue("password","::DOCPROP:WritePW");返回值:0正确-1:不支持此命令,请确定您的第二个参数没有传错-127:异常*///设置文件只读密码document.all.FramerControl1.SetValue("password","::DOCPROP:PassWord");//设置文件修改密码document.all.FramerControl1.SetValue("password","::DOCPROP:WritePW");/*0x44.设置文档变量,这个很少能用到HRESULTSetDocVariable([in]BSTRstrVarName,[in]BSTRstrValue,[in]longlOpt,[out,retval]long*pbool);strVarName:变量名strVlaue:变量值lOpt:操作类型,按位第一位为1:表示update域关联的第二位为1:表示如果没有这个变量则添加第三位为1:未来支持return:0:OK-127:异常*//*0x45:分页保存HRESULTSetPageAs([in]BSTRstrLocalFile,[in]longlPageNum,[in]longlType,[out,retval]long*pbool);strLocalFile:本地路径lPageNum:页数*/
2025/6/13 12:22:57 139KB web office word 在线
1
uint8_tProgram_verify(uint8_t*buff1,uint8_t*buff2,uint32_tcount);voidWB_Serial_NAND_Pageprogram_Pattern(uint8_taddh,uint8_taddl,uint8_t*program_buffer,uint32_tcount);voidWB_Serial_NAND_Program_Excute(uint8_taddh,uint8_taddl);/*statuscheck*/uint8_tWB_Check_Embedded_ECC();uint8_tWB_Check_Program_Erase_Fail_Flag();uint8_tWB_Read_Serial_NAND_StatusRegister(uint8_tsr_sel);voidWB_Serial_NAND_ReadyBusy_Check();uint32_tWB_NAND_Read_JEDEC_ID();uint8_tWB_Serial_NAND_bad_block_check(uint32_tpage_address);voidWB_Serial_NAND_LUT_Read(uint16_t*LBA,uint16_t*PBA);/*StackfunctionforW25Mseries*/voidWB_Die_Select(uint8_tselect_die);/*statusset*/voidWB_Enable_Embedded_ECC();voidWB_Disable_Embedded_ECC();voidWB_Enable_Buffer_mode();voidWB_Disable_Buffer_mode();voidWB_Serial_NAND_StatusRegister_Write_SR1(uint8_tSR1);voidWB_Serial_NAND_StatusRegister_Write_SR2(uint8_tSR2);voidWB_Serial_NAND_StatusRegister_Write_SR3(uint8_tSR3);voidWB_NAND_Reset();voidWB_Protect();voidWB_Unprotect();voidWB_Serial_NAND_LUT_Set(uint16_tLBA,uint16_tPBA);/*erasefunction*/voidWB_Serial_NAND_BlockErase(uint8_tPA_H,uint8_tPA_L);/*readfunction*/voidWB_Serial_NAND_PageDataRead(uint8_tPA_H,uint8_tPA_L);voidWB_Serial_NAND_Normal_Read(uint8_taddh,uint8_taddl,uint8_t*buff,uint32_tcount);voidWB_Serial_NAND_Continuous_Normal_Read(uint8_t*buff,uint32_tcount);
2025/6/11 15:24:57 7KB W25N01G
1
基于ssm的人脸识别餐厅订餐系统设计与实现环境要求:tomcat7.0+jdk1.7+数据库名:order用户名:root密码:123456如需修改或有出入,mybatis里修改登录:项目路径/userlogin.jsp项目路径/adminlogin.jsp若项目搭完404,请把项目buildpath一下(项目上右键),Tomcat7.0-remove,再addlibrary,serverruntime,Tomcat7.0加一次。
后台功能:菜系管理:添加修改菜系菜品管理:设置菜品价格图片,增删改查订单管理:处理菜单用户管理:管理员、用户管理人脸注册(对接百度ai接口)前台功能:菜单:点菜购物车:添加到购物车的菜品,提交订单到后台确认我的订单:订单列表收货,需先等待后台确认个人设置:设置个人信息,收货地址等人脸注册人脸识别说明:1、人脸识别id,ask等请更换自己的:项目/src/Chinasofti/utils/faceUtils.java中修改2、前后台人脸注册登录功能尚不完善,注册完用户不会写入数据库,用了百度人脸识别的demo。
如需正常使用人脸功能,请把注册登录方法里加上百度人脸识别返回的参数。
2025/6/10 22:39:21 23.33MB 人脸识别餐厅
1
共 682 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡