主頁 >  其他 > 《Android 開發藝術探索》筆記8--Android的Drawable

《Android 開發藝術探索》筆記8--Android的Drawable

2020-09-17 22:25:39 其他

    • Drawable簡介
    • Drawable的分類
      • BitmapDrawable
      • NinePatchDrawable
      • ShapeDrawable
      • LayerDrawable
      • StateListDrawable
      • LevelListDrawable
      • TransitionDrawable
      • InsetDrawable
      • ScaleDrawable
      • ClipDrawable
    • 自定義Drawable
  • 參看文章

Android的Drawable.png

Drawable簡介

Drawable表示一種影像的概念. **優點:**使用比自定義View的成本低, 非圖片型別的Drawable占用空間較小. Drawable本身是一個抽象類. 是所有Drawable物件的基類, 每個具體的Drawable都是其子類.

Drawable內部寬高通過getIntrinsicWidthgetIntrinsicHeight這兩個方法獲得. 需要注意這個內部寬高的概念針對不同的型別的Drawable, 對于圖片形成的Drawable內部寬高就是圖片的寬高. 而顏色所形成的Drawable沒有內部寬高的概念. Drawable的內部寬高不等于它的大小. 當作為View的背景的視圖, Drawable會被拉伸至View的同等大小.

Drawable的分類

BitmapDrawable

表示一張圖片, 在開發中直接參考原始圖片也可, 下面給出在XML中描述稍微完整的宣告

<?xml version="1.0" encoding="utf-8"?>

<bitmap

    xmlns:android="http://schemas.android.com/apk/res/android"

    android:src="@mipmap/ic_sample"

    android:antialias="true"

    android:dither="true"

    android:filter="true"

    android:gravity="top"

    android:mipMap="true"

    android:tileMode="repeat"

    >

</bitmap>

</pre>

  • src: 圖片的資源檔案id(AS下可能不會自動提示mipmap,直接寫入即可)
  • antialias: 圖片抗鋸齒.屬性值boolean 開啟可以讓圖片變得平滑.
  • dither: 抖動效果. 屬性值Boolean. 當圖片的像素配置和手機螢屏的像素配置不一致時,開啟此選項可以讓高質量的圖片在低質量的螢屏上繼續保持較好效果. 例如圖片模式為ARGB8888,而設備螢屏所支持為RGB555. 開啟可以讓圖片不會過于失真.
  • filter: 過濾效果. 當圖片尺寸被拉伸或者壓縮,可以保持較好的效果.
  • gravity: 可以對圖片進行定位. 可以使用|組合屬性使用. 可供使用的屬性
可選項含義
top放在頂部, 不改變圖片大小
bottom放在底部, 不改變圖片大小
left放在左端, 不改變圖片大小
right放在右端, 不改變圖片大小
center_vertical使圖片豎直居中, 不改變圖片大小
fill_vertical圖片豎直方向填充容器
center_horizontal使圖片水平居中, 不改變圖片大小
fill_horizontal圖片水平方向填充容器
center圖片同時水平和垂直居中, 不改變圖片大小
fill圖片水平和豎直方向均填充容器, 這是默認值
clip_vertical表示豎直方向的裁剪, 較少使用
clip_horizontal表示水平方向的裁剪, 較少使用
  • mipmap: 紋理映射 默認為false
  • tileMode: 平鋪模式. 有四種值: disable關閉平鋪模式(默認值), repeat普通平鋪開啟, mirror平鋪的同時,平鋪圖片做鏡面效果. clamp在原始圖片最右邊像素向右延伸

NinePatchDrawable

表示一張.9格式的圖片, .9圖片可以自動的根據所需要的寬高進行相應的縮放并保證不失真. 和BitmapDrawable使用一樣直接引入圖片即可. xml方式如下:

<?xml version="1.0" encoding="utf-8"?>

<nine-patch xmlns:android="http://schemas.android.com/apk/res/android"

    android:src="xxxx"

    android:dither="true"/>

</pre>

ShapeDrawable

這是一種通過顏色來構成的圖片, 它可以為純色的圖形, 也可以具有漸變的圖形. 以下是一個簡單使用方法

