#1、#2です。
修正しました。これでたぶんどこのセル範囲でも大丈夫だと思います。
なお画面の右の方だったり下のほうだったりした時にユーザーフォームが切れるのは直していませんので悪しからず。
----------------
Sub test()
Dim x As Long
Dim y As Long
Dim str As String
Dim rng As Range
Dim adr As String
str = Selection.Address
If InStr(str, ":") = 0 Then
adr = str
Else
adr = Mid(str, InStr(str, ":") + 1, Len(str) - InStr(str, ":"))
End If
Set rng = Range(adr).Offset(1, 1)
x = ActiveWindow.PointsToScreenPixelsX(0) * 72 / 96 + rng.Left * ActiveWindow.Zoom / 100
y = ActiveWindow.PointsToScreenPixelsY(0) * 72 / 96 + rng.Top * ActiveWindow.Zoom / 100
Load UserForm1
With UserForm1
.StartUpPosition = 0
.Left = x
.Top = y
End With
UserForm1.Show
End Sub
手抜きなところが多々ありますが、こんな感じでどうでしょうか。
セル範囲選択してマクロ実行するとフォームが選択範囲の右下に表示されます。
選択範囲が画面の右のほうだったり下のほうだったりするとユーザーフォームが見切れて表示されてしまいますのでご注意を。
---------------------
Sub test()
Dim x As Long
Dim y As Long
Dim str As String
Dim rng As Range
str = Selection.Address
Set rng = Range(Right(str, 4)).Offset(1, 1)
x = ActiveWindow.PointsToScreenPixelsX(0) * 72 / 96 + rng.Left * ActiveWindow.Zoom / 100
y = ActiveWindow.PointsToScreenPixelsY(0) * 72 / 96 + rng.Top * ActiveWindow.Zoom / 100
Load UserForm1
With UserForm1
.StartUpPosition = 0
.Left = x
.Top = y
End With
UserForm1.Show
End Sub
--------------
私もいろいろ調べながら書いてみましたので、細かいところのフォローはできかねますのでご容赦ください。
お礼
昨日の今日で。。お忙しい中、完璧なご回答をありがとう御座いました♪ さらりと書いてあるコードですが、全く思いつく所が無く感服しております。 また別質問する際は宜しくお願い致します<(_ _)> ご覧頂いてご検討して頂いた方々もいらっしゃるかと思いますが ありがとうございました。