Case2 个人路径

# -*- encoding=utf8 -*-
__author__ = "admin、"
from airtest.core.api import *
from airtest.report.report import simple_report
from airtest.report.report import LogToHtml
from airtest.core.helper import G
from threading import Thread
from random import randint
from random import choice
from poco.drivers.android.uiautomation import AndroidUiautomationPoco
import logging
import traceback,sys
import time

auto_setup(__file__,devices=["Android://127.0.0.1:5037/A123456"])   #logdir默认为None
"""auto_setup(__file__,devices=["Android://127.0.0.1:5037/123","Android://127.0.0.1:5037/456"])多台设备的示例"""
"""https://mp.weixin.qq.com/s?__biz=MzUxMDc4NTkwMA==&mid=2247484283&idx=1&sn=a82976cfe898711cc560592942c52d74&scene=21#wechat_redirect"""
poco = AndroidUiautomationPoco(use_airtest_input=True, screenshot_each_action=False)

"""多机协作
poco2=AndroidUiautomationPoco(device=G.DEVICE_LIST[1],use_airtest_input=True,screenshot_each_action=False)
这里不能直接将设备号传入,否则AttributeError: 'str' object has no attribute 'adb'。G.DEVICE_LIST传入的是内存地址
实例化Poco的顺序  必须和auto_setup的顺序相一致"""