<?xml version="1.0" encoding="utf-8"?>

<shape xmlns:android="http://schemas.android.com/apk/res/android"

    android:shape="rectangle">

    <!--圓角-->

    <corners android:radius="50dp"/>

    <padding android:top="5dp"/>

    <!--填充-->

    <solid android:color="@color/colorPrimary"/>

    <!--gradient 和solid 互測驗性誰放在后面誰才有效-->

    <!--漸變-->

    <gradient android:angle="90"

        android:startColor="#f00"

        android:centerColor="#0f0"

        android:endColor="#00f"/>

    <!--邊框-->

    <stroke android:width="30dp"

        android:color="#ff0000" />

</shape>

</pre>

來說說具體的屬性都有什么

shape:

表示圖片的形狀, 有四個選項: rectangle()矩形, oval(橢圓), line(橫線), ring(圓環). 默認值為矩形. 另外linering這兩個選項必須要通過<stroke>標簽來指定線的寬度和顏色等資訊, 否則無法達到預期效果.當ring這個形狀還需要添加幾個屬性innerRadius圓環內半徑, thickness圓環的厚度,外半徑減去內半徑的距離. 還有兩個半分比的屬性.效果一樣. useLevel:基本都是用false, 否則可能無法到達預期的顯示效果,除非被當做LevelListDrawable
<corner>
表示shape的四個角度. 它只適用于矩形shape. 支持屬性總共有五個,一個Radius和四個頂角如topLeftRadius等等. Radius的優先級最低, 會被其他屬性覆寫.
<gradient>
它與<solid>標簽是互相互斥的. 其中solid表示純色填充, 而gradient則表示漸變效果.

有如下屬性:

  • android:angle –漸變的角度, 默認為0, 其值必須為45的倍數. 0表示從左到右, 90表示從下到上.
  • android:centerX –漸變的中心點橫坐標(范圍0~1)
  • android:centerY –漸變的中心點縱坐標(范圍0~1)
  • android:startColor –漸變的起始色
  • android:centerColor –漸變的中間色
  • android:endColor –漸變的結束色
  • android:gradientRadius –漸變半徑, 僅當android:type=”radial”時有效,**并且當type=”radial”**的時候必須宣告此屬性,否則崩潰
  • android:useLevel –一般為false.當Drawable作為StateListDrawable使用時為true
  • android:type –漸變的型別, 有linear(線性漸變), radial(徑向漸變), sweep(掃描線漸變)三種, 默認為線性漸變

