安卓小程序开发实验报告(微信小程序开发实训报告刘晓刚)
本篇文章给大家谈谈安卓小程序开发实验报告,以及微信小程序开发实训报告刘晓刚对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
- 1、写给Android开发者看的『微信小程序和Android开发的对比』
- 2、微信小程序开发的完整流程介绍,新手必读
- 3、微信小程序项目开发总结
- 4、!高分跪求帮忙写一个简单小程序的JAVA课程设计报告(内详!!)
写给Android开发者看的『微信小程序和Android开发的对比』
微信小程序近期可谓是动作频出,仅最近新增的能力就有:
种种迹象表明,微信对小程序的期望值是很大,所以在它推出的几个月效果没到达预期的情况下,之前的很多『克制』也就逐渐变成『放肆』了 —— 不过不管小程序以后的发展到底怎样,对我们开发者来发,多了解一些总是没有坏处的。
他山之石,可以攻玉。
对于是技术人来说,多了解一些不同的技术、不同的开发模式、不同的架构思想,提高技术『广度』,对于自己的成长是十分必要的。
所以,本文就是从一个 Android 开发者的角度,从项目工程方便切入,来分析一下『微信小程序』跟『Android App』开发上的一些异同。
『微信小程序』开发是一个相对较新的技术,希望通过本文,能让你对它多一些了解。
因为内容是从Android开发的角度来谈的,所以我假设你已经对 Android 开发比较熟悉了。并且对微信小程序的开发也比较感兴趣,如果要是再能有些 javascript、css 的基础的话那就更好了!
Android 开发我们已经比较熟悉——
作为对比,进行微信小程序开发所用的语言是这些——
wxml (WeiXin Markup Language) 基本约等于是 xml。微信之所以没有直接使用 xml ,可能是为了以后扩展方便一些(野心很大)。
同理, wxss (WeiXin Style Sheets) 基本约等于是 css。也是微信扩展了一些功能,比如统一的尺寸单位 rpx 。
对于 Android 来说,对于页面的描述基本上在 xml 中定义的,比如:
这是一个简单的典型的示例,这个文件就是描述了两部分内容:
some.wxss:
很明显可以看出:wxml 是负责了 页面结构 的展示;而 wxss 则负责了对 页面样式 的定义。
这种把结构和样式分离的做法,其实是延续了网页开发中的习惯(html + css)。
这样做的好处起码有两个:
——看起来还是挺简单的结构:
这三个文件用以描述小程序 app 相关的内容,他们的命名是固定这样的,位置也固定是在根目录下。
app.js 基本相当于 Android 中的 Application 类,文件中主要是有一个 App() 函数,来进行小程序的初始化操作。
app.json 的作用跟 Android 中的 AndroidMainifest.xml 文件很相似 —— 都是静态化的配置文件。
app.wxss 定义全局的样式 —— 其定义的样式会作用于每个页面。比如在 app.wxss 中加入:
就可以给所有的 text 控件添加 5px 的 padding 。
当然,页面本身的 xxPage.wxss 可以定义局部样式来覆盖全局样式。
根目录下的 utils 文件夹中有一个 util.js 文件,这个故名思意,是类似于 Java 中的一些工具类的存在。
utils 文件夹其实是一个非必须的结构,而它之所以出现在官方的 HelloWorld 工程中,是作为一个代表,表明了开发者在这里是可以自定义新的文件夹和结构的。微信小程序作为一个使用 js 来开发的平台,是可以使用许多第三方的 js 库的,对于这些第三方库,以及其他的图片资源等,都可以放到自定义的文件夹中。
pages 文件夹下包含两个子目录:index 和 logs ,两个目录的结构都是基本一样的,都是包含四个相同主名称的文件: xx.js、xx.wxml、xx.json、xx.wxss 这几个文件。
这样的一个典型结构表明它是一个小程序的页面,四个文件的作用分别是:
在视图的动态显示上,微信小程序使用了 数据绑定(data-binding) 的方式。
如果你之前使用过 AngularJS 或者 Vue.js 等这些流行的 js 框架,那么你肯定对 数据绑定 并不陌生。它是一种把一个控件的属性绑定到某个数据对象(view-model)的属性的方法,这样在改变数据对象属性的时候,所对应的控件属性也就会相应变化 —— 在开发中,这种方式会使得对 View 层的显示控制变得十分简单、自然。
基于此,软件工程的流行架构方式也在之前的 MVC 、 MVP 之外,又多了一个 —— MVVM(Model-View-ViewModel) 。
数据绑定 这种方式现在是如此的流行,以致于 Android 官方都出了一个 [Data Binding Library] ( ) 来支持数据绑定,但是由于成熟度等原因,目前还并没有成为主流,Android 中的主流视图显示方式,还是通过开发者手动给每个控件 set 数据。
—— 单从这一点上看,微信小程序的开发模式是比原生 Andorid 要『先进』一些的~ 😏
小程序虽然是和前端 H5 页面一样是用 js 来开发,但是由于它最终运行的平台不再是浏览器,而是和 App 的表现几无二致,所以页面的生命周期也是和 App 差不多的。
一个小程序页面的典型生命周期如下:
对比一下 Android 的 Activity 生命周期 :
微信小程序的页面生命周期稍微简单一些,但主要的思想跟 Activity 生命周期基本是一致的。
小程序的官方 IDE 是微信自己出品 微信Web开发者工具 ,它内置了一个小程序的运行环境,本质上是基于 Chrome 内核的一个浏览器框架,算是一个模拟器了。
——它虽然跟 Android 的各种高大上的模拟器相比起来略显简陋,但是基本该有的功能也基本都有(断点、Log、网络监控等),而且由于是基于浏览器内核的页面 DOM 解析,所以运行的速度也是像浏览器打开网页一样流畅,不会像 Android 模拟器那样对系统资源要求很高。
另外,在绑定了开发者账号之后,也可以用手机进行真机调试来调试小程序,所以也能在上线前用不同的机器来进行充分的兼容性测试。
总体来说,小程序作为一个新的形态,从开发的角度,它可以算作是一个【Native开发】和【H5开发】的结合,它吸收了原生开发和 H5 开发的优点。对于前端开发人员和原生开发人员来说,都可以在微信小程序中找到许多熟悉的东西。再细节的许多点这里就不在赘述了,大家如果有兴趣,可以自己上手去体验一下。
综上,自然也就有两种人特别适合去做小程序的开发——H5的前端开发人员,以及之前的 Android/iOS 原生 App 开发者。
微信小程序的开发总体来说是很简单的。
—— 对于前端开发者来说,了解一下原生 App 的一些相关思想即可,这些工作其实只要读一遍小程序的开发者指南基本就差不多了。
—— 而对于原生开发者来说,只要稍微补一下 js 的相关知识(html/css),也基本就差不多可以上手去做了。如果你之前恰好已经有过一些 js 的使用经验,那就不用多说了,花半个小时看一下小程序的文档,直接上!
关于作者 :
微信小程序开发的完整流程介绍,新手必读
自从跳一跳小程序游戏出现后,一夜之间,小程序就变得家喻户晓了,功能开发也越来越丰富,在微信搜一搜就会发现许多大品牌早已有自己的小程序了,越来越多的企业和商家都看中了这个风口,想快速开发出一款属于自己的小程序,那小程序开发的流程是怎样的呢?
一、准备好小程序开发所要用到的材料
企业开发小程序所需的材料有:
公司的营业执照、法人的手机号、身份证号、微信号扫描、认证单——用于微信公众号认证。
银行对公账号、银行开户许可证、企业网银——申请支付接口。
小程序logo、企业介绍。产品信息、联系方式等——小程序开发。
注: 个人可以申请微信小程序,但无法申请微信支付接口。
二、微信小程序开发的完整流程介绍
1. 设计原型图,把想要实现的功能大概画出来,这一步主要探讨的是逻辑思维,只有把逻辑理清楚了,后面的工作才会开展的更顺畅,需要客户和设计师反复沟通确定才可以实现,减少沟通过程中存在的一些误差。
2. 注册小程序账号,需要支付300元的认证费用,假如需要使用微信支付功能,那还要申请支付接口。
3. UI设计,UI设计师根据原型图、产品特点、公司文化等来设计界面,比较注重外观和细节,优质的界面会让人有流连忘返的感觉,让用户把小程序添加到收藏列表中。
4. 后端开发,根据原型图制作系统后台和开发相关接口,包括后台数据管理、和小程序前台交互的接口。小程序接口需要使用HTTPS,也就是服务器必须按照SSL证书,同时需要加入相关域名到管理后台。
5. 前端开发,小程序前端工程师除了制作界面外,还需要对接后台的接口来进行数据交互,从而制作出完整的流程,制作完成生成体验版,供大家内部测试。
6. 测试环节,小程序也讲究兼容性,测试人员要测一下开发出来的功能是否能正常使用,苹果和安卓版本是否会有误差,确保小程序的各项功能正常。
7. 最后提交申请上线,体验版测试通过后,管理员可以提交到平台审核,平台审核通过后即可发布上线,供所有平台用户使用。
微信小程序项目开发总结
1. 微信小程序知识总结和案例分析
微信小程序知识总结和案例分析 1.如何做好微信小程序数据分析
实时统计:即当前在线访问的用户数,包括:。
访问时长(0~30s,30s~60s,1min~3min,3min~5min,5min~10min,10min以上)。 访问页数(1页,2页,3~5页,6~10页,11~20页,20页以上)。
访问地域(全部,自由选择国家,地区组合)。 详细数据(一键生成小程序第一次访问时间,地域,访客类型,入口页面,最后停留页面,访问时长,访问页数)。
累计访问用户数:默认显示的是30天的数据,累计访问次数即小程序自上线到当前的所有访问用户数。 实时访问:访问小程序所有或单个页面的总次数,多个页面之间跳转,同个页面的重复访问计为多次访问(实时数据处理同步可能有15分钟以内的延迟,只统计已发布的线上版本使用数据)。
打开次数:昨日打开小程序总次数,用户从打开小程序到主动关小程序开发多少钱闭小程序或超时退出为一次。 访问次数:昨日访问小程序内所有页面总次数,多个页面之间的跳转,同一页面的重复访问计为多次访问。
访问人数:昨日访问小程序内所有页面的总用户数,同一用户多次访问不重复计。 新访问用户数:首次访问小程序页面的用户数,同一用户多次访问不重复计。
2.微信小程序有哪些商店案例
微信小程序商店很多的,想要找到一家好的商店小程序开发公司不容易,需要注意以下几方面:
第一,看美不美小程序从看到的第一眼到打开页面的整体都得好看。如果第三方公司给你提供的小程序你觉得页面很LOW,不好看一定影响转化率,丑的一定没有转化率。在这个拼颜值的年代,界面美不美观是块敲门砖。
如果你希望自己的小程序装修得非常漂亮,其实需要非常多的模块。如:图片轮播广告、视频播放、语音播放、公告、商品组件、店铺导航、关联链接、商品搜索等等。这就像积木一样,商家要根据自己品牌调性和商品特点,来个性化自定义自己的店铺。可以提供丰富的店铺模板、装修组件等选择,帮助店铺搭建。
第二、看快不快
如果一个小程序2s钟都没打开,你一定会关掉,没有人会等3s。所以,在正常4G环境下,小程序打开页面必须在2s之内,因为大部分是冲动型购买场景。所以小程序系统的访问速度必须非常快,比如说H5做到1s以内,小程序需要做到1.5s以内,如果第三方公司给你做的小程序慢于2s才打开,不建议你选择。
第三、看稳不稳定
小程序如果不稳定,给商家带来的损失是致命的。因为你做到一定程度时,做一次活动,一次群发和一次推广影响到的人群很庞大。当所有人都参与活动的时候,如果一次群发宕机访问不了,你就会失去了一大批用户。判断第三方公司做的小程序系统是不是稳定,你要看一年的稳定时间。
第四、看营销功能多不多
小程序没有关注行为,没有像公众号图文群发的功能。所以,营销功能要足够多,才能实现裂变。根据多年微商城的经验,比如多人拼团、分销员、好友瓜分券、多网点、限时折扣、优惠券、发券宝、秒杀等,这些都是很好实现裂变传播、推广获客、营销成交、留存复购的营销功能。
3.旅游小程序开发的优秀案例有哪些
小程序种类多,方便快捷,而对于旅游这种范围广,涉及多个产业群的产业可开发的小程序就更多了,包括食住行游娱购等六个主要方面。
旅游电商•在线交易在旅游出行中,包括机票预购、酒店预订、车辆预约以及门票购买等等,都可以在小程序实现。达到了方便快捷。
户外活动•组织报名通过微信小程序发布活动消息,借助微信好友、群聊和公众号分享传播,通过小程序进行活动报名。旅行社•虚拟货架打破门店空间限制,将传统产品手册同步至线上渠道,以虚拟货架的形式,展示门店产品和服务旅游景区•信息发布旅游景区及时高效的信息发布平台,通过小程序介绍景区资源,发布旅游信息,提供游玩攻略,参与游客互动。
旅游出行类小程序目前开发的案例:一家民宿是一个民宿预订平台,功能唯一,但高度专注,提 *** 品齐全,基本满足需求。一家民宿针对人们旅行住宿的需求,整合资源,力图为每一个自助出境游的华人提供住宿帮助,在小程序的开发上,该平台也以实用性作为了标准,携程作为国内OTA的领头羊,在规模上对其他同行保持了绝对的优势,携程也不仅仅再局限于在线旅游代理平台,实用性也远远超过了其它一些提供单一业务的平台,携程小程序同样具备完善的功能,从订酒店订车票车辆预约甚至定制旅游等都出现在首页面,个人中心一目了然,包含了出游每一个环节,提供一站式旅游服务这一直都是携程的主张。
旅游小程序的开发可不止这些主流的开发方向,因为与这些拥有资源和经验优势的大佬们没有可比性,可以尝试从细分垂直领域去开发小程序,旅行小账本就是非常另类的一个小程序,功能定位明确,也是旅途非常有必要的操作,在整个旅游服务环节能包车保持较高的使用频率,一直从游前贯穿到游后,并且还能作为数据留存,是游客产生依赖感。小程序中完全为了游客记账的方便而设计。
以上三种不同类别的小程序开发可为当前旅游业小程序开发提供借鉴思路。
4.案例分析实验总结
相关案例资料,熟悉了我们组的PPT流程。
我们组首先从书本入手查阅相关的资料,进而分析了案例的相关知识、优缺点等等,融合之后进行总结制作PPT。四、实验中遇到问题及解决方法1、不善于对知识点的总结与应用,总结资料能力多少都有些欠缺,经常锻炼这些能力是十分必要的。
2、对信息的处理不到位,考虑分析问题的时候不能做到全面细致,由于思考和理解存在局限性,应该听老师和同学的讲解来解决。3、对案例分析题中所涉及的知识,不能熟练的找出来。
而想到某一些知识点也不能很好的概括并加以分析说明。对有些财务政策比较陌生,以后应该多研读政策原文,理解政策精神。
4、语言表达能力有所欠缺,比较死板缺乏活力,以后要加强这方面的经验,继而有所提高。5、对于PPT的制作很陌生,遇到不少的困难。
再加上对方案进行比较、择优时,考虑得不够全面,分析得不够透彻。经常犯一些不必要的错误。
五、实验结论具体参见同学的【附页】:案例分析报告六、心得体会在我大三的下半学年,我们上了叫“财务管理案例分析”的实验课。短短两周的实验课程竟然是将近两年不见的赖老师给我们授课。
这令我万分的怀念。除了这一惊喜外,赖老师还给我们贮备了另一个惊喜:那就是赖氏特色的教学方式。
以前的实验课老师都是紧紧抓住书本,让我们做书本上的题、计算一类的。但是本次的校内实习,老师让同学们组成小组通过多个不同的案例进行分析,我们分成人数不等的小组,然后进行分工,有的查阅资料,有的制作PPT,有的是陈述人,有的是答辩人。
然后让我们团结协作做成PPT并用类似演讲的形式展示出来,然后又通过问答的环节,让全班同学都积极参与进来。当然回答问题的小组成员也要事前做足了充分的准备。
我们每天都有不同的案例或者一天就多个案例的进行着,除了小组案例分析外还有班级对抗赛、小组自由选择案例分析等等多方面的创新。这不但能熟悉财务管理这门学科中所涉及的知识和问题,让我们掌握了现实当中的多类企业的财务管理中面对的不同问题,这还锻炼了我们的思维思考、语言表达、组织能力等等。
我在小组中做过陈述人、资料查阅、还答辩了一个问题。这不仅加强了我的专业知识掌握度还加强了我的个人综合能力,从而为实际工作打下良好基础。
我们懂得了在案例中涉及教材上的知识点,从而对案例如何进行系统的分析。我们通过互联网进行资料查询,使我们对案例有了进一步的了解,更便于我们对其进行分析总结,并从中进行知识的扩展。
老式教学都是针对课本做计算做题,这无疑于纸上谈兵,在现实工作中,我们对于课本上的理论知识的运用是不太现实的,工作中的不定因素太多,而书本只是把理论性的东西写了出来。赖老师把我们从传统的教学模式中拉了出来,这个新式的教学方法很特别,常常带给我们不一样的全新感受。
这次试验对于我来说最大的收获是综合能力的提高,好比原来搜索资料的时候只知道看原文,从不知道还要标注作者、出版社、出版年限等等,还有就是PPT的使用,之前我很少制作PPT,运用得相当不熟练,制作出来的PPT也没有什么特色而且速度相当缓慢,现在的我对于这种软件有了比较充分的了解,做出来的效果也较之前好了不少速度也有了相应的提高。这对于我今后的工作帮助是很大的。
再一点就是同学之间的协作沟通,因为在之前的学习生活中很少与同学有这种知识的交流,所以也发现了每个人的想法是多么的不同,看问题的角度千奇百怪,这使得可能我找出来的资料,总结制作的同学觉得并没有用处,这也就锻炼了我的沟通能力和协作能力,几个同学也在这种沟通下更加的了解彼此,加深了我们的友谊。特别是我们组的人比较少,只有四个,而且相对于其他小组对于分工有着明确的划分,我们组则是机动性的时刻变化着,每个人都是身兼数职,所以我们就更加团结、更加了解彼此了。
不过对于我本人最大的锻炼则是作为陈述人在讲台上讲述PPT,这对于我来说是很难得的经历,因为我本人对于演讲主持这类的工作是不大热爱的,那么自然也就很陌生,当然这也就使我很紧张。讲解的也就比较生硬相对于其他小组的陈述相比之下就不是很有特色了,不过先不论我讲解的好坏,单单上台去讲这对于我已经是不小的突破了。
这成为我珍贵的经验。做了这么多天的案例分析,自然也就对于这些案例的知识点有了更深一步的认识,这使我的会计知识更加丰富了,理解的也更加透彻了。
还锻炼了我们的思维思考能力、语言表达能力、组织能力等等。要知道个人的综合能力的高低是在职场上获得成功的关键所在。
所以提高综合能力是多么的重要。
!高分跪求帮忙写一个简单小程序的JAVA课程设计报告(内详!!)
连连看java源代码
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
public class lianliankan implements ActionListener
{
JFrame mainFrame; //主面板
Container thisContainer;
JPanel centerPanel,southPanel,northPanel; //子面板
JButton diamondsButton[][] = new JButton[6][5];//游戏按钮数组
JButton exitButton,resetButton,newlyButton; //退出,重列,重新开始按钮
JLabel fractionLable=new JLabel("0"); //分数标签
JButton firstButton,secondButton; //分别记录两次被选中的按钮
int grid[][] = new int[8][7];//储存游戏按钮位置
static boolean pressInformation=false; //判断是否有按钮被选中
int x0=0,y0=0,x=0,y=0,fristMsg=0,secondMsg=0,validateLV; //游戏按钮的位置坐标
int i,j,k,n;//消除方法控制
public void init(){
mainFrame=new JFrame("JKJ连连看");
thisContainer = mainFrame.getContentPane();
thisContainer.setLayout(new BorderLayout());
centerPanel=new JPanel();
southPanel=new JPanel();
northPanel=new JPanel();
thisContainer.add(centerPanel,"Center");
thisContainer.add(southPanel,"South");
thisContainer.add(northPanel,"North");
centerPanel.setLayout(new GridLayout(6,5));
for(int cols = 0;cols 6;cols++){
for(int rows = 0;rows 5;rows++ ){
diamondsButton[cols][rows]=new JButton(String.valueOf(grid[cols+1][rows+1]));
diamondsButton[cols][rows].addActionListener(this);
centerPanel.add(diamondsButton[cols][rows]);
}
}
exitButton=new JButton("退出");
exitButton.addActionListener(this);
resetButton=new JButton("重列");
resetButton.addActionListener(this);
newlyButton=new JButton("再来一局");
newlyButton.addActionListener(this);
southPanel.add(exitButton);
southPanel.add(resetButton);
southPanel.add(newlyButton);
fractionLable.setText(String.valueOf(Integer.parseInt(fractionLable.getText())));
northPanel.add(fractionLable);
mainFrame.setBounds(280,100,500,450);
mainFrame.setVisible(true);
}
public void randomBuild() {
int randoms,cols,rows;
for(int twins=1;twins=15;twins++) {
randoms=(int)(Math.random()*25+1);
for(int alike=1;alike=2;alike++) {
cols=(int)(Math.random()*6+1);
rows=(int)(Math.random()*5+1);
while(grid[cols][rows]!=0) {
cols=(int)(Math.random()*6+1);
rows=(int)(Math.random()*5+1);
}
this.grid[cols][rows]=randoms;
}
}
}
public void fraction(){
fractionLable.setText(String.valueOf(Integer.parseInt(fractionLable.getText())+100));
}
public void reload() {
int save[] = new int[30];
int n=0,cols,rows;
int grid[][]= new int[8][7];
for(int i=0;i=6;i++) {
for(int j=0;j=5;j++) {
if(this.grid[i][j]!=0) {
save[n]=this.grid[i][j];
n++;
}
}
}
n=n-1;
this.grid=grid;
while(n=0) {
cols=(int)(Math.random()*6+1);
rows=(int)(Math.random()*5+1);
while(grid[cols][rows]!=0) {
cols=(int)(Math.random()*6+1);
rows=(int)(Math.random()*5+1);
}
this.grid[cols][rows]=save[n];
n--;
}
mainFrame.setVisible(false);
pressInformation=false; //这里一定要将按钮点击信息归为初始
init();
for(int i = 0;i 6;i++){
for(int j = 0;j 5;j++ ){
if(grid[i+1][j+1]==0)
diamondsButton[i][j].setVisible(false);
}
}
}
public void estimateEven(int placeX,int placeY,JButton bz) {
if(pressInformation==false) {
x=placeX;
y=placeY;
secondMsg=grid[x][y];
secondButton=bz;
pressInformation=true;
}
else {
x0=x;
y0=y;
fristMsg=secondMsg;
firstButton=secondButton;
x=placeX;
y=placeY;
secondMsg=grid[x][y];
secondButton=bz;
if(fristMsg==secondMsg secondButton!=firstButton){
xiao();
}
}
}
public void xiao() { //相同的情况下能不能消去。仔细分析,不一条条注释
if((x0==x (y0==y+1||y0==y-1)) || ((x0==x+1||x0==x-1)(y0==y))){ //判断是否相邻
remove();
}
else{
for (j=0;j7;j++ ) {
if (grid[x0][j]==0){ //判断第一个按钮同行哪个按钮为空
if (yj) { //如果第二个按钮的Y坐标大于空按钮的Y坐标说明第一按钮在第二按钮左边
for (i=y-1;i=j;i-- ){ //判断第二按钮左侧直到第一按钮中间有没有按钮
if (grid[x][i]!=0) {
k=0;
break;
}
else{ k=1; } //K=1说明通过了第一次验证
}
if (k==1) {
linePassOne();
}
}
if (yj){ //如果第二个按钮的Y坐标小于空按钮的Y坐标说明第一按钮在第二按钮右边
for (i=y+1;i=j ;i++ ){ //判断第二按钮左侧直到第一按钮中间有没有按钮
if (grid[x][i]!=0){
k=0;
break;
}
else { k=1; }
}
if (k==1){
linePassOne();
}
}
if (y==j ) {
linePassOne();
}
}
if (k==2) {
if (x0==x) {
remove();
}
if (x0x) {
for (n=x0;n=x-1;n++ ) {
if (grid[n][j]!=0) {
k=0;
break;
}
if(grid[n][j]==0 n==x-1) {
remove();
}
}
}
if (x0x) {
for (n=x0;n=x+1 ;n-- ) {
if (grid[n][j]!=0) {
k=0;
break;
}
if(grid[n][j]==0 n==x+1) {
remove();
}
}
}
}
}
for (i=0;i8;i++ ) { //列
if (grid[i][y0]==0) {
if (xi) {
for (j=x-1;j=i ;j-- ) {
if (grid[j][y]!=0) {
k=0;
break;
}
else { k=1; }
}
if (k==1) {
rowPassOne();
}
}
if (xi) {
for (j=x+1;j=i;j++ ) {
if (grid[j][y]!=0) {
k=0;
break;
}
else { k=1; }
}
if (k==1) {
rowPassOne();
}
}
if (x==i) {
rowPassOne();
}
}
if (k==2){
if (y0==y) {
remove();
}
if (y0y) {
for (n=y0;n=y-1 ;n++ ) {
if (grid[i][n]!=0) {
k=0;
break;
}
if(grid[i][n]==0 n==y-1) {
remove();
}
}
}
if (y0y) {
for (n=y0;n=y+1 ;n--) {
if (grid[i][n]!=0) {
k=0;
break;
}
if(grid[i][n]==0 n==y+1) {
remove();
}
}
}
}
}
}
}
public void linePassOne(){
if (y0j){ //第一按钮同行空按钮在左边
for (i=y0-1;i=j ;i-- ){ //判断第一按钮同左侧空按钮之间有没按钮
if (grid[x0][i]!=0) {
k=0;
break;
}
else { k=2; } //K=2说明通过了第二次验证
}
}
if (y0j){ //第一按钮同行空按钮在与第二按钮之间
for (i=y0+1;i=j ;i++){
if (grid[x0][i]!=0) {
k=0;
break;
}
else{ k=2; }
}
}
}
public void rowPassOne(){
if (x0i) {
for (j=x0-1;j=i ;j-- ) {
if (grid[j][y0]!=0) {
k=0;
break;
}
else { k=2; }
}
}
if (x0i) {
for (j=x0+1;j=i ;j++ ) {
if (grid[j][y0]!=0) {
k=0;
break;
}
else { k=2; }
}
}
}
public void remove(){
firstButton.setVisible(false);
secondButton.setVisible(false);
fraction();
pressInformation=false;
k=0;
grid[x0][y0]=0;
grid[x][y]=0;
}
public void actionPerformed(ActionEvent e) {
if(e.getSource()==newlyButton){
int grid[][] = new int[8][7];
this.grid = grid;
randomBuild();
mainFrame.setVisible(false);
pressInformation=false;
init();
}
if(e.getSource()==exitButton)
System.exit(0);
if(e.getSource()==resetButton)
reload();
for(int cols = 0;cols 6;cols++){
for(int rows = 0;rows 5;rows++ ){
if(e.getSource()==diamondsButton[cols][rows])
estimateEven(cols+1,rows+1,diamondsButton[cols][rows]);
}
}
}
public static void main(String[] args) {
lianliankan llk = new lianliankan();
llk.randomBuild();
llk.init();
}
}
//old 998 lines
//new 318 lines
参考资料:
安卓小程序开发实验报告的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于微信小程序开发实训报告刘晓刚、安卓小程序开发实验报告的信息别忘了在本站进行查找喔。