同一圖層,同一顏色,同一文字樣式的文字,打印成PDF時(shí),打印預(yù)覽顯示全部文字,但確定,打印成PDF后,打開PDF,只顯示部分字體,是什么地方出了問題?如下圖所示。

1.png

打印效果和預(yù)覽效果

光看描述我無法知道是什么原因,我懷疑是打印驅(qū)動(dòng)或圖的問題,就讓這位朋友把圖發(fā)給我。收到圖后我在AutoCAD 2011版上用內(nèi)置的dwg to pdf的驅(qū)動(dòng)試了一下,確實(shí)如此,現(xiàn)象很容易就重現(xiàn)了,并且很快地找到了問題。

這個(gè)問題也比較特殊,不知道其他人是否遇到過,估計(jì)不常見。之所以寫下來,主要是想將我分析問題的思路跟大家分享一下,希望對(duì)大家有幫助。

打印完P(guān)DF后,我首先看哪些文字是打印出來的,哪些文字是沒有打印出來的,然后我在圖中分別選中了一個(gè)可以打印和一個(gè)不能打印的文字,打開屬性框(CTRL+1)。我們來看看他們有哪些共同屬性,哪些不同的屬性,如下圖所示。

2.png

從屬性框中可以看出兩個(gè)文字是單行文字,圖層相同,文字樣式相同,只是寬度因子不同。其實(shí)從圖面上也可以看出來文字的寬度不同,而且一個(gè)邊界比較平滑,一個(gè)則能看到一些鋸齒。

為了看到比屬性框更多的信息,我輸入LI(LIST)命令,進(jìn)一步查看一下這兩個(gè)文字的參數(shù),如下圖所示。

3.png

從這里可以看到兩個(gè)文字的寬度因子分別是1和0.9,可以打印出來的是0.9,我嘗試將寬度因子為1的寬度因子改為0.9,這些字就能打印出來了。但我感覺這應(yīng)該不是問題根源所在,而且也想不通為什么0.9就能打印出來,而1就打印不出來呢!

在上圖中我還注意到一個(gè)細(xì)節(jié),就是這個(gè)文字樣式的字體是simplex。字體名后面沒有帶shx,說明用的是操作系統(tǒng)的字體simplex.ttf,而不是CAD字體simplex.shx。跟CAD的simplex.shx字體類似,simplex也只有單字體字符,不包含漢字,哪些漢字是如何顯示出來的呢?

輸入ST,打開文字樣式對(duì)話框,發(fā)現(xiàn)這個(gè)文字樣式真的很奇怪,如下圖所示。

4.png

這個(gè)文字樣式設(shè)置的字體是simplex,“使用大字體”勾選框是灰的,而且右側(cè)“字體樣式”下拉列表被激活了,說明使用的是系統(tǒng)字體。這個(gè)字體不包括中文,國(guó)內(nèi)幾乎不可能有人這么設(shè)置字體,而圖中的中文只所以能顯示,是CAD采取了自動(dòng)替換的策略,應(yīng)該被替換成了宋體顯示了。我們選跟simplex類似的SHX字體試一下,就知道正常顯示的時(shí)候是什么狀態(tài)。在字體名列表中選一種其他的SHX文件,然后在選回simplex.shx,如下圖所示。

5.png

如果點(diǎn)“應(yīng)用”按鈕使用這種設(shè)置并關(guān)閉文字樣式對(duì)話框,然后輸入RE命令重生成圖形,你會(huì)發(fā)現(xiàn)剛才那些漢字都變成了問號(hào),這才是這種文字樣式設(shè)置下中文的正常狀態(tài),如下圖所示。

6.png

顯然這張圖的文字樣式的數(shù)據(jù)有錯(cuò)誤,本身樣式設(shè)置是無法顯示中文的,但CAD的自動(dòng)替換蒙蔽了我們,使我們想不到是文字樣式的問題。我將文字樣式修改成能顯示漢字的字體,例如直接在字體列表里選擇“新宋體”,或者勾選“使用大字體”后,大字體選擇hztxt.shx,然后再打印,就完全正常了,所有文字都可以正常打印了。

雖然這個(gè)問題解決了,這個(gè)里面還是有兩個(gè)疑問:

1、為什么文字樣式會(huì)變成這樣?

2、為什么之前寬度因子為0.9的可以打印出來,而寬度因子為1的卻打印不出來?

對(duì)于問題1我也無法解釋得很清楚。從這位朋友的說明和文字樣式的名稱來看,這張圖是天正建筑繪制的圖紙,然后進(jìn)行了轉(zhuǎn)換,可能在天正高版本轉(zhuǎn)天3文件時(shí)數(shù)據(jù)轉(zhuǎn)換導(dǎo)致了這種錯(cuò)誤,AutoCAD2007以后版本與之前版本格式之間相互轉(zhuǎn)換也會(huì)出現(xiàn)文字樣式的字體出現(xiàn)錯(cuò)誤的問題,比如以前我見過字體設(shè)置為宋體被解析錯(cuò)導(dǎo)致漢字顯示不正確的狀況。之前我從來沒見過國(guó)內(nèi)在文字樣式中用操作系統(tǒng)的simplex字體的,而且這張圖中字體替換成宋體后很多文字都超出了表格邊框,我猜測(cè)這張圖原始的字體設(shè)置應(yīng)該是simplex.shx加上一種大字體,在轉(zhuǎn)存或轉(zhuǎn)換的過程中,simplex.shx被寫成simplex,后面的大字體自然就丟失了。這種文字樣式雖然轉(zhuǎn)錯(cuò)了,但對(duì)于CAD講這種文字樣式也是正確的,所以修復(fù)圖紙也無法解決這個(gè)問題,必須手動(dòng)解決。

至于問題2我通過驗(yàn)證確認(rèn)了我的猜測(cè)。CAD在打印輸出PDF時(shí),如果文字使用的是操作系統(tǒng)的TTF字體,而且寬度因子是1,就會(huì)保留原有的字體和文字,在PDF文件中我們可以選中這些文字,而寬度因子不是1的,在輸出PDF的時(shí)候則會(huì)轉(zhuǎn)換為圖形,再PDF中無法選中,如下圖所示。

7.png

我想CAD輸出PDF的流程可能是這樣的:在輸出成PDF文件時(shí),寬度因子不是1的文字CAD先按錯(cuò)誤的文字樣式生成了圖形數(shù)據(jù)寫入了PDF文件,而寬度因子是1的文字則將文字內(nèi)容和字體寫入了PDF文件,而寫入的字體是simplex,PDF查看器中能找到這個(gè)字體,但這個(gè)字體中根本就沒有漢字,因此那些正常寬度的漢字無法顯示。而打印預(yù)覽跟圖形窗口顯示的流程類似,能顯示的文字在打印預(yù)覽中都能看到。

通過上面的記錄和分析,不僅希望能幫助遇到同類問題的朋友,也希望能給其他人一些啟發(fā),自己遇到問題能快速找到解決辦法,避免在一個(gè)問題上耽誤太多時(shí)間。

如果打印成PDF后不需要文字是可修改狀態(tài),可以直接在PDF的打印特性中直接設(shè)置將所有文字輸出為圖形

,如下圖所示。

8.png

不同CAD版本PDF打印驅(qū)動(dòng)的特性不完全相同,只要找到文字處理成幾何圖形的選項(xiàng),勾選上即可。