logger=logging.getLogger("airtest")
logger.setLevel(logging.ERROR)
class Case(object):

    def __init__(self):
        #初始化设备
        size = poco.get_screen_size()  #(720,1560)
        self.width = size[0]   #屏宽
        self.height = size[1]  #屏高

    def contacts(self):  #联系人
        os.system("adb shell am start -n com.google.android.contacts/com.android.contacts.activities.PeopleActivity")
        try:
            if poco("android.widget.LinearLayout").offspring("android:id/button2").exists:
                poco(text="跳过").click()
                sleep(1)
        except Exception as E:
            print("不需要跳过:%s" %(E))

        if poco(text="搜索联系人").exists():
            poco(text="搜索联系人").click()
            os.system("adb shell input text b")
            name = poco("com.google.android.contacts:id/cliv_name_textview")[0].get_text()
            Judgment_value=isinstance(name,str)    #True
            print(Judgment_value)
            if Judgment_value==True:
                pass
            else:
                print("请检查是否有联系人")
            sleep(1)
        keyevent("home")
    # def chrome_position(self):
    """守护线程"""
    #     try:
    #         if poco(text="www.baidu.com 想使用您设备的位置信息",name="com.android.chrome:id/text").wait(300).exists:
    #             poco(text="允许",name="com.android.chrome:id/positive_button").click()
    #     except:
    #         pass
    #     sleep(5)
    #
    # a_Thread=Thread(target=chrome_position)
    # a_Thread.setDaemon(True)
    # a_Thread.start()
    def chrome(self):    #chorme浏览器
        # size = poco.get_screen_size()  # 获取屏幕长宽比例
        # width = size[0]
        # height = size[1]
        start_pos = (0.5 * self.width,0.8 * self.height)
        end_pos = (0.5 * self.width, 0.2 * self.height)
        start_app("com.android.chrome")
        #os.system("adb shell am start com.android.chrome")
        try:
            poco(text="接受并继续").wait(3)
            poco(text="接受并继续").click()
            poco(text="不用了,谢谢").click()
            poco(text="搜索或输入网址", name="com.android.chrome:id/search_box_text").wait_for_appearance(4)
            poco(text="搜索或输入网址", name="com.android.chrome:id/search_box_text").click()
            text("www.baidu.com")
            sleep(5)
        except Exception as e:
            log(e,snapshot=True)
        try:
            sleep(6)
            poco("index-kw").click()  # 点击搜索
            text("爱奇艺")
            try:
                if poco(text="m.baidu.com 想使用您设备的位置信息", name="com.android.chrome:id/text").wait(300).exists:
                    poco(text="允许", name="com.android.chrome:id/positive_button").click()
            except:
                pass
            # poco("android.widget.LinearLayout").offspring("com.android.chrome:id/compositor_view_holder").offspring("android.webkit.WebView")[0].offspring("index-form").child("android.view.View").click()

            poco(text="爱奇艺", name="kw").wait_for_appearance(30)  # 超时30s
        except Exception as E:
            print("检查错误:%s" % (E))
        while True:
            if poco(text="下一页", name="android.widget.TextView").exists():  # 一直往下滑动,直到最底页
                break
            else:
                swipe(start_pos, end_pos, duration=0.5)
                sleep(0.5)

        for i in range(10):
            # duration 滑动时长 steps步长  fingers手指头数目
            swipe(end_pos, start_pos, duration=1, steps=6, fingers=1)  # 从继续往上滑动
        sleep(5)

        """滑动失败,待改动"""
        #swipe((width,0.5*height),(0,0.5*height))  #最左端的滑动


        poco("android.widget.LinearLayout").offspring("com.android.chrome:id/menu_button").click()  #添加书签
        sleep(2)
        touch(Template(r"收藏网址.png", record_pos=(-0.018, -0.915), resolution=(720, 1560)))  #书签星标 """书签星标元素无法定位,改用touch"""


        poco(text="爱奇艺", name="kw").click()  #定位爱奇艺输入框,删除,并重新输入
        for i in range(5):
            keyevent("67")
        text("腾讯视频")
        sleep(5)
        touch(Template(r"点击腾讯视频官网.png"))
        tengxun_click = (0.5 * self.width, 0.35 * self.height)
        touch(tengxun_click)
        poco(text="播放", name="android.widget.Button").click()
        for i in range(1, 8):
            keyevent("24")  #加大音量
        for i in range(1, 12):
            keyevent("25") #减少音量

        poco("android.widget.LinearLayout").offspring("com.android.chrome:id/menu_button").click()  # 添加书签
        sleep(2)
        touch(Template(r"收藏网址.png", record_pos=(-0.018, -0.915), resolution=(720, 1560)))  # 书签星标 """书签星标元素无法定位,改用touch"""

    def Clock(self):
        pass

    def Camera(self):
        screen = r"X:\Airtest\Test_Case.air\screen"  # 跑失败截图的路径
        report_path = r"X:\Airtest\Test_Case.air\report"  # 生成报告的路径
        report_name = report_path + time.strftime("%Y-%m-%d_%H_%M_%S", time.localtime()) + ".html"  # 报告的名字
        start_app("com.freeme.camera")  # 启动相机
        self.paizhao = poco("com.freeme.camera:id/shutter_button")
        try:
            def photo():  # 普通拍照
                poco(text="拍照").click()
                # poco(text="拍照").click()
                for i in range(5):
                    self.paizhao.click()

            def meiyan():  # 美艳
                poco(text="请问").click()
                for i in range(randint(3, 5)):
                    self.paizhao.click()

            def mengyan():
                poco(text="萌颜").click()
                for i in range(5):
                    self.paizhao.click()

            def xuhuan():
                poco(text="虚化").click()
                for i in range(5):
                    self.paizhao.click()

            def renxiang():
                poco(text="人像").click()
                for i in range(5):
                    self.paizhao.click()

            def guangjiao():
                poco(text="广角").click()
                for i in range(5):
                    self.paizhao.click()

            def shipin():  #摄像
                poco(text="视频").click()
                sleep(2)
                vss = poco("com.freeme.camera:id/btn_vss")
                resume = poco("com.freeme.camera:id/btn_pause_resume")
                random_action = [vss, resume]  # 一拍照  2暂停
                for i in range(5):
                    self.paizhao.click()  # 开启摄像
                    for q in range(5):
                        choice(random_action).click()
                    sleep(10)
                    self.paizhao.click()  # 停止


            def houzhi():
                photo()
                meiyan()
                # mengyan()
                # xuhuan()
                renxiang()

            def qianzhi():
                photo()
                meiyan()
                # mengyan()
                # xuhuan()
                renxiang()

            houzhi()  # 后置拍照
            poco("com.freeme.camera:id/camera_switcher").click()  # 切换 前置
            qianzhi()  # 前置拍照
            shipin()

        except:
            snapshot(filename=screen + time.strftime("%Y-%m-%d_%H_%M_%S", time.localtime()) + ".jpg", msg="跑失败的照片",
                     quality=80)  # 截图

            simple_report(__file__, logpath=r"X:\Airtest\Test_Case.air", output=report_name)
            self.Camera()  # 失败之后重来
        finally:
            simple_report(__file__, logpath=r"X:\Airtest\Test_Case.air", output=report_name)  #output不能接11.html   必须接绝对路径

    #simple_report()  #1、考虑怎么终端程序也会出报告
                      #2、跑多轮出多次报告


    def storage(self):
            pass
    def search(self):
        pass
    def stream_media(self):
        pass
    def GMail(self):
        pass
    def message(self):
        set_current(1)
        stop_app("com.google.android.apps.messaging/com.google.android.apps.messaging.ui.ConversationListActivity")  # 启动短信

        set_current(0)
        os.system(
            "adb -s A123456 shell am start -n com.google.android.apps.messaging/com.google.android.apps.messaging.ui.ConversationListActivity")  # 启动短信
        poco(text="开始聊天", name="com.google.android.apps.messaging:id/start_new_conversation_button").click()

        text("19914450031")
        sleep(2)
        text("你好他好才是真的好")
        # poco1(name="com.google.android.apps.messaging:id/compose_message_text").set_text("1212121")  #使用pooo也可以
        poco(name="com.google.android.apps.messaging:id/send_message_button_icon").click()
        keyevent("BACK")
        