看看type不同的格式什么樣子
<solid>
表示純色填充, 通過android:color來指定顏色
<stroke>
shape的描邊,有四個屬性. width描邊的寬度, color描邊的顏色, dashWidth組成虛線的線段的寬度, dashGap組成虛線的線段之間的間隔.
<padding>
這個表示空白, 但是他表示的不是shape的空白, 而是包含它的View的空白, 有上下左右四個屬性
<size>
Drawable有兩個方法獲得固有高度.getIntrinsicWidth(),getIntrinsicHeight(). 就是如果是圖片Drawable`那就是圖片的屬性大小. 如果不是那就是回傳-1. 如果size標簽設定了大小. 在方法回傳的時候就不再是-1. 但是作為View的背景, shape還會被拉伸或者縮為View的大小.

LayerDrawable

對應的標簽是<layer-list>, 他表示一個層次化得Drawable集合.通過將不同的Drawable放置在不同的層面上從而達到一種疊加的效果.

一個這種標簽可以包含多個item, 每個item表示一個Drawable. item的結構很簡單上下左右四個屬性加上id屬性和drawable屬性. 可以直接通過drawable屬性參考一個Drawable也可以在標簽寫個子標簽生成一個.

StateListDrawable

StateList對應<selector>標簽, 也是Drawable集合. 這個我們經常使用在開發中的按鈕狀態選擇器.

<?xml version="1.0" encoding="utf-8"?>

<selector

    xmlns:android="http://schemas.android.com/apk/res/android"

    android:constantSize="true"

    android:dither="true"

    android:variablePadding="false"

    >

   <!-- 只是列舉一下

   <item android:state_pressed="true" android:drawable="xxx"/>

   <item android:state_focused="true" android:drawable="xxx"/>

   <item android:state_hovered="true" android:drawable="xxx"/>

   <item android:state_pressed="true" android:drawable="xxx"/>

   <item android:state_selected="true" android:drawable="xxx"/>

   <item android:state_checkable="true" android:drawable="xxx"/>

   <item android:state_checked="true" android:drawable="xxx"/>

   <item android:state_enabled="true" android:drawable="xxx"/>

   <item android:state_activated="true" android:drawable="xxx"/>

   <item android:state_window_focused="true" android:drawable="xxx"/>

    -->

</selector>

select標簽對應有三個屬性

  • constantSize: 用于StateListDrawable的固有大小是否不隨著其狀態改變而改變的, 因為狀態的改變會切換不同的item的drawable, 而不同的drawable具有不同的固有大小. 如果為true那就是整個StateListDrawable固有大小是內部所有Drawable最大固有大小的值. false會隨之變化, 默認為false
  • dither: 是否開啟抖動效果, 默認為true
  • variablePadding: 表示padding是否隨著狀態的改變而改變, padding取得值是所有Drawable的最大值. 默認為false. 不會隨之改變.

<item>標簽也比較簡單, 指定一個drawable,并加一個狀態判斷值.

下面給出常見的狀態判斷

狀態含義
android:state_pressed表示按下狀態, 比如Button被按下后沒有松開時的狀態
android:state_focused表示View已經獲取了焦點
android:state_selected表示用戶選擇了View
android:state_checked表示用戶選中了View, 一般適用于CheckBox這類在選中和非選中之間切換的
android:state_enabled表示View當前是否可用

默認狀態的一定要放在最后一條, 因為系統是按照從上到下的順序查找. 只要找到任何一個匹配狀態的那么久結束了.

LevelListDrawable

LevelListDrawable對應于<level-list>標簽, 也表示一個Drawable集合, 集合中每一個Drawable都有一個等級的概念, 根據不同的等級LevelListDrawable會切換不同的對應的Drawable.

<?xml version="1.0" encoding="utf-8"?>

<level-list xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:drawable="@mipmap/ic_sample"

        android:maxLevel="2"

        android:minLevel="2"/>

    <item android:drawable="@mipmap/ic_launcher"

        android:maxLevel="1"

        android:minLevel="1"

        />

</level-list>

這里就相當于給每一個Drawable設定一個標識. level-list會根據這個標識去自己的item中查找. 默認等級為0, Level的取值在0~10000. 在給每個Item宣告等級的時候盡量最大和最小等級保持一致. 讓每個item都可以有一個唯一標識等級, 而避免有一些公共擁有等級的Item導致出現和我們預期的不符.

如果作為了背景, 那么獲得Drawable物件通過getLevel(), setLevel()來得到和設定不同的等級做到切換圖片的效果. 如果是ImageView那么通過前景設定其等級就可以,一定別忘了把Drawable設定前景再通過這種方式實作.

TransitionDrawable

對應著<transition>標簽, 它用于實作兩個Drawable之間的淡入淡出效果.

<transition xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:drawable="@mipmap/ic_sample"/>

    <item android:drawable="@mipmap/ic_launcher"/>

</transition>
TransitionDrawable drawable = (TransitionDrawable) iv_main.getBackground();
drawable.startTransition(5000);

這個沒什么好說的了, 很簡單. 注意一下如果是給ImageView設定前景的話那么不要用getBackground()來獲取了,通過getDrawable()來獲取.

InsetDrawable

InsetDrawable對應<inset>標簽, 它可以將其他Drawable內嵌到自己當中, 并可以在四周留出一定的距離. 當一個View希望自己的背景比自己的實際區域小的時候, 可以使用這個來實作.(相當于給使用的View增加了margin效果) LayerDrawable也可以實作此效果

<?xml version="1.0" encoding="utf-8"?>

<inset xmlns:android="http://schemas.android.com/apk/res/android"

    android:insetBottom="20dp"

    android:insetTop="50dp"

    android:insetRight="20dp"

    android:insetLeft="20dp">

    <shape >

        <solid android:color="#ffff00"/>

    </shape>

</inset>

ScaleDrawable

ScaleDrawable對應<scale>標簽, 他可以根據自己的等級level將制定的Drawable縮放到一定比例.

<?xml version="1.0" encoding="utf-8"?>

<scale xmlns:android="http://schemas.android.com/apk/res/android"

    android:drawable="@mipmap/ic_sample"

    android:scaleHeight="10%"

    android:scaleWidth="10%"

    android:scaleGravity="center">

</scale>

并在代碼中設定等級, 默認為0是不顯示ScaleDrawable

ScaleDrawable drawable = (ScaleDrawable) findViewById(R.id.activity_main).getBackground();

drawable.setLevel(1);

其中scaleHeightscaleWidth需要的是百分比值. 有點別扭, 如果你設定了10%, 那么實際的意義就是縮放了原大小的10%, 相當于去掉了設定的值. 最終呈現出來的是1-設定的百分比. 就是展現了90%.

而設定的等級會影響最終的圖片大小, 等級越大圖片越大. 最好等級控制到0~10000 最后.

ClipDrawable

ClipDrawable對應于<clip>標簽, 他可以根據自己當前的等級來裁剪Drawable, 裁剪的方向通過android:clipOrientationandroid:gravity這兩個屬性來共同控制.

<?xml version="1.0" encoding="utf-8"?>

<clip xmlns:android="http://schemas.android.com/apk/res/android"

    android:clipOrientation="horizontal"

    android:drawable="@mipmap/ic_sample"

    android:gravity="center">

</clip>

首先android:clipOrientation 如果引數添加水平 horizontal. 實際上是豎直切割, 保留垂直方向的完整. 如果是Vertical反之.

gravity有的屬性和BitmapDrawable中的gravity一樣. 這里現在是android:clipOrientation="horizontal"它是以水平方向做的垂直切割. 那么通過給gravity設定左 中 右就是left, center, right可以達到不同的效果.

重要的一點還有動態代碼設定等級, 要是不設定等級就是默認的0, 0就是切割掉100%的部分,所以剩下的部位為0也就是空的

ClipDrawable drawable = (ClipDrawable) findViewById(R.id.activity_main).getBackground();
drawable.setLevel(5000);

這個等級的數還是1~10000.

  • 等級為0那么意味著裁剪Drawable的**100%**部分. 什么東西沒有.空的
  • 等級為5000那么意味著裁剪Drawable的**50%**部分, 我上面的演示的圖片都是以等級為5000為標準測驗的
  • 等級為10000那么就意味的裁剪部分為Drawable的**100%**部分, 也就是完全顯示了.

可以看出來了, 綜合上面的看出, 上面的gravity的方向可以認為是從那邊開始進行裁剪保留.

自定義Drawable

一般Drawable都是作為View的背景圖, 或者ImageView的顯示圖片. 其作業原理核心就是draw()方法. 而系統會呼叫Drawabledraw()來繪制View的背景, 所以我們通過重寫draw()來實作自定義Drawable.

一般draw(), setAlpha(), setColorFilter(), 和getOpacity()都是要實作的 , draw()里面的具體實作和我們View的onDraw()很相似. 可以參考ShapeDrawableBitmapDrawable的原始碼去仿造實作.

在自定義的時候注意: 如果要定義的Drawable有固有的大小值, 那么最好重寫getIntrinsicWidth()getIntrinsicHeight()這兩個方法. 因為它會影響到View的wrap_content布局. 最后內部大小不一定等于Drawable的實際大小, Drawable實際大小可以通過getBound()來獲取.

參看文章

《Android 開發藝術探索》書集
《Android 開發藝術探索》 06-Android的Drawable

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/68864.html

標籤:其他

上一篇:Android Studio missing essential plugin org.jetbrains.android

下一篇:鴻蒙開發-撰寫應用程式第一個界面

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more