a=Case()
a.Camera()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的文件内容,本文将详细解析“飞行弹道仿真”的核心知识点,主要涉及MATLAB编程环境下的弹道仿真实现过程。 ### 弹道仿真概述 弹道仿真是一种通过数学模型来预测导弹、炮弹等飞行器在空中飞行轨迹的技术。在军事、航天等多个领域都有着广泛的应用。对于弹道仿真的研究不仅有助于提升武器系统的精确度,还能帮助科研人员更好地理解空气动力学原理以及飞行器的动力特性。 ### MATLAB环境下弹道仿真的实现 #### 1. **初始化参数** 在代码中,作者首先对一系列变量进行了初始化处理。这些变量包括但不限于:质量(`m`), 速度(`V`), 高度(`H`)等关键物理量。此外,还定义了一些常量如重力加速度(`g`)、空气密度(`rho_air`)等。 #### 2. **地面高度分布设定** 通过设定地面高度随距离变化的函数(`x_d` 表示水平距离,`H_d` 表示对应的高度),可以模拟不同的地形特征。这里使用了一个分段函数来表示地面高度的变化情况。 #### 3. **动态方程与运动方程** - **动态方程**:描述了导弹受到的外力作用(推力、阻力、升力)以及重力对其运动状态的影响。 - 推力(`P`)、阻力(`X`)、升力(`Y`)等参数被用于计算导弹的速度和角度变化。 - 通过积分运算更新速度、角度等状态量。 - **运动方程**:描述了导弹在三维空间中的位置变化情况。 - 包括水平方向速度(`equ4_Kinematic_x`)、垂直方向速度(`equ5_Kinematic_y`)以及姿态角(`equ6_Kinematic_Theta`)的变化。 - 这些方程同样通过积分方法进行求解。 #### 4. **控制律设计** 控制律设计是确保导弹按照预定轨迹飞行的关键环节。例如,代码中采用了简单的PID控制策略来调整导弹的姿态角。具体地: - `k_phi` 和 `k_phidiff` 分别代表比例系数和微分系数。 - 通过调整这些系数的值,可以优化导弹的飞行性能,使其更加稳定且能够准确跟踪目标。 #### 5. **数值积分方法** 为了求解动态方程与运动方程,文中采用了一种数值积分方法(`integral_to_next`)。该方法可以近似计算出导弹在下一时刻的状态量(速度、角度等)。虽然具体的实现细节没有给出,但通常这类方法基于欧拉法或者更高级的龙格-库塔法等。 ### 结论 本文通过对“飞行弹道仿真”这一主题的深入探讨,不仅详细介绍了如何使用MATLAB进行弹道仿真,而且还重点讲解了其中涉及到的重要概念和技术细节,如地面高度分布设定、动态方程与运动方程、控制律设计以及数值积分方法等。对于希望深入了解弹道仿真技术的研究者来说,本文提供了丰富的参考资料和实施指南。通过这样的仿真研究,不仅可以提高导弹等飞行器的设计精度,还能为未来航空航天技术的发展提供强有力的支持。
项目:使用AngularJs编写的简单 益智游戏(附源代码)  这是一个简单的 javascript 项目。这是一个拼图游戏,也包含一个填字游戏。这个游戏玩起来很棒。有两个不同的版本可以玩这个游戏。你也可以玩填字游戏。 关于游戏 这款游戏的玩法很简单。如上所述,它包含拼图和填字游戏。您可以通过移动图像来玩滑动拼图。您还可以选择要在滑动面板中拥有的列数和网格数。 另一个是填字游戏。在这里你只需要找到浏览器左侧提到的那些单词。 要运行此游戏,您需要在系统上安装浏览器。下载并在代码编辑器中打开此项目。然后有一个 index.html 文件可供您修改。在命令提示符中运行该文件,或者您可以直接运行索引文件。使用 Google Chrome 或 FireFox 可获得更好的用户体验。此外,这是一款多人游戏,双方玩家都是人类。 这个游戏包含很多 JavaScript 验证。这个游戏很有趣,如果你能用一点 CSS 修改它,那就更好了。 总的来说,这个项目使用了很多 javascript 和 javascript 库。如果你可以添加一些具有不同颜色选项的级别,那么你一定可以利用其库来提高你的 javascript 技能。 演示: 该项目为国外大神项目,可以作为毕业设计的项目,也可以作为大作业项目,不用担心代码重复,设计重复等,如果需要对项目进行修改,需要具备一定基础知识。 注意:如果装有360等杀毒软件,可能会出现误报的情况,源码本身并无病毒,使用源码时可以关闭360,或者添加信任。